/******************************************************************************* * Copyright (c) 2000, 2009 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * IBM Corporation - initial API and implementation *******************************************************************************/ package org.eclipse.core.resources; import java.util.Map; /** * A marker delta describes the change to a single marker. A marker can either be added, removed or * changed. Marker deltas give access to the state of the marker as it was (in the case of deletions * and changes) before the modifying operation occurred. * * @noimplement This interface is not intended to be implemented by clients. * @noextend This interface is not intended to be extended by clients. */ public interface IMarkerDelta { /** * Returns the object attribute with the given name. The result is an instance of one of the * following classes: <code>String</code>, <code>Integer</code>, or <code>Boolean</code>. * Returns <code>null</code> if the attribute is undefined. The set of valid attribute names is * defined elsewhere. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @param attributeName the name of the attribute * @return the value, or <code>null</code> if the attribute is undefined. */ public Object getAttribute(String attributeName); /** * Returns the integer-valued attribute with the given name. Returns the given default value if * the attribute is undefined or is not an integer value. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @param attributeName the name of the attribute * @param defaultValue the value to use if the attribute does not exist * @return the value or the default value if the attribute is undefined. */ public int getAttribute(String attributeName, int defaultValue); /** * Returns the string-valued attribute with the given name. Returns the given default value if * the attribute is undefined or is not a string value. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @param attributeName the name of the attribute * @param defaultValue the value to use if the attribute does not exist * @return the value or the default value if the attribute is undefined. */ public String getAttribute(String attributeName, String defaultValue); /** * Returns the boolean-valued attribute with the given name. Returns the given default value if * the attribute is undefined or is not a boolean value. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @param attributeName the name of the attribute * @param defaultValue the value to use if the attribute does not exist * @return the value or the default value if the attribute is undefined. */ public boolean getAttribute(String attributeName, boolean defaultValue); /** * Returns a Map with all the attributes for the marker. The result is a Map whose keys are * attributes names and whose values are attribute values. Each value an instance of one of the * following classes: <code>String</code>, <code>Integer</code>, or <code>Boolean</code>. If the * marker has no attributes then <code>null</code> is returned. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @return a map of attribute keys and values (key type : <code>String</code> value type : * <code>String</code>, <code>Integer</code>, or <code>Boolean</code>) or * <code>null</code>. */ public Map getAttributes(); /** * Returns the attributes with the given names. The result is an array whose elements correspond * to the elements of the given attribute name array. Each element is <code>null</code> or an * instance of one of the following classes: <code>String</code>, <code>Integer</code>, or * <code>Boolean</code>. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @param attributeNames the names of the attributes * @return the values of the given attributes. */ public Object[] getAttributes(String[] attributeNames); /** * Returns the id of the marker. The id of a marker is unique relative to the resource with * which the marker is associated. Marker ids are not globally unique. * * @return the id of the marker */ public long getId(); /** * Returns the kind of this marker delta: one of <code>IResourceDelta.ADDED</code>, * <code>IResourceDelta.REMOVED</code>, or <code>IResourceDelta.CHANGED</code>. * * @return the kind of marker delta * @see IResourceDelta#ADDED * @see IResourceDelta#REMOVED * @see IResourceDelta#CHANGED */ public int getKind(); /** * Returns the marker described by this change. If kind is <code>IResourceDelta.REMOVED</code>, * then this is the old marker, otherwise this is the new marker. Note that if the marker was * deleted, the value returned cannot be used to access attributes. * * @return the marker */ public IMarker getMarker(); /** * Returns the resource with which this marker is associated. * * @return the resource */ public IResource getResource(); /** * Returns the type of this marker. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @return the type of this marker */ public String getType(); /** * Returns whether the type of this marker is considered to be a sub-type of the given marker * type. * <p> * If kind is <code>IResourceDelta.ADDED</code>, then the information is from the new marker, * otherwise it is from the old marker. * </p> * * @return boolean <code>true</code>if the marker's type is the same as (or a sub-type of) the * given type. */ public boolean isSubtypeOf(String superType); }