Skip to main content

Class: UntypedTarget

processTargets/targets/UntypedTarget.UntypedTarget

  • Treated as "line" for "pour", "clone", and "breakpoint"
  • Use token delimiters (space) for removal and insertion
  • Expand to nearest containing pair when asked for boundary or interior

Hierarchy

Constructors

constructor

new UntypedTarget(parameters)

Parameters

NameType
parametersUntypedTargetParameters

Overrides

BaseTarget.constructor

Defined in

processTargets/targets/UntypedTarget.ts:24

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

BaseTarget.hasExplicitRange

Defined in

processTargets/targets/BaseTarget.ts:31


hasExplicitScopeType

hasExplicitScopeType: boolean = false

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.

Overrides

BaseTarget.hasExplicitScopeType

Defined in

processTargets/targets/UntypedTarget.ts:22


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

BaseTarget.insertionDelimiter

Defined in

processTargets/targets/UntypedTarget.ts:21


isLine

isLine: boolean = false

If true this target should be treated as a line

Inherited from

BaseTarget.isLine

Defined in

processTargets/targets/BaseTarget.ts:29


isNotebookCell

isNotebookCell: boolean = false

If true this target is a notebook cell

Inherited from

BaseTarget.isNotebookCell

Defined in

processTargets/targets/BaseTarget.ts:33


isRaw

isRaw: boolean = false

If true this target is a raw selection and its insertion delimiter should not be used on bring action

Inherited from

BaseTarget.isRaw

Defined in

processTargets/targets/BaseTarget.ts:32


state

Protected Readonly state: CommonTargetParameters

Inherited from

BaseTarget.state

Defined in

processTargets/targets/BaseTarget.ts:28

Accessors

contentRange

get contentRange(): Range

Returns

Range

Inherited from

BaseTarget.contentRange

Defined in

processTargets/targets/BaseTarget.ts:65


contentSelection

get contentSelection(): Selection

Returns

Selection

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

TextEditor

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

Target

Inherited from

BaseTarget.thatTarget

Defined in

processTargets/targets/BaseTarget.ts:51

Methods

cloneWith

Readonly cloneWith(parameters): any

Parameters

NameType
parametersCloneWithParameters

Returns

any

Inherited from

BaseTarget.cloneWith

Defined in

processTargets/targets/BaseTarget.ts:110


constructChangeEdit

constructChangeEdit(text): EditWithRangeUpdater

Constructs change/insertion edit. Adds delimiter before/after if needed

Parameters

NameType
textstring

Returns

EditWithRangeUpdater

Inherited from

BaseTarget.constructChangeEdit

Defined in

processTargets/targets/BaseTarget.ts:69


constructRemovalEdit

constructRemovalEdit(): EditWithRangeUpdater

Constructs removal edit

Returns

EditWithRangeUpdater

Inherited from

BaseTarget.constructRemovalEdit

Defined in

processTargets/targets/BaseTarget.ts:77


createContinuousRangeTarget

createContinuousRangeTarget(isReversed, endTarget, includeStart, includeEnd): Target

Parameters

NameType
isReversedboolean
endTargetTarget
includeStartboolean
includeEndboolean

Returns

Target

Overrides

BaseTarget.createContinuousRangeTarget

Defined in

processTargets/targets/UntypedTarget.ts:42


getBoundaryStrict

getBoundaryStrict(): Target[]

Returns

Target[]

Inherited from

BaseTarget.getBoundaryStrict

Defined in

processTargets/targets/BaseTarget.ts:106


getCloneParameters

Protected getCloneParameters(): Object

Returns

Object

NameType
contentRangeRange
editorTextEditor
hasExplicitRangeboolean
isReversedboolean
thatTarget?Target

Overrides

BaseTarget.getCloneParameters

Defined in

processTargets/targets/UntypedTarget.ts:57


getEditNewContext

getEditNewContext(): EditNewContext

Returns

EditNewContext

Inherited from

BaseTarget.getEditNewContext

Defined in

processTargets/targets/BaseTarget.ts:85


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 thatTargets 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

BaseTarget.getInteriorStrict

Defined in

processTargets/targets/BaseTarget.ts:103


getLeadingDelimiterTarget

getLeadingDelimiterTarget(): undefined | Target

The range of the delimiter before the content selection

Returns

undefined | Target

Overrides

BaseTarget.getLeadingDelimiterTarget

Defined in

processTargets/targets/UntypedTarget.ts:29


getRemovalHighlightRange

getRemovalHighlightRange(): undefined | Range

Returns

undefined | Range

Inherited from

BaseTarget.getRemovalHighlightRange

Defined in

processTargets/targets/BaseTarget.ts:91


getRemovalRange

getRemovalRange(): Range

Returns

Range

Overrides

BaseTarget.getRemovalRange

Defined in

processTargets/targets/UntypedTarget.ts:35


getTrailingDelimiterTarget

getTrailingDelimiterTarget(): undefined | Target

The range of the delimiter after the content selection

Returns

undefined | Target

Overrides

BaseTarget.getTrailingDelimiterTarget

Defined in

processTargets/targets/UntypedTarget.ts:32


isEqual

isEqual(otherTarget): boolean

Parameters

NameType
otherTargetTarget

Returns

boolean

Inherited from

BaseTarget.isEqual

Defined in

processTargets/targets/BaseTarget.ts:151


toPositionTarget

toPositionTarget(position): Target

Construct a position target with the given position.

Parameters

NameType
positionPosition

Returns

Target

Inherited from

BaseTarget.toPositionTarget

Defined in

processTargets/targets/BaseTarget.ts:177


withContentRange

withContentRange(contentRange): Target

Parameters

NameType
contentRangeRange

Returns

Target

Inherited from

BaseTarget.withContentRange

Defined in

processTargets/targets/BaseTarget.ts:99


withThatTarget

withThatTarget(thatTarget): Target

Parameters

NameType
thatTargetTarget

Returns

Target

Inherited from

BaseTarget.withThatTarget

Defined in

processTargets/targets/BaseTarget.ts:95