Package org.jsoup.nodes
Class Range
java.lang.Object
org.jsoup.nodes.Range
public class Range extends Object
A Range object tracks the character positions in the original input source where a Node starts or ends. If you want to track these positions, tracking must be enabled in the Parser with
Parser.setTrackPosition(boolean) .
- Since:
- 1.15.2
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classstatic classA Position object tracks the character position in the original input source where a Node starts or ends. -
Constructor Summary
ConstructorsConstructorDescriptionRange(Range.Position start, Range.Position end) Creates a new Range with start and end Positions. -
Method Summary
Modifier and TypeMethodDescriptionend()Get the end position of this node.intendPos()Get the ending cursor position of this range.booleanequals(Object o) inthashCode()booleanChecks if the range represents a node that was implicitly created / closed.booleanTest if this source range was tracked during parsing.start()Get the start position of this node.intstartPos()Get the starting cursor position of this range.StringtoString()Gets a String presentation of this Range, in the formatline,column:pos-line,column:pos.Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Constructor Details
-
Method Details
-
start
Get the start position of this node.- Returns:
- the start position
-
startPos
public int startPos()Get the starting cursor position of this range.- Returns:
- the 0-based start cursor position.
- Since:
- 1.17.1
-
end
Get the end position of this node.- Returns:
- the end position
-
endPos
public int endPos()Get the ending cursor position of this range.- Returns:
- the 0-based ending cursor position.
- Since:
- 1.17.1
-
isTracked
public boolean isTracked()Test if this source range was tracked during parsing.- Returns:
-
true if this was tracked during parsing, false otherwise (and all fields will be
-1).
-
isImplicit
public boolean isImplicit()Checks if the range represents a node that was implicitly created / closed.For example, with HTML of
<p>One<p>Two, bothpelements will have an explicitNode.sourceRange(but an implicit) Element.endSourceRange(marking the end position, as neither have closing) </p>tags. The TextNodes will have explicit sourceRanges.A range is considered implicit if its start and end positions are the same.
- Returns:
- true if the range is tracked and its start and end positions are the same, false otherwise.
- Since:
- 1.17.1
-
equals
public boolean equals(Object o) - Overrides:
-
equalsin classObject
-
hashCode
public int hashCode()- Overrides:
-
hashCodein classObject
-
toString
public String toString()Gets a String presentation of this Range, in the formatline,column:pos-line,column:pos.- Overrides:
-
toStringin classObject - Returns:
- a String
-