Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
cee1934a
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cee1934a
编写于
3月 03, 2017
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add & adopt forceTokenization
上级
838517b5
变更
14
隐藏空白更改
内联
并排
Showing
14 changed file
with
87 addition
and
65 deletion
+87
-65
src/vs/editor/browser/standalone/colorizer.ts
src/vs/editor/browser/standalone/colorizer.ts
+2
-1
src/vs/editor/browser/widget/codeEditorWidget.ts
src/vs/editor/browser/widget/codeEditorWidget.ts
+2
-1
src/vs/editor/common/controller/cursorTypeOperations.ts
src/vs/editor/common/controller/cursorTypeOperations.ts
+4
-2
src/vs/editor/common/editorCommon.ts
src/vs/editor/common/editorCommon.ts
+9
-4
src/vs/editor/common/model/textModelWithTokens.ts
src/vs/editor/common/model/textModelWithTokens.ts
+12
-8
src/vs/editor/common/model/tokenIterator.ts
src/vs/editor/common/model/tokenIterator.ts
+6
-3
src/vs/editor/common/modes/languageConfigurationRegistry.ts
src/vs/editor/common/modes/languageConfigurationRegistry.ts
+2
-1
src/vs/editor/common/viewModel/splitLinesCollection.ts
src/vs/editor/common/viewModel/splitLinesCollection.ts
+3
-3
src/vs/editor/common/viewModel/viewModelImpl.ts
src/vs/editor/common/viewModel/viewModelImpl.ts
+1
-1
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
+2
-1
src/vs/editor/test/common/model/model.modes.test.ts
src/vs/editor/test/common/model/model.modes.test.ts
+36
-36
src/vs/editor/test/common/model/textModelWithTokens.test.ts
src/vs/editor/test/common/model/textModelWithTokens.test.ts
+4
-1
src/vs/editor/test/common/viewModel/splitLinesCollection.test.ts
...editor/test/common/viewModel/splitLinesCollection.test.ts
+2
-2
src/vs/workbench/parts/debug/electron-browser/debugEditorContribution.ts
...h/parts/debug/electron-browser/debugEditorContribution.ts
+2
-1
未找到文件。
src/vs/editor/browser/standalone/colorizer.ts
浏览文件 @
cee1934a
...
...
@@ -113,7 +113,8 @@ export class Colorizer {
public
static
colorizeModelLine
(
model
:
IModel
,
lineNumber
:
number
,
tabSize
:
number
=
4
):
string
{
let
content
=
model
.
getLineContent
(
lineNumber
);
let
tokens
=
model
.
getLineTokens
(
lineNumber
,
false
);
model
.
forceTokenization
(
lineNumber
);
let
tokens
=
model
.
getLineTokens
(
lineNumber
);
let
inflatedTokens
=
tokens
.
inflate
();
return
this
.
colorizeLine
(
content
,
model
.
mightContainRTL
(),
inflatedTokens
,
tabSize
);
}
...
...
src/vs/editor/browser/widget/codeEditorWidget.ts
浏览文件 @
cee1934a
...
...
@@ -145,7 +145,8 @@ export abstract class CodeEditorWidget extends CommonCodeEditor implements edito
return
''
;
}
let
content
=
model
.
getLineContent
(
lineNumber
);
let
tokens
=
model
.
getLineTokens
(
lineNumber
,
false
);
model
.
forceTokenization
(
lineNumber
);
let
tokens
=
model
.
getLineTokens
(
lineNumber
);
let
inflatedTokens
=
tokens
.
inflate
();
let
tabSize
=
model
.
getOptions
().
tabSize
;
return
Colorizer
.
colorizeLine
(
content
,
model
.
mightContainRTL
(),
inflatedTokens
,
tabSize
);
...
...
src/vs/editor/common/controller/cursorTypeOperations.ts
浏览文件 @
cee1934a
...
...
@@ -344,7 +344,8 @@ export class TypeOperations {
}
}
let
lineTokens
=
model
.
getLineTokens
(
position
.
lineNumber
,
false
);
model
.
forceTokenization
(
position
.
lineNumber
);
let
lineTokens
=
model
.
getLineTokens
(
position
.
lineNumber
);
let
shouldAutoClosePair
=
false
;
try
{
...
...
@@ -413,7 +414,8 @@ export class TypeOperations {
}
let
position
=
cursor
.
position
;
let
lineTokens
=
model
.
getLineTokens
(
position
.
lineNumber
,
false
);
model
.
forceTokenization
(
position
.
lineNumber
);
let
lineTokens
=
model
.
getLineTokens
(
position
.
lineNumber
);
let
electricAction
:
IElectricAction
;
try
{
...
...
src/vs/editor/common/editorCommon.ts
浏览文件 @
cee1934a
...
...
@@ -2011,12 +2011,17 @@ export interface IFoundBracket {
export
interface
ITokenizedModel
extends
ITextModel
{
/**
* Tokenize if necessary and get the tokens for the line `lineNumber`.
* @param lineNumber The line number
* @param inaccurateTokensAcceptable Are inaccurate tokens acceptable? Defaults to false
* Force tokenization information for `lineNumber` to be accurate.
* @internal
*/
forceTokenization
(
lineNumber
:
number
):
void
;
/**
* Get the tokens for the line `lineNumber`.
* The tokens might be inaccurate. Use `forceTokenization` to ensure accurate tokens.
* @internal
*/
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
):
LineTokens
;
getLineTokens
(
lineNumber
:
number
):
LineTokens
;
/**
* Get the language associated with this model.
...
...
src/vs/editor/common/model/textModelWithTokens.ts
浏览文件 @
cee1934a
...
...
@@ -167,15 +167,19 @@ export class TextModelWithTokens extends TextModel implements editorCommon.IToke
return
result
;
}
public
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
):
LineTokens
{
public
forceTokenization
(
lineNumber
:
number
):
void
{
if
(
lineNumber
<
1
||
lineNumber
>
this
.
getLineCount
())
{
throw
new
Error
(
'
Illegal value
'
+
lineNumber
+
'
for `lineNumber`
'
);
}
if
(
!
inaccurateTokensAcceptable
)
{
this
.
_withModelTokensChangedEventBuilder
((
eventBuilder
)
=>
{
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
,
true
);
});
this
.
_withModelTokensChangedEventBuilder
((
eventBuilder
)
=>
{
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
);
});
}
public
getLineTokens
(
lineNumber
:
number
):
LineTokens
{
if
(
lineNumber
<
1
||
lineNumber
>
this
.
getLineCount
())
{
throw
new
Error
(
'
Illegal value
'
+
lineNumber
+
'
for `lineNumber`
'
);
}
return
this
.
_getLineTokens
(
lineNumber
);
...
...
@@ -225,7 +229,7 @@ export class TextModelWithTokens extends TextModel implements editorCommon.IToke
let
{
lineNumber
,
column
}
=
this
.
validatePosition
({
lineNumber
:
_lineNumber
,
column
:
_column
});
this
.
_withModelTokensChangedEventBuilder
((
eventBuilder
)
=>
{
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
,
true
);
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
);
});
let
lineTokens
=
this
.
_getLineTokens
(
lineNumber
);
...
...
@@ -311,7 +315,7 @@ export class TextModelWithTokens extends TextModel implements editorCommon.IToke
}
}
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
,
false
);
this
.
_updateTokensUntilLine
(
eventBuilder
,
lineNumber
);
tokenizedChars
+=
currentCharsToTokenize
;
// Skip the lines that got tokenized
...
...
@@ -326,7 +330,7 @@ export class TextModelWithTokens extends TextModel implements editorCommon.IToke
});
}
private
_updateTokensUntilLine
(
eventBuilder
:
ModelTokensChangedEventBuilder
,
lineNumber
:
number
,
emitEvents
:
boolean
):
void
{
private
_updateTokensUntilLine
(
eventBuilder
:
ModelTokensChangedEventBuilder
,
lineNumber
:
number
):
void
{
if
(
!
this
.
_tokenizationSupport
)
{
this
.
_invalidLineStartIndex
=
this
.
_lines
.
length
;
return
;
...
...
src/vs/editor/common/model/tokenIterator.ts
浏览文件 @
cee1934a
...
...
@@ -82,7 +82,8 @@ export class TokenIterator implements editorCommon.ITokenIterator {
position
=
findClosestNonEmptyLine
(
model
,
position
);
if
(
position
)
{
let
lineTokens
=
this
.
_model
.
getLineTokens
(
position
.
lineNumber
,
false
);
this
.
_model
.
forceTokenization
(
position
.
lineNumber
);
let
lineTokens
=
this
.
_model
.
getLineTokens
(
position
.
lineNumber
);
let
currentToken
=
lineTokens
.
findTokenAtOffset
(
position
.
column
-
1
);
if
(
currentToken
)
{
this
.
_prev
=
this
.
_next
=
new
TokenInfo
(
currentToken
,
position
.
lineNumber
);
...
...
@@ -99,7 +100,8 @@ export class TokenIterator implements editorCommon.ITokenIterator {
let
next
=
this
.
_next
.
_actual
.
next
();
while
(
!
next
&&
lineNumber
<
this
.
_lineCount
)
{
lineNumber
++
;
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
,
false
);
this
.
_model
.
forceTokenization
(
lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
);
next
=
currentLineTokens
.
firstToken
();
}
...
...
@@ -120,7 +122,8 @@ export class TokenIterator implements editorCommon.ITokenIterator {
let
prev
=
this
.
_prev
.
_actual
.
prev
();
while
(
!
prev
&&
lineNumber
>
1
)
{
lineNumber
--
;
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
,
false
);
this
.
_model
.
forceTokenization
(
lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
);
prev
=
currentLineTokens
.
lastToken
();
}
...
...
src/vs/editor/common/modes/languageConfigurationRegistry.ts
浏览文件 @
cee1934a
...
...
@@ -399,7 +399,8 @@ export class LanguageConfigurationRegistryImpl {
}
private
getScopedLineTokens
(
model
:
ITokenizedModel
,
lineNumber
:
number
)
{
let
lineTokens
=
model
.
getLineTokens
(
lineNumber
,
false
);
model
.
forceTokenization
(
lineNumber
);
let
lineTokens
=
model
.
getLineTokens
(
lineNumber
);
let
column
=
model
.
getLineMaxColumn
(
lineNumber
);
let
scopedLineTokens
=
createScopedLineTokens
(
lineTokens
,
column
-
1
);
return
scopedLineTokens
;
...
...
src/vs/editor/common/viewModel/splitLinesCollection.ts
浏览文件 @
cee1934a
...
...
@@ -35,7 +35,7 @@ export interface ILineMapperFactory {
}
export
interface
IModel
{
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
):
LineTokens
;
getLineTokens
(
lineNumber
:
number
):
LineTokens
;
getLineContent
(
lineNumber
:
number
):
string
;
getLineMinColumn
(
lineNumber
:
number
):
number
;
getLineMaxColumn
(
lineNumber
:
number
):
number
;
...
...
@@ -90,7 +90,7 @@ class VisibleIdentitySplitLine implements ISplitLine {
}
public
getViewLineData
(
model
:
IModel
,
modelLineNumber
:
number
,
outputLineIndex
:
number
):
ViewLineData
{
let
lineTokens
=
model
.
getLineTokens
(
modelLineNumber
,
true
);
let
lineTokens
=
model
.
getLineTokens
(
modelLineNumber
);
let
lineContent
=
lineTokens
.
getLineContent
();
return
new
ViewLineData
(
lineContent
,
...
...
@@ -263,7 +263,7 @@ export class SplitLine implements ISplitLine {
if
(
outputLineIndex
>
0
)
{
deltaStartIndex
=
this
.
wrappedIndentLength
;
}
let
lineTokens
=
model
.
getLineTokens
(
modelLineNumber
,
true
);
let
lineTokens
=
model
.
getLineTokens
(
modelLineNumber
);
return
new
ViewLineData
(
lineContent
,
...
...
src/vs/editor/common/viewModel/viewModelImpl.ts
浏览文件 @
cee1934a
...
...
@@ -667,7 +667,7 @@ export class ViewModel implements IViewModel {
let
result
=
''
;
for
(
let
lineNumber
=
startLineNumber
;
lineNumber
<=
endLineNumber
;
lineNumber
++
)
{
const
lineTokens
=
this
.
model
.
getLineTokens
(
lineNumber
,
true
);
const
lineTokens
=
this
.
model
.
getLineTokens
(
lineNumber
);
const
lineContent
=
lineTokens
.
getLineContent
();
const
startOffset
=
(
lineNumber
===
startLineNumber
?
startColumn
-
1
:
0
);
const
endOffset
=
(
lineNumber
===
endLineNumber
?
endColumn
-
1
:
lineContent
.
length
);
...
...
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
浏览文件 @
cee1934a
...
...
@@ -165,7 +165,8 @@ class ModelRawTokenScanner {
while
(
!
this
.
_next
&&
this
.
_lineNumber
<
this
.
_lineCount
)
{
this
.
_lineNumber
++
;
this
.
_lineText
=
this
.
_model
.
getLineContent
(
this
.
_lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
this
.
_lineNumber
,
false
);
this
.
_model
.
forceTokenization
(
this
.
_lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
this
.
_lineNumber
);
this
.
_next
=
currentLineTokens
.
firstToken
();
}
}
...
...
src/vs/editor/test/common/model/model.modes.test.ts
浏览文件 @
cee1934a
...
...
@@ -59,98 +59,98 @@ suite('Editor Model - Model Modes 1', () => {
});
test
(
'
model calls syntax highlighter 1
'
,
()
=>
{
thisModel
.
getLineTokens
(
1
,
false
);
thisModel
.
forceTokenization
(
1
);
checkAndClear
([
'
1
'
]);
});
test
(
'
model calls syntax highlighter 2
'
,
()
=>
{
thisModel
.
getLineTokens
(
2
,
false
);
thisModel
.
forceTokenization
(
2
);
checkAndClear
([
'
1
'
,
'
2
'
]);
thisModel
.
getLineTokens
(
2
,
false
);
thisModel
.
forceTokenization
(
2
);
checkAndClear
([]);
});
test
(
'
model caches states
'
,
()
=>
{
thisModel
.
getLineTokens
(
1
,
false
);
thisModel
.
forceTokenization
(
1
);
checkAndClear
([
'
1
'
]);
thisModel
.
getLineTokens
(
2
,
false
);
thisModel
.
forceTokenization
(
2
);
checkAndClear
([
'
2
'
]);
thisModel
.
getLineTokens
(
3
,
false
);
thisModel
.
forceTokenization
(
3
);
checkAndClear
([
'
3
'
]);
thisModel
.
getLineTokens
(
4
,
false
);
thisModel
.
forceTokenization
(
4
);
checkAndClear
([
'
4
'
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
5
'
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([]);
});
test
(
'
model invalidates states for one line insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
1
),
'
-
'
)]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
-
'
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([]);
});
test
(
'
model invalidates states for many lines insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
1
),
'
0
\n
-
\n
+
'
)]);
assert
.
equal
(
thisModel
.
getLineCount
(),
7
);
thisModel
.
getLineTokens
(
7
,
false
);
thisModel
.
forceTokenization
(
7
);
checkAndClear
([
'
0
'
,
'
-
'
,
'
+
'
]);
thisModel
.
getLineTokens
(
7
,
false
);
thisModel
.
forceTokenization
(
7
);
checkAndClear
([]);
});
test
(
'
model invalidates states for one new line
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
2
),
'
\n
'
)]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
2
,
1
),
'
a
'
)]);
thisModel
.
getLineTokens
(
6
,
false
);
thisModel
.
forceTokenization
(
6
);
checkAndClear
([
'
1
'
,
'
a
'
]);
});
test
(
'
model invalidates states for one line delete
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
2
),
'
-
'
)]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
1
,
2
))]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
-
'
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([]);
});
test
(
'
model invalidates states for many lines delete
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
3
,
1
))]);
thisModel
.
getLineTokens
(
3
,
false
);
thisModel
.
forceTokenization
(
3
);
checkAndClear
([
'
3
'
]);
thisModel
.
getLineTokens
(
3
,
false
);
thisModel
.
forceTokenization
(
3
);
checkAndClear
([]);
});
});
...
...
@@ -227,17 +227,17 @@ suite('Editor Model - Model Modes 2', () => {
});
test
(
'
getTokensForInvalidLines one text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
6
),
'
-
'
)]);
invalidEqual
(
thisModel
,
[
0
]);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1-
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines two text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
6
),
'
-
'
),
...
...
@@ -245,46 +245,46 @@ suite('Editor Model - Model Modes 2', () => {
]);
invalidEqual
(
thisModel
,
[
0
,
2
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1-
'
,
'
Line2
'
,
'
Line3-
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one multi-line text insert, one small text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
6
),
'
\n
New line
\n
Another new line
'
)]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
5
,
6
),
'
-
'
)]);
invalidEqual
(
thisModel
,
[
0
,
4
]);
thisModel
.
getLineTokens
(
7
,
false
);
thisModel
.
forceTokenization
(
7
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
New line
'
,
'
Another new line
'
,
'
Line2
'
,
'
Line3-
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
1
,
5
))]);
invalidEqual
(
thisModel
,
[
0
]);
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one line delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
2
,
1
))]);
invalidEqual
(
thisModel
,
[
0
]);
statesEqual
(
thisModel
,
[
''
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
getLineTokens
(
4
,
false
);
thisModel
.
forceTokenization
(
4
);
statesEqual
(
thisModel
,
[
''
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines multiple lines delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
,
false
);
thisModel
.
forceTokenization
(
5
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
3
,
3
))]);
invalidEqual
(
thisModel
,
[
0
]);
statesEqual
(
thisModel
,
[
''
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
getLineTokens
(
3
,
false
);
thisModel
.
forceTokenization
(
3
);
statesEqual
(
thisModel
,
[
''
,
'
ne3
'
,
'
Line4
'
,
'
Line5
'
]);
});
});
...
...
src/vs/editor/test/common/model/textModelWithTokens.test.ts
浏览文件 @
cee1934a
...
...
@@ -266,7 +266,10 @@ suite('TextModelWithTokens regression tests', () => {
test
(
'
Microsoft/monaco-editor#122: Unhandled Exception: TypeError: Unable to get property
\'
replace
\'
of undefined or null reference
'
,
()
=>
{
function
assertViewLineTokens
(
model
:
Model
,
lineNumber
:
number
,
forceTokenization
:
boolean
,
expected
:
ViewLineToken
[]):
void
{
let
actual
=
model
.
getLineTokens
(
lineNumber
,
!
forceTokenization
).
inflate
();
if
(
forceTokenization
)
{
model
.
forceTokenization
(
lineNumber
);
}
let
actual
=
model
.
getLineTokens
(
lineNumber
).
inflate
();
let
decode
=
(
token
:
ViewLineToken
)
=>
{
return
{
endIndex
:
token
.
endIndex
,
...
...
src/vs/editor/test/common/viewModel/splitLinesCollection.test.ts
浏览文件 @
cee1934a
...
...
@@ -352,7 +352,7 @@ suite('SplitLinesCollection', () => {
languageRegistration
=
modes
.
TokenizationRegistry
.
register
(
LANGUAGE_ID
,
tokenizationSupport
);
model
=
Model
.
createFromString
(
_text
.
join
(
'
\n
'
),
undefined
,
new
modes
.
LanguageIdentifier
(
LANGUAGE_ID
,
0
));
// force tokenization
model
.
getLineTokens
(
model
.
getLineCount
(),
false
);
model
.
forceTokenization
(
model
.
getLineCount
()
);
});
teardown
(()
=>
{
...
...
@@ -777,7 +777,7 @@ function createLineMapping(breakingLengths: number[], wrappedLinesPrefix: string
function
createModel
(
text
:
string
):
IModel
{
return
{
getLineTokens
:
(
lineNumber
:
number
,
inaccurateTokensAcceptable
?:
boolean
)
=>
{
getLineTokens
:
(
lineNumber
:
number
)
=>
{
return
null
;
},
getLineContent
:
(
lineNumber
:
number
)
=>
{
...
...
src/vs/workbench/parts/debug/electron-browser/debugEditorContribution.ts
浏览文件 @
cee1934a
...
...
@@ -514,7 +514,8 @@ export class DebugEditorContribution implements IDebugEditorContribution {
continue
;
}
const
lineTokens
=
model
.
getLineTokens
(
lineNumber
,
false
);
model
.
forceTokenization
(
lineNumber
);
const
lineTokens
=
model
.
getLineTokens
(
lineNumber
);
for
(
let
token
=
lineTokens
.
firstToken
();
!!
token
;
token
=
token
.
next
())
{
const
tokenStr
=
lineContent
.
substring
(
token
.
startOffset
,
token
.
endOffset
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录