Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
838517b5
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,发现更多精彩内容 >>
提交
838517b5
编写于
3月 03, 2017
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Explicit inaccurateTokensAcceptable in getLineTokens
上级
305f0fbb
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
43 addition
and
43 deletion
+43
-43
src/vs/editor/common/editorCommon.ts
src/vs/editor/common/editorCommon.ts
+1
-1
src/vs/editor/common/model/textModelWithTokens.ts
src/vs/editor/common/model/textModelWithTokens.ts
+1
-1
src/vs/editor/common/model/tokenIterator.ts
src/vs/editor/common/model/tokenIterator.ts
+3
-3
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
+1
-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/workbench/parts/debug/electron-browser/debugEditorContribution.ts
...h/parts/debug/electron-browser/debugEditorContribution.ts
+1
-1
未找到文件。
src/vs/editor/common/editorCommon.ts
浏览文件 @
838517b5
...
...
@@ -2016,7 +2016,7 @@ export interface ITokenizedModel extends ITextModel {
* @param inaccurateTokensAcceptable Are inaccurate tokens acceptable? Defaults to false
* @internal
*/
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
?
:
boolean
):
LineTokens
;
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
):
LineTokens
;
/**
* Get the language associated with this model.
...
...
src/vs/editor/common/model/textModelWithTokens.ts
浏览文件 @
838517b5
...
...
@@ -167,7 +167,7 @@ export class TextModelWithTokens extends TextModel implements editorCommon.IToke
return
result
;
}
public
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
=
false
):
LineTokens
{
public
getLineTokens
(
lineNumber
:
number
,
inaccurateTokensAcceptable
:
boolean
):
LineTokens
{
if
(
lineNumber
<
1
||
lineNumber
>
this
.
getLineCount
())
{
throw
new
Error
(
'
Illegal value
'
+
lineNumber
+
'
for `lineNumber`
'
);
}
...
...
src/vs/editor/common/model/tokenIterator.ts
浏览文件 @
838517b5
...
...
@@ -82,7 +82,7 @@ export class TokenIterator implements editorCommon.ITokenIterator {
position
=
findClosestNonEmptyLine
(
model
,
position
);
if
(
position
)
{
let
lineTokens
=
this
.
_model
.
getLineTokens
(
position
.
lineNumber
);
let
lineTokens
=
this
.
_model
.
getLineTokens
(
position
.
lineNumber
,
false
);
let
currentToken
=
lineTokens
.
findTokenAtOffset
(
position
.
column
-
1
);
if
(
currentToken
)
{
this
.
_prev
=
this
.
_next
=
new
TokenInfo
(
currentToken
,
position
.
lineNumber
);
...
...
@@ -99,7 +99,7 @@ export class TokenIterator implements editorCommon.ITokenIterator {
let
next
=
this
.
_next
.
_actual
.
next
();
while
(
!
next
&&
lineNumber
<
this
.
_lineCount
)
{
lineNumber
++
;
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
,
false
);
next
=
currentLineTokens
.
firstToken
();
}
...
...
@@ -120,7 +120,7 @@ export class TokenIterator implements editorCommon.ITokenIterator {
let
prev
=
this
.
_prev
.
_actual
.
prev
();
while
(
!
prev
&&
lineNumber
>
1
)
{
lineNumber
--
;
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
lineNumber
,
false
);
prev
=
currentLineTokens
.
lastToken
();
}
...
...
src/vs/editor/contrib/smartSelect/common/tokenTree.ts
浏览文件 @
838517b5
...
...
@@ -165,7 +165,7 @@ 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
);
let
currentLineTokens
=
this
.
_model
.
getLineTokens
(
this
.
_lineNumber
,
false
);
this
.
_next
=
currentLineTokens
.
firstToken
();
}
}
...
...
src/vs/editor/test/common/model/model.modes.test.ts
浏览文件 @
838517b5
...
...
@@ -59,98 +59,98 @@ suite('Editor Model - Model Modes 1', () => {
});
test
(
'
model calls syntax highlighter 1
'
,
()
=>
{
thisModel
.
getLineTokens
(
1
);
thisModel
.
getLineTokens
(
1
,
false
);
checkAndClear
([
'
1
'
]);
});
test
(
'
model calls syntax highlighter 2
'
,
()
=>
{
thisModel
.
getLineTokens
(
2
);
thisModel
.
getLineTokens
(
2
,
false
);
checkAndClear
([
'
1
'
,
'
2
'
]);
thisModel
.
getLineTokens
(
2
);
thisModel
.
getLineTokens
(
2
,
false
);
checkAndClear
([]);
});
test
(
'
model caches states
'
,
()
=>
{
thisModel
.
getLineTokens
(
1
);
thisModel
.
getLineTokens
(
1
,
false
);
checkAndClear
([
'
1
'
]);
thisModel
.
getLineTokens
(
2
);
thisModel
.
getLineTokens
(
2
,
false
);
checkAndClear
([
'
2
'
]);
thisModel
.
getLineTokens
(
3
);
thisModel
.
getLineTokens
(
3
,
false
);
checkAndClear
([
'
3
'
]);
thisModel
.
getLineTokens
(
4
);
thisModel
.
getLineTokens
(
4
,
false
);
checkAndClear
([
'
4
'
]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
5
'
]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([]);
});
test
(
'
model invalidates states for one line insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
1
),
'
-
'
)]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
-
'
]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([]);
});
test
(
'
model invalidates states for many lines insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
7
,
false
);
checkAndClear
([
'
0
'
,
'
-
'
,
'
+
'
]);
thisModel
.
getLineTokens
(
7
);
thisModel
.
getLineTokens
(
7
,
false
);
checkAndClear
([]);
});
test
(
'
model invalidates states for one new line
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
6
,
false
);
checkAndClear
([
'
1
'
,
'
a
'
]);
});
test
(
'
model invalidates states for one line delete
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
insert
(
new
Position
(
1
,
2
),
'
-
'
)]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
1
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
1
,
2
))]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
-
'
]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([]);
});
test
(
'
model invalidates states for many lines delete
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
checkAndClear
([
'
1
'
,
'
2
'
,
'
3
'
,
'
4
'
,
'
5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
3
,
1
))]);
thisModel
.
getLineTokens
(
3
);
thisModel
.
getLineTokens
(
3
,
false
);
checkAndClear
([
'
3
'
]);
thisModel
.
getLineTokens
(
3
);
thisModel
.
getLineTokens
(
3
,
false
);
checkAndClear
([]);
});
});
...
...
@@ -227,17 +227,17 @@ suite('Editor Model - Model Modes 2', () => {
});
test
(
'
getTokensForInvalidLines one text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
5
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
Line1-
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines two text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
5
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
Line1-
'
,
'
Line2
'
,
'
Line3-
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one multi-line text insert, one small text insert
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
7
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
New line
'
,
'
Another new line
'
,
'
Line2
'
,
'
Line3-
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
Line1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
thisModel
.
applyEdits
([
EditOperation
.
delete
(
new
Range
(
1
,
1
,
1
,
5
))]);
invalidEqual
(
thisModel
,
[
0
]);
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
1
'
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines one line delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
4
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
Line2
'
,
'
Line3
'
,
'
Line4
'
,
'
Line5
'
]);
});
test
(
'
getTokensForInvalidLines multiple lines delete text
'
,
()
=>
{
thisModel
.
getLineTokens
(
5
);
thisModel
.
getLineTokens
(
5
,
false
);
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
);
thisModel
.
getLineTokens
(
3
,
false
);
statesEqual
(
thisModel
,
[
''
,
'
ne3
'
,
'
Line4
'
,
'
Line5
'
]);
});
});
...
...
src/vs/workbench/parts/debug/electron-browser/debugEditorContribution.ts
浏览文件 @
838517b5
...
...
@@ -514,7 +514,7 @@ export class DebugEditorContribution implements IDebugEditorContribution {
continue
;
}
const
lineTokens
=
model
.
getLineTokens
(
lineNumber
);
const
lineTokens
=
model
.
getLineTokens
(
lineNumber
,
false
);
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.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录