Record Class Search
java.lang.Object
java.lang.Record
org.variantsync.diffdetective.variation.tree.view.relevance.Search
- All Implemented Interfaces:
Predicate<VariationNode<?,,?>> Source,Relevance
Relevance predicate that searches for implementation artifacts in a variation tree.
This relevance predicate is the implementation of Equation 7 in our SPLC'23 paper.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final StringThe field for theartifactrecord component. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionartifact()Returns the value of theartifactrecord component.final booleanIndicates whether some other object is "equal to" this one.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
-
artifact
The field for theartifactrecord component.
-
-
Constructor Details
-
Search
Creates an instance of aSearchrecord class.- Parameters:
artifact- the value for theartifactrecord 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). -
artifact
Returns the value of theartifactrecord component.- Returns:
- the value of the
artifactrecord component
-