Record Class Trace
java.lang.Object
java.lang.Record
org.variantsync.diffdetective.variation.tree.view.relevance.Trace
- All Implemented Interfaces:
Predicate<VariationNode<?,,?>> Source,Relevance
Relevance predicate that traces a certain feature syntactically within a variation tree.
This relevance predicate is the implementation of Equation 6 in our SPLC'23 paper.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final StringThe field for thefeatureNamerecord component. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal booleanIndicates whether some other object is "equal to" this one.Returns the value of thefeatureNamerecord component.Returns a list of arguments required to understand this source.Returns a short, one line explanation or identifier of this source.final inthashCode()Returns a hash code value for this object.booleantest(VariationNode<?, ?> v) toString()Returns a string representation of this record class.Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.variantsync.diffdetective.variation.tree.view.relevance.Relevance
computeViewNodesMethods inherited from interface org.variantsync.diffdetective.util.Source
fullExplanation, functionExplanation, getRootSource, getSources, shallowExplanation
-
Field Details
-
featureName
The field for thefeatureNamerecord component.
-
-
Constructor Details
-
Trace
Creates an instance of aTracerecord class.- Parameters:
featureName- the value for thefeatureNamerecord component
-
-
Method Details
-
test
- Specified by:
testin interfacePredicate<VariationNode<?,?>>
-
getSourceArguments
Description copied from interface:SourceReturns a list of arguments required to understand this source. Each argument in the result list should represent astringwithout newlines and will be formatted together withSource.getSourceExplanation()like"sourceExplanation(argument1, argument2)"bySource.shallowExplanation(). This method is only intended to access the arguments forprinting. In case access to the well-typed object is required, useSource.<T>findFirst(org.variantsync.diffdetective.util.Source,java.lang.Class<T>)orSource.<T>findAll(org.variantsync.diffdetective.util.Source,java.lang.Class<T>)and use the accessors of the underlying type.For ease of implementing
Source, the return value is a list ofObjects instead of a list ofStrings to allow code likeList.of(arg0, arg1, arg2)instead ofList.of(arg0.toString(), arg1.toString(), arg2.toString()). Users of this function should assume nothing from the returned objects except thatObject.toString()is well behaved.- Specified by:
getSourceArgumentsin interfaceSource- Returns:
- an empty list by default
- See Also:
-
getSourceExplanation
Description copied from interface:SourceReturns a short, one line explanation or identifier of this source. The result is used bySource.shallowExplanation()and is formatted together withSource.getSourceArguments()like"sourceExplanation(argument1, argument2)".- Specified by:
getSourceExplanationin interfaceSource
-
toString
Returns a string representation of this record class. The representation contains the name of the class, followed by the name and value of each of the record components. -
hashCode
public final int hashCode()Returns a hash code value for this object. The value is derived from the hash code of each of the record components. -
equals
Indicates whether some other object is "equal to" this one. The objects are equal if the other object is of the same class and if all the record components are equal. All components in this record class are compared withObjects::equals(Object,Object). -
featureName
Returns the value of thefeatureNamerecord component.- Returns:
- the value of the
featureNamerecord component
-