Class: WordScopeHandler
processTargets/modifiers/scopeHandlers/WordScopeHandler.WordScopeHandler
Hierarchy
↳
WordScopeHandler
Constructors
constructor
• new WordScopeHandler(scopeType
, languageId
)
Parameters
Name | Type |
---|---|
scopeType | ScopeType |
languageId | string |
Inherited from
NestedScopeHandler.constructor
Defined in
processTargets/modifiers/scopeHandlers/NestedScopeHandler.ts:56
Properties
isHierarchical
• Protected
Readonly
isHierarchical: false
Indicates whether scopes are allowed to contain one another. If false
, we
can optimise the algorithm by making certain assumptions.
Inherited from
NestedScopeHandler.isHierarchical
Defined in
processTargets/modifiers/scopeHandlers/NestedScopeHandler.ts:29
iterationScopeType
• Readonly
iterationScopeType: Object
The scope type of the default iteration scope of this scope type. This
scope type will be used when the input target has no explicit range (ie
Target.hasExplicitRange is false
).
Type declaration
Name | Type |
---|---|
type | "identifier" |
Overrides
NestedScopeHandler.iterationScopeType
Defined in
processTargets/modifiers/scopeHandlers/WordScopeHandler.ts:10
languageId
• Protected
languageId: string
Inherited from
scopeType
• Readonly
scopeType: Object
The scope type handled by this scope handler
Type declaration
Name | Type |
---|---|
type | "word" |
Overrides
Defined in
processTargets/modifiers/scopeHandlers/WordScopeHandler.ts:9
wordTokenizer
• Private
wordTokenizer: WordTokenizer
Defined in
processTargets/modifiers/scopeHandlers/WordScopeHandler.ts:12
Accessors
searchScopeHandler
• Private
get
searchScopeHandler(): ScopeHandler
Returns
Inherited from
NestedScopeHandler.searchScopeHandler
Defined in
processTargets/modifiers/scopeHandlers/NestedScopeHandler.ts:63
searchScopeType
• Protected
get
searchScopeType(): ScopeType
We expand to this scope type before looking for instances of the scope type
handled by this scope handler. In most cases the iteration scope will
suffice, but in some cases you want them to diverge. For example, you
might want the default iteration scope to be "file"
, but you don't need
to expand to the file just to find instances of the given scope type.
Returns
Inherited from
NestedScopeHandler.searchScopeType
Defined in
processTargets/modifiers/scopeHandlers/NestedScopeHandler.ts:38
Methods
generateScopeCandidates
▸ Protected
generateScopeCandidates(editor
, position
, direction
, hints
): Iterable
<TargetScope
>
Returns an iterable that yields scopes.
If your scope type is not hierarchical, and {@link direction} is
"forward"
, yield all scopes whose domain's
end is equal to or after position in document
order.
If your scope type is not hierarchical, and {@link direction} is
"backward"
, yield all scopes whose domain's
start is equal to or before position, in
reverse document order.
If your scope type is hierarchical, and {@link direction} is "forward"
,
walk forward starting at position (including position). Any time a
scope's domain ends or starts, yield that scope.
If multiple domains start or end at a particular point, break ties as
follows:
- First yield any scopes with empty domain.
- Then yield any scopes whose domains are ending, in reverse order of where they start.
- Then yield the scope with minimal domain that is starting. Any time you yield a scope, advance your position to the end of the scope, but when considering this new position, don't return this scope again.
If your scope type is hierarchical, and {@link direction} is
"backward"
, walk backward starting at position (including
position). Any time a scope's domain ends or
starts, yield that scope. If multiple domains start or end at a particular
point, break ties as follows:
- First yield any scopes with empty domain.
- Then yield any scopes whose domains are starting, in order of where they end.
- Then yield the scope with minimal domain that is ending. Any time you yield a scope, advance your position to the start of the scope, but when considering this new position, don't return this scope again.
Note that the {@link hints} argument can be ignored, but you are welcome to use it to improve performance. For example, knowing the ScopeIteratorRequirements.distalPosition can be useful if you need to query a list of scopes in bulk.
Some notes:
- Once you have yielded a scope, you do not need to yield any scopes contained by that scope.
- You can yield the same scope more than once if it makes your life easier
The only strict requirements are that
- you yield every scope that might meet the requirements
- you yield scopes in the correct order
Parameters
Name | Type |
---|---|
editor | TextEditor |
position | Position |
direction | Direction |
hints | ScopeIteratorRequirements |
Returns
Iterable
<TargetScope
>
Inherited from
NestedScopeHandler.generateScopeCandidates
Defined in
processTargets/modifiers/scopeHandlers/NestedScopeHandler.ts:74
generateScopes
▸ generateScopes(editor
, position
, direction
, requirements?
): Iterable
<TargetScope
>
Returns an iterable of scopes meeting the requirements in {@link requirements}, yielded in a specific order. See generateScopeCandidates and compareTargetScopes for more on the order.
Parameters
Name | Type |
---|---|
editor | TextEditor |
position | Position |
direction | Direction |
requirements | Partial <ScopeIteratorRequirements > |
Returns
Iterable
<TargetScope
>
Inherited from
NestedScopeHandler.generateScopes
Defined in
processTargets/modifiers/scopeHandlers/BaseScopeHandler.ts:99
generateScopesInSearchScope
▸ Protected
generateScopesInSearchScope(direction
, searchScope
): Iterable
<TargetScope
>
This function is the only function that needs to be defined in the derived type. It should yield all child scope types in the given parent scope type, in the order specified in {@link direction}.
Parameters
Name | Type |
---|---|
direction | Direction |
searchScope | TargetScope |
Returns
Iterable
<TargetScope
>
Overrides
NestedScopeHandler.generateScopesInSearchScope
Defined in
processTargets/modifiers/scopeHandlers/WordScopeHandler.ts:52
getScopesInSearchScope
▸ Private
getScopesInSearchScope(__namedParameters
): TargetScope
[]
Parameters
Name | Type |
---|---|
__namedParameters | TargetScope |
Returns
Defined in
processTargets/modifiers/scopeHandlers/WordScopeHandler.ts:14