Class: PositionTarget
processTargets/targets/PositionTarget.PositionTarget
Hierarchy
↳
PositionTarget
Constructors
constructor
• new PositionTarget(parameters
)
Parameters
Name | Type |
---|---|
parameters | PositionTargetParameters |
Overrides
Defined in
processTargets/targets/PositionTarget.ts:22
Properties
hasExplicitRange
• hasExplicitRange: boolean
= true
If true
, then this target has an explicit range. This attribute is used
by "every"
to determine whether to return all scopes in the iteration
scope or just the ones that overlap with the given target's
contentRange.
Most targets have explicit ranges. As of writing this comment, the only targets that don't are as follows:
- a decorated mark (
"air"
), or - an empty cursor mark (
"this"
with an empty selection), or - an empty
"that"
mark (eg after saying"chuck air"
).
For example, when the user says "change every state air"
, we clear every
statement in the function, but "change every state this"
with a non-empty
selection will only target statements overlapping the cursor.
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:31
hasExplicitScopeType
• hasExplicitScopeType: boolean
= true
If true
, then this target has an explicit scope type, and so should never
be automatically expanded to a containing scope.
Examples of targets that have explicit scopes are ScopeTypeTarget
(eg "funk"
), TokenTarget (eg "token"
), etc.
As of writing this comment, the only target type that doesn't have an explicit scope type is UntypedTarget, which can be constructed by
- using a decorated mark (
"air"
), or - using any cursor mark (
"this"
), or - using a range between decorated marks or cursor marks (eg
"past air"
or"air past bat"
), or - using any
"that"
mark (eg after saying"copy air"
), though this final behaviour will change with #466.
The primary consumer of this attribute is ModifyIfUntypedStage,
which is used in the following situations to automatically expand to a
particular scope type when hasExplicitScopeType
is false
:
- To expand to
"line"
for"pour"
,"clone"
, and"breakpoint"
- To expand to
"token"
for"leading"
and"trailing"
- To expand to nearest containing pair for
"inside"
,"bounds"
, and"rewrap"
- To expand to SnippetVariable.wrapperScopeType for snippet wrapping
- To expand to Snippet.insertionScopeTypes for snippet insertion
For example, when the user says "pour air"
, the
{@link DecoratedSymbolStage} will return an UntypedTarget, which
has hasExplicitScopeType=false
, so "pour"
will expand to the line
containining the air token and insert a newline after it.
Inherited from
BaseTarget.hasExplicitScopeType
Defined in
processTargets/targets/BaseTarget.ts:30
indentationString
• Private
indentationString: string
Defined in
processTargets/targets/PositionTarget.ts:20
insertionDelimiter
• insertionDelimiter: string
If this selection has a delimiter use it for inserting before or after the target. For example, new line for a line or paragraph and comma for a list or argument
Overrides
Defined in
processTargets/targets/PositionTarget.ts:15
isBefore
• Private
isBefore: boolean
Defined in
processTargets/targets/PositionTarget.ts:19
isLine
• isLine: boolean
= false
If true this target should be treated as a line
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:29
isLineDelimiter
• Private
isLineDelimiter: boolean
Defined in
processTargets/targets/PositionTarget.ts:18
isNotebookCell
• isNotebookCell: boolean
= false
If true this target is a notebook cell
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:33
isRaw
• isRaw: boolean
If true this target is a raw selection and its insertion delimiter should not be used on bring action
Overrides
Defined in
processTargets/targets/PositionTarget.ts:16
position
• Private
position: Position
Defined in
processTargets/targets/PositionTarget.ts:17
state
• Protected
Readonly
state: CommonTargetParameters
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:28
Accessors
contentRange
• get
contentRange(): Range
Returns
Inherited from
BaseTarget.contentRange
Defined in
processTargets/targets/BaseTarget.ts:65
contentSelection
• get
contentSelection(): Selection
Returns
Inherited from
BaseTarget.contentSelection
Defined in
processTargets/targets/BaseTarget.ts:61
contentText
• get
contentText(): string
Returns
string
Inherited from
BaseTarget.contentText
Defined in
processTargets/targets/BaseTarget.ts:57
editor
• get
editor(): TextEditor
Returns
Inherited from
BaseTarget.editor
Defined in
processTargets/targets/BaseTarget.ts:44
isReversed
• get
isReversed(): boolean
Returns
boolean
Inherited from
BaseTarget.isReversed
Defined in
processTargets/targets/BaseTarget.ts:47
thatTarget
• get
thatTarget(): Target
Returns
Inherited from
BaseTarget.thatTarget
Defined in
processTargets/targets/BaseTarget.ts:51
Methods
cloneWith
▸ Readonly
cloneWith(parameters
): any
Parameters
Name | Type |
---|---|
parameters | CloneWithParameters |
Returns
any
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:110
constructChangeEdit
▸ constructChangeEdit(text
): EditWithRangeUpdater
Constructs change/insertion edit. Adds delimiter before/after if needed
Parameters
Name | Type |
---|---|
text | string |
Returns
Overrides
BaseTarget.constructChangeEdit
Defined in
processTargets/targets/PositionTarget.ts:54
constructEditWithDelimiters
▸ Private
constructEditWithDelimiters(text
): EditWithRangeUpdater
Parameters
Name | Type |
---|---|
text | string |
Returns
Defined in
processTargets/targets/PositionTarget.ts:69
constructEditWithoutDelimiters
▸ Private
constructEditWithoutDelimiters(text
): EditWithRangeUpdater
Parameters
Name | Type |
---|---|
text | string |
Returns
Defined in
processTargets/targets/PositionTarget.ts:85
constructRemovalEdit
▸ constructRemovalEdit(): EditWithRangeUpdater
Constructs removal edit
Returns
Inherited from
BaseTarget.constructRemovalEdit
Defined in
processTargets/targets/BaseTarget.ts:77
createContinuousRangeTarget
▸ createContinuousRangeTarget(isReversed
, endTarget
, includeStart
, includeEnd
): Target
Parameters
Name | Type |
---|---|
isReversed | boolean |
endTarget | Target |
includeStart | boolean |
includeEnd | boolean |
Returns
Inherited from
BaseTarget.createContinuousRangeTarget
Defined in
processTargets/targets/BaseTarget.ts:121
getBoundaryStrict
▸ getBoundaryStrict(): Target
[]
Returns
Target
[]
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:106
getCloneParameters
▸ Protected
getCloneParameters(): PositionTargetParameters
Returns
Overrides
Defined in
processTargets/targets/PositionTarget.ts:60
getEditNewContext
▸ getEditNewContext(): EditNewContext
Returns
Overrides
Defined in
processTargets/targets/PositionTarget.ts:44
getEditRange
▸ Private
getEditRange(): Range
Returns
Defined in
processTargets/targets/PositionTarget.ts:93
getEditText
▸ Private
getEditText(text
): string
Parameters
Name | Type |
---|---|
text | string |
Returns
string
Defined in
processTargets/targets/PositionTarget.ts:107
getEqualityParameters
▸ Protected
getEqualityParameters(): object
Constructs an object that can be used for determining equality between two
BaseTarget objects. We proceed by just getting the objects clone
parameters and removing the thatTarget
.
We would prefer to instead merge the thatTarget
s into a list. See #780
for more details.
Returns
object
The object to be used for determining equality
Inherited from
BaseTarget.getEqualityParameters
Defined in
processTargets/targets/BaseTarget.ts:168
getInteriorStrict
▸ getInteriorStrict(): Target
[]
Returns
Target
[]
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:103
getLeadingDelimiterTarget
▸ getLeadingDelimiterTarget(): undefined
The range of the delimiter before the content selection
Returns
undefined
Overrides
BaseTarget.getLeadingDelimiterTarget
Defined in
processTargets/targets/PositionTarget.ts:39
getRemovalHighlightRange
▸ getRemovalHighlightRange(): undefined
| Range
Returns
undefined
| Range
Inherited from
BaseTarget.getRemovalHighlightRange
Defined in
processTargets/targets/BaseTarget.ts:91
getRemovalRange
▸ getRemovalRange(): Range
Returns
Overrides
Defined in
processTargets/targets/PositionTarget.ts:42
getTrailingDelimiterTarget
▸ getTrailingDelimiterTarget(): undefined
The range of the delimiter after the content selection
Returns
undefined
Overrides
BaseTarget.getTrailingDelimiterTarget
Defined in
processTargets/targets/PositionTarget.ts:40
isEqual
▸ isEqual(otherTarget
): boolean
Parameters
Name | Type |
---|---|
otherTarget | Target |
Returns
boolean
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:151
toPositionTarget
▸ toPositionTarget(position
): Target
Construct a position target with the given position.
Parameters
Name | Type |
---|---|
position | Position |
Returns
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:177
updateRange
▸ Private
updateRange(range
, text
): Range
Parameters
Name | Type |
---|---|
range | Range |
text | string |
Returns
Defined in
processTargets/targets/PositionTarget.ts:115
withContentRange
▸ withContentRange(contentRange
): Target
Parameters
Name | Type |
---|---|
contentRange | Range |
Returns
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:99
withThatTarget
▸ withThatTarget(thatTarget
): Target
Parameters
Name | Type |
---|---|
thatTarget | Target |
Returns
Inherited from
Defined in
processTargets/targets/BaseTarget.ts:95