SubwayTooter-Android-App/_Emoji/src/main/java/com/android/ide/common/blame/Message.java

195 lines
6.0 KiB
Java

/*
* Copyright (C) 2015 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.blame;
import com.android.annotations.NonNull;
import com.android.annotations.Nullable;
import com.android.annotations.concurrency.Immutable;
import com.google.common.base.MoreObjects;
import com.google.common.base.Objects;
import com.google.common.collect.ImmutableList;
import java.io.File;
import java.util.List;
@Immutable
public final class Message {
@NonNull
private final Kind mKind;
@NonNull
private final String mText;
@NonNull
private final List<SourceFilePosition> mSourceFilePositions;
@NonNull
private final String mRawMessage;
/**
* Create a new message, which has a {@link Kind}, a String which will be shown to the user and
* at least one {@link SourceFilePosition}.
*
* @param kind the message type.
* @param text the text of the message.
* @param sourceFilePosition the first source file position the message .
* @param sourceFilePositions any additional source file positions, may be empty.
*/
public Message(@NonNull Kind kind,
@NonNull String text,
@NonNull SourceFilePosition sourceFilePosition,
@NonNull SourceFilePosition... sourceFilePositions) {
mKind = kind;
mText = text;
mRawMessage = text;
mSourceFilePositions = ImmutableList.<SourceFilePosition>builder()
.add(sourceFilePosition).add(sourceFilePositions).build();
}
/**
* Create a new message, which has a {@link Kind}, a String which will be shown to the user and
* at least one {@link SourceFilePosition}.
* <p>
* It also has a rawMessage, to store the original string for cases when the message is
* constructed by parsing the output from another tool.
*
* @param kind the message kind.
* @param text a human-readable string explaining the issue.
* @param rawMessage the original text of the message, usually from an external tool.
* @param sourceFilePosition the first source file position.
* @param sourceFilePositions any additional source file positions, may be empty.
*/
public Message(@NonNull Kind kind,
@NonNull String text,
@NonNull String rawMessage,
@NonNull SourceFilePosition sourceFilePosition,
@NonNull SourceFilePosition... sourceFilePositions) {
mKind = kind;
mText = text;
mRawMessage = rawMessage;
mSourceFilePositions = ImmutableList.<SourceFilePosition>builder()
.add(sourceFilePosition).add(sourceFilePositions).build();
}
public Message(@NonNull Kind kind,
@NonNull String text,
@NonNull String rawMessage,
@NonNull ImmutableList<SourceFilePosition> positions) {
mKind = kind;
mText = text;
mRawMessage = rawMessage;
if (positions.isEmpty()) {
mSourceFilePositions = ImmutableList.of(SourceFilePosition.UNKNOWN);
} else {
mSourceFilePositions = positions;
}
}
@NonNull
public Kind getKind() {
return mKind;
}
@NonNull
public String getText() {
return mText;
}
/**
* Returns a list of source positions. Will always contain at least one item.
*/
@NonNull
public List<SourceFilePosition> getSourceFilePositions() {
return mSourceFilePositions;
}
@NonNull
public String getRawMessage() {
return mRawMessage;
}
@Nullable
public String getSourcePath() {
File file = mSourceFilePositions.get(0).getFile().getSourceFile();
if (file == null) {
return null;
}
return file.getAbsolutePath();
}
/**
* Returns a legacy 1-based line number.
*/
@Deprecated
public int getLineNumber() {
return mSourceFilePositions.get(0).getPosition().getStartLine() + 1;
}
/**
* @return a legacy 1-based column number.
*/
@Deprecated
public int getColumn() {
return mSourceFilePositions.get(0).getPosition().getStartColumn() + 1;
}
public enum Kind {
ERROR, WARNING, INFO, STATISTICS, UNKNOWN, SIMPLE;
public static Kind findIgnoringCase(String s, Kind defaultKind) {
for (Kind kind : values()) {
if (kind.toString().equalsIgnoreCase(s)) {
return kind;
}
}
return defaultKind;
}
@Nullable
public static Kind findIgnoringCase(String s) {
return findIgnoringCase(s, null);
}
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof Message)) {
return false;
}
Message that = (Message) o;
return Objects.equal(mKind, that.mKind) &&
Objects.equal(mText, that.mText) &&
Objects.equal(mSourceFilePositions, that.mSourceFilePositions);
}
@Override
public int hashCode() {
return Objects.hashCode(mKind, mText, mSourceFilePositions);
}
@Override
public String toString() {
return MoreObjects.toStringHelper(this).add("kind", mKind).add("text", mText).add("sources",
mSourceFilePositions).toString();
}
}