/*
* Copyright (C) 2009 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 signature.compare.model.impl;
import java.lang.reflect.Field;
import java.util.Arrays;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Set;
import signature.compare.model.IDelta;
import signature.compare.model.DeltaType;
public abstract class SigDelta<T> implements IDelta<T> {
private T from;
private T to;
public SigDelta(T from, T to) {
this.from = from;
this.to = to;
}
public final T getFrom() {
return from;
}
public final T getTo() {
return to;
}
public final DeltaType getType() {
if (from == null && to != null) {
return DeltaType.ADDED;
}
if (from != null && to == null) {
return DeltaType.REMOVED;
}
return DeltaType.CHANGED;
}
private static <T extends IDelta<?>> Set<T> getDeltas(Set<T> deltas,
DeltaType type) {
Set<T> addedElements = new HashSet<T>();
for (T delta : deltas) {
if (type.equals(delta.getType())) {
addedElements.add(delta);
}
}
return addedElements;
}
public static <T extends IDelta<?>> Set<T> getAdded(Set<T> deltas) {
return getDeltas(deltas, DeltaType.ADDED);
}
public static <T extends IDelta<?>> Set<T> getRemoved(Set<T> deltas) {
return getDeltas(deltas, DeltaType.REMOVED);
}
public static <T extends IDelta<?>> Set<T> getChanged(Set<T> deltas) {
return getDeltas(deltas, DeltaType.CHANGED);
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append(getClass().getSimpleName());
builder.append(":\n");
List<Field> allFields = new LinkedList<Field>();
Class<?> actualClass = getClass();
// add all fields / super classes also
do {
allFields.addAll(Arrays.asList(actualClass.getDeclaredFields()));
actualClass = actualClass.getSuperclass();
} while (actualClass != Object.class);
builder.append("from: ");
builder.append(from);
builder.append("\nto: ");
builder.append(to);
builder.append("\n");
try {
for (Field field : allFields) {
if (!ignore.contains(field.getName())) {
field.setAccessible(true);
Object delta = field.get(this);
if (delta != null) {
builder.append(field.getName());
builder.append(":\n");
builder.append(delta);
}
}
}
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (SecurityException e) {
e.printStackTrace();
}
return builder.toString();
}
private static Set<String> ignore = new HashSet<String>();
{
ignore.add("from");
ignore.add("to");
ignore.add("reason");
ignore.add("ignore"); // =)
}
}