All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.android.ide.common.res2.MergingException Maven / Gradle / Ivy

There is a newer version: 25.3.0
Show newest version
/*
 * Copyright (C) 2013 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.android.ide.common.res2;

import com.android.annotations.NonNull;
import com.android.annotations.Nullable;

import java.io.File;

/** Exception for errors during merging */
public class MergingException extends Exception {
    private String mMessage; // Keeping our own copy since parent prepends exception class name
    private File mFile;
    private int mLine = -1;
    private int mColumn = -1;

    public MergingException(@NonNull String message, @Nullable Throwable cause) {
        super(message, cause);
        mMessage = message;
    }

    public MergingException(@NonNull String message) {
        this(message, null);
    }

    public MergingException(@NonNull Throwable cause) {
        this(cause.getLocalizedMessage(), cause);
    }

    public MergingException setFile(@NonNull File file) {
        mFile = file;
        return this;
    }

    public MergingException setCause(@NonNull Throwable cause) {
        initCause(cause);
        return this;
    }

    public MergingException setLine(int line) {
        mLine = line;
        return this;
    }

    public MergingException setColumn(int column) {
        mColumn = column;
        return this;
    }

    /** Computes the error message to display for this error */
    @Override
    public String getMessage() {
        StringBuilder sb = new StringBuilder();
        String path = null;
        if (mFile != null) {
            path = mFile.getAbsolutePath();
            sb.append(path);
            if (mLine >= 0) {
                sb.append(':');
                sb.append(Integer.toString(mLine));
                if (mColumn >= 0) {
                    sb.append(':');
                    sb.append(Integer.toString(mColumn));
                }
            }
        }

        if (sb.length() > 0) {
            sb.append(':').append(' ');

            // ALWAYS insert the string "Error:" between the path and the message.
            // This is done to make the error messages more simple to detect
            // (since a generic path: message pattern can match a lot of output, basically
            // any labeled output, and we don't want to do file existence checks on any random
            // string to the left of a colon.)
            if (!mMessage.startsWith("Error: ")) {
                sb.append("Error: ");
            }
        } else if (!mMessage.contains("Error: ")) {
            sb.append("Error: ");
        }

        String message = mMessage;

        // If the error message already starts with the path, strip it out.
        // This avoids redundant looking error messages you can end up with
        // like for example for permission denied errors where the error message
        // string itself contains the path as a prefix:
        //    /my/full/path: /my/full/path (Permission denied)
        if (path != null && message.startsWith(path)) {
            int stripStart = path.length();
            if (message.length() > stripStart && message.charAt(stripStart) == ':') {
                stripStart++;
            }
            if (message.length() > stripStart && message.charAt(stripStart) == ' ') {
                stripStart++;
            }
            message = message.substring(stripStart);
        }

        sb.append(message);
        return sb.toString();
    }

    @Override
    public String toString() {
        return getMessage();
    }

    /** @return the source file where the error occurred, if known */
    @Nullable
    public File getFile() {
        return mFile;
    }

    /** @return the 0-based line number, if known, otherwise -1 */
    public int getLine() {
        return mLine;
    }

    /** @return the 0-based column number, if known, otherwise -1 */
    public int getColumn() {
        return mColumn;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy