Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
efd7f099
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
efd7f099
编写于
1月 10, 2020
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix issues around surrogate pairs
上级
5b5f01d7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
175 addition
and
98 deletion
+175
-98
src/vs/editor/common/viewModel/characterHardWrappingLineMapper.ts
...ditor/common/viewModel/characterHardWrappingLineMapper.ts
+136
-97
src/vs/editor/test/common/viewModel/characterHardWrappingLineMapper.test.ts
.../common/viewModel/characterHardWrappingLineMapper.test.ts
+39
-1
未找到文件。
src/vs/editor/common/viewModel/characterHardWrappingLineMapper.ts
浏览文件 @
efd7f099
...
...
@@ -104,6 +104,9 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
return
null
;
}
const
prevBreakingOffsets
=
previousBreakingData
.
breakOffsets
;
const
prevBreakingOffsetsVisibleColumn
=
previousBreakingData
.
breakingOffsetsVisibleColumn
;
const
wrappedTextIndentLength
=
computeWrappedTextIndentLength
(
lineText
,
tabSize
,
firstLineBreakingColumn
,
columnsForFullWidthChar
,
hardWrappingIndent
);
const
wrappedLineBreakingColumn
=
firstLineBreakingColumn
-
wrappedTextIndentLength
;
...
...
@@ -111,21 +114,18 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
let
breakingOffsetsVisibleColumn
:
number
[]
=
[];
let
breakingOffsetsCount
:
number
=
0
;
const
prevBreakingOffsets
=
previousBreakingData
.
breakOffsets
;
const
prevBreakingOffsetsVisibleColumn
=
previousBreakingData
.
breakingOffsetsVisibleColumn
;
let
breakingColumn
=
firstLineBreakingColumn
;
const
prevLen
=
prevBreakingOffsets
.
length
;
let
prevIndex
=
0
;
if
(
prevIndex
>=
0
)
{
let
currentDiff
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
]
-
breakingColumn
);
let
bestDistance
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
]
-
breakingColumn
);
while
(
prevIndex
+
1
<
prevLen
)
{
const
potentialDiff
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
+
1
]
-
breakingColumn
);
if
(
potentialDiff
>=
currentDiff
)
{
const
distance
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
+
1
]
-
breakingColumn
);
if
(
distance
>=
bestDistance
)
{
break
;
}
currentDiff
=
potentialDiff
;
bestDistance
=
distance
;
prevIndex
++
;
}
}
...
...
@@ -133,7 +133,7 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
while
(
prevIndex
<
prevLen
)
{
// Allow for prevIndex to be -1 (for the case where we hit a tab when walking backwards from the first break)
const
prevBreakOffset
=
prevIndex
<
0
?
0
:
prevBreakingOffsets
[
prevIndex
];
const
prevBreakoffsetVisibleColumn
=
prevIndex
<
0
?
0
:
prevBreakingOffsetsVisibleColumn
[
prevIndex
];
;
const
prevBreakoffsetVisibleColumn
=
prevIndex
<
0
?
0
:
prevBreakingOffsetsVisibleColumn
[
prevIndex
];
let
breakOffset
=
0
;
let
breakOffsetVisibleColumn
=
0
;
...
...
@@ -148,29 +148,32 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
let
prevCharCodeClass
=
classifier
.
get
(
prevCharCode
);
let
entireLineFits
=
true
;
for
(
let
i
=
prevBreakOffset
;
i
<
len
;
i
++
)
{
const
charStartOffset
=
i
;
const
charCode
=
lineText
.
charCodeAt
(
i
);
const
charCodeClass
=
classifier
.
get
(
charCode
);
let
charCodeClass
:
number
;
let
charWidth
:
number
;
if
(
strings
.
isHighSurrogate
(
prevC
harCode
))
{
if
(
strings
.
isHighSurrogate
(
c
harCode
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
visibleColumn
+=
1
;
prevCharCode
=
charCode
;
prevCharCodeClass
=
charCodeClass
;
continue
;
i
++
;
charCodeClass
=
CharacterClass
.
NONE
;
charWidth
=
2
;
}
else
{
charCodeClass
=
classifier
.
get
(
charCode
);
charWidth
=
computeCharWidth
(
charCode
,
visibleColumn
,
tabSize
,
columnsForFullWidthChar
);
}
if
(
canBreak
(
prevCharCodeClass
,
charCodeClass
))
{
breakOffset
=
i
;
breakOffset
=
charStartOffset
;
breakOffsetVisibleColumn
=
visibleColumn
;
}
const
charWidth
=
computeCharWidth
(
charCode
,
visibleColumn
,
tabSize
,
columnsForFullWidthChar
);
visibleColumn
+=
charWidth
;
// check if adding character at `i` will go over the breaking column
if
(
visibleColumn
>
breakingColumn
)
{
// We need to break at least before character at `i`:
forcedBreakOffset
=
i
;
forcedBreakOffset
=
charStartOffset
;
forcedBreakOffsetVisibleColumn
=
visibleColumn
-
charWidth
;
if
(
visibleColumn
-
breakOffsetVisibleColumn
>
wrappedLineBreakingColumn
)
{
...
...
@@ -188,9 +191,11 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
if
(
entireLineFits
)
{
// there is no more need to break => stop the outer loop!
// Add last segment
breakingOffsets
[
breakingOffsetsCount
]
=
prevBreakingOffsets
[
prevBreakingOffsets
.
length
-
1
];
breakingOffsetsVisibleColumn
[
breakingOffsetsCount
]
=
prevBreakingOffsetsVisibleColumn
[
prevBreakingOffsets
.
length
-
1
];
if
(
breakingOffsetsCount
>
0
)
{
// Add last segment
breakingOffsets
[
breakingOffsetsCount
]
=
prevBreakingOffsets
[
prevBreakingOffsets
.
length
-
1
];
breakingOffsetsVisibleColumn
[
breakingOffsetsCount
]
=
prevBreakingOffsetsVisibleColumn
[
prevBreakingOffsets
.
length
-
1
];
}
break
;
}
}
...
...
@@ -202,16 +207,8 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
let
charCodeClass
=
classifier
.
get
(
charCode
);
let
hitATabCharacter
=
false
;
for
(
let
i
=
prevBreakOffset
-
1
;
i
>=
0
;
i
--
)
{
const
charStartOffset
=
i
+
1
;
const
prevCharCode
=
lineText
.
charCodeAt
(
i
);
const
prevCharCodeClass
=
classifier
.
get
(
prevCharCode
);
if
(
strings
.
isHighSurrogate
(
prevCharCode
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
visibleColumn
-=
1
;
charCode
=
prevCharCode
;
charCodeClass
=
prevCharCodeClass
;
continue
;
}
if
(
prevCharCode
===
CharCode
.
Tab
)
{
// cannot determine the width of a tab when going backwards, so we must go forwards
...
...
@@ -219,11 +216,22 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
break
;
}
const
charWidth
=
(
strings
.
isFullWidthCharacter
(
prevCharCode
)
?
columnsForFullWidthChar
:
1
);
let
prevCharCodeClass
:
number
;
let
prevCharWidth
:
number
;
if
(
strings
.
isLowSurrogate
(
prevCharCode
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
i
--
;
prevCharCodeClass
=
CharacterClass
.
NONE
;
prevCharWidth
=
2
;
}
else
{
prevCharCodeClass
=
classifier
.
get
(
prevCharCode
);
prevCharWidth
=
(
strings
.
isFullWidthCharacter
(
prevCharCode
)
?
columnsForFullWidthChar
:
1
);
}
if
(
visibleColumn
<=
breakingColumn
)
{
if
(
forcedBreakOffset
===
0
)
{
forcedBreakOffset
=
i
+
1
;
forcedBreakOffset
=
charStartOffset
;
forcedBreakOffsetVisibleColumn
=
visibleColumn
;
}
...
...
@@ -233,17 +241,35 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
}
if
(
canBreak
(
prevCharCodeClass
,
charCodeClass
))
{
breakOffset
=
i
+
1
;
breakOffset
=
charStartOffset
;
breakOffsetVisibleColumn
=
visibleColumn
;
break
;
}
}
visibleColumn
-=
c
harWidth
;
visibleColumn
-=
prevC
harWidth
;
charCode
=
prevCharCode
;
charCodeClass
=
prevCharCodeClass
;
}
if
(
breakOffset
!==
0
)
{
const
remainingWidthOfNextLine
=
wrappedLineBreakingColumn
-
(
forcedBreakOffsetVisibleColumn
-
breakOffsetVisibleColumn
);
if
(
remainingWidthOfNextLine
<=
tabSize
)
{
const
charCodeAtForcedBreakOffset
=
lineText
.
charCodeAt
(
forcedBreakOffset
);
let
charWidth
:
number
;
if
(
strings
.
isHighSurrogate
(
charCodeAtForcedBreakOffset
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
charWidth
=
2
;
}
else
{
charWidth
=
computeCharWidth
(
charCodeAtForcedBreakOffset
,
forcedBreakOffsetVisibleColumn
,
tabSize
,
columnsForFullWidthChar
);
}
if
(
remainingWidthOfNextLine
-
charWidth
<
0
)
{
// it is not worth it to break at breakOffset, it just introduces an extra needless line!
breakOffset
=
0
;
}
}
}
if
(
hitATabCharacter
)
{
// cannot determine the width of a tab when going backwards, so we must go forwards from the previous break
prevIndex
--
;
...
...
@@ -266,14 +292,13 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
prevIndex
++
;
}
let
currentDiff
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
]
-
breakingColumn
);
// let lastBreakingColumn
let
bestDistance
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
]
-
breakingColumn
);
while
(
prevIndex
+
1
<
prevLen
)
{
const
potentialDiff
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
+
1
]
-
breakingColumn
);
if
(
potentialDiff
>=
currentDiff
)
{
const
distance
=
Math
.
abs
(
prevBreakingOffsetsVisibleColumn
[
prevIndex
+
1
]
-
breakingColumn
);
if
(
distance
>=
bestDistance
)
{
break
;
}
currentDiff
=
potentialDiff
;
bestDistance
=
distance
;
prevIndex
++
;
}
}
...
...
@@ -282,54 +307,56 @@ function createLineMappingFromPreviousLineMapping(classifier: WrappingCharacterC
return
null
;
}
// return new LineBreakingData(firstLineBreakingColumn, breakingOffsets, breakingOffsetsVisibleColumn, wrappedTextIndentLength);
const
expected
=
createLineMapping
(
classifier
,
lineText
,
tabSize
,
firstLineBreakingColumn
,
columnsForFullWidthChar
,
hardWrappingIndent
);
const
actual
=
new
LineBreakingData
(
firstLineBreakingColumn
,
breakingOffsets
,
breakingOffsetsVisibleColumn
,
wrappedTextIndentLength
);
try
{
actual
.
assertEqual
(
expected
);
}
catch
(
err
)
{
console
.
log
(
`BREAKING!!`
);
console
.
log
(
err
);
console
.
log
(
`previous breaks:
${
JSON
.
stringify
(
prevBreakingOffsets
)}
, breakingOffsetsVisibleColumn:
${
JSON
.
stringify
(
prevBreakingOffsetsVisibleColumn
)}
`
);
console
.
log
(
`expected breakOffsets:
${
JSON
.
stringify
(
expected
?.
breakOffsets
)}
, breakingOffsetsVisibleColumn:
${
JSON
.
stringify
(
expected
?.
breakingOffsetsVisibleColumn
)}
`
);
console
.
log
(
`actual breakOffsets:
${
JSON
.
stringify
(
actual
?.
breakOffsets
)}
, breakingOffsetsVisibleColumn:
${
JSON
.
stringify
(
actual
?.
breakingOffsetsVisibleColumn
)}
`
);
console
.
log
(
`actual str:
${
toAnnotatedText
(
lineText
,
actual
)}
`
);
console
.
log
(
`
assertIncrementalLineMapping(
factory,
${
str
(
lineText
)}
, 4,
${
previousBreakingData
.
breakingColumn
}
,
${
str
(
toAnnotatedText
(
lineText
,
previousBreakingData
))}
,
${
expected
!
.
breakingColumn
}
,
${
str
(
toAnnotatedText
(
lineText
,
expected
))}
,
WrappingIndent.
${
hardWrappingIndent
===
WrappingIndent
.
None
?
'
None
'
:
hardWrappingIndent
===
WrappingIndent
.
Same
?
'
Same
'
:
hardWrappingIndent
===
WrappingIndent
.
Indent
?
'
Indent
'
:
'
DeepIndent
'
}
);
`
);
function
str
(
strr
:
string
)
{
return
`'
${
strr
.
replace
(
/'/g
,
'
\\\'
'
)}
'`
;
}
function
toAnnotatedText
(
text
:
string
,
lineBreakingData
:
LineBreakingData
|
null
):
string
{
// Insert line break markers again, according to algorithm
let
actualAnnotatedText
=
''
;
if
(
lineBreakingData
)
{
let
previousLineIndex
=
0
;
for
(
let
i
=
0
,
len
=
text
.
length
;
i
<
len
;
i
++
)
{
let
r
=
LineBreakingData
.
getOutputPositionOfInputOffset
(
lineBreakingData
.
breakOffsets
,
i
);
if
(
previousLineIndex
!==
r
.
outputLineIndex
)
{
previousLineIndex
=
r
.
outputLineIndex
;
actualAnnotatedText
+=
'
|
'
;
}
actualAnnotatedText
+=
text
.
charAt
(
i
);
}
}
else
{
// No wrapping
actualAnnotatedText
=
text
;
}
return
actualAnnotatedText
;
}
}
return
actual
;
return
new
LineBreakingData
(
firstLineBreakingColumn
,
breakingOffsets
,
breakingOffsetsVisibleColumn
,
wrappedTextIndentLength
);
// const expected = createLineMapping(classifier, lineText, tabSize, firstLineBreakingColumn, columnsForFullWidthChar, hardWrappingIndent);
// const actual = new LineBreakingData(firstLineBreakingColumn, breakingOffsets, breakingOffsetsVisibleColumn, wrappedTextIndentLength);
// try {
// actual.assertEqual(expected);
// } catch (err) {
// console.log(`BREAKING!!`);
// console.log(err);
// console.log(`
// firstLineBreakingColumn: ${firstLineBreakingColumn}
// previous breaks: ${JSON.stringify(prevBreakingOffsets)}, breakingOffsetsVisibleColumn: ${JSON.stringify(prevBreakingOffsetsVisibleColumn)}
// expected breaks: ${JSON.stringify(expected?.breakOffsets)}, breakingOffsetsVisibleColumn: ${JSON.stringify(expected?.breakingOffsetsVisibleColumn)}
// actual breaks: ${JSON.stringify(actual?.breakOffsets)}, breakingOffsetsVisibleColumn: ${JSON.stringify(actual?.breakingOffsetsVisibleColumn)}
// previous str: ${toAnnotatedText(lineText, previousBreakingData)}
// expected str: ${toAnnotatedText(lineText, expected)}
// actual str: ${toAnnotatedText(lineText, actual)}
// assertIncrementalLineMapping(
// factory, ${str(lineText)}, 4,
// ${previousBreakingData.breakingColumn}, ${str(toAnnotatedText(lineText, previousBreakingData))},
// ${expected!.breakingColumn}, ${str(toAnnotatedText(lineText, expected))},
// WrappingIndent.${hardWrappingIndent === WrappingIndent.None ? 'None' : hardWrappingIndent === WrappingIndent.Same ? 'Same' : hardWrappingIndent === WrappingIndent.Indent ? 'Indent' : 'DeepIndent'}
// );
// `);
// function str(strr: string) {
// return `'${strr.replace(/\\/g, '\\\\').replace(/'/g, '\\\'')}'`;
// }
// function toAnnotatedText(text: string, lineBreakingData: LineBreakingData | null): string {
// // Insert line break markers again, according to algorithm
// let actualAnnotatedText = '';
// if (lineBreakingData) {
// let previousLineIndex = 0;
// for (let i = 0, len = text.length; i < len; i++) {
// let r = LineBreakingData.getOutputPositionOfInputOffset(lineBreakingData.breakOffsets, i);
// if (previousLineIndex !== r.outputLineIndex) {
// previousLineIndex = r.outputLineIndex;
// actualAnnotatedText += '|';
// }
// actualAnnotatedText += text.charAt(i);
// }
// } else {
// // No wrapping
// actualAnnotatedText = text;
// }
// return actualAnnotatedText;
// }
// }
// return actual;
}
function
createLineMapping
(
classifier
:
WrappingCharacterClassifier
,
lineText
:
string
,
tabSize
:
number
,
firstLineBreakingColumn
:
number
,
columnsForFullWidthChar
:
number
,
hardWrappingIndent
:
WrappingIndent
):
LineBreakingData
|
null
{
...
...
@@ -356,24 +383,36 @@ function createLineMapping(classifier: WrappingCharacterClassifier, lineText: st
let
prevCharCodeClass
=
classifier
.
get
(
prevCharCode
);
let
visibleColumn
=
computeCharWidth
(
prevCharCode
,
0
,
tabSize
,
columnsForFullWidthChar
);
for
(
let
i
=
1
;
i
<
len
;
i
++
)
{
let
startOffset
=
1
;
if
(
strings
.
isHighSurrogate
(
prevCharCode
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
visibleColumn
+=
1
;
prevCharCode
=
lineText
.
charCodeAt
(
1
);
prevCharCodeClass
=
classifier
.
get
(
prevCharCode
);
startOffset
++
;
}
for
(
let
i
=
startOffset
;
i
<
len
;
i
++
)
{
const
charStartOffset
=
i
;
const
charCode
=
lineText
.
charCodeAt
(
i
);
const
charCodeClass
=
classifier
.
get
(
charCode
);
let
charCodeClass
:
number
;
let
charWidth
:
number
;
if
(
strings
.
isHighSurrogate
(
prevC
harCode
))
{
if
(
strings
.
isHighSurrogate
(
c
harCode
))
{
// A surrogate pair must always be considered as a single unit, so it is never to be broken
visibleColumn
+=
1
;
prevCharCode
=
charCode
;
prevCharCodeClass
=
charCodeClass
;
continue
;
i
++
;
charCodeClass
=
CharacterClass
.
NONE
;
charWidth
=
2
;
}
else
{
charCodeClass
=
classifier
.
get
(
charCode
);
charWidth
=
computeCharWidth
(
charCode
,
visibleColumn
,
tabSize
,
columnsForFullWidthChar
);
}
if
(
canBreak
(
prevCharCodeClass
,
charCodeClass
))
{
breakOffset
=
i
;
breakOffset
=
charStartOffset
;
breakOffsetVisibleColumn
=
visibleColumn
;
}
const
charWidth
=
computeCharWidth
(
charCode
,
visibleColumn
,
tabSize
,
columnsForFullWidthChar
);
visibleColumn
+=
charWidth
;
// check if adding character at `i` will go over the breaking column
...
...
@@ -382,7 +421,7 @@ function createLineMapping(classifier: WrappingCharacterClassifier, lineText: st
if
(
breakOffset
===
0
||
visibleColumn
-
breakOffsetVisibleColumn
>
wrappedLineBreakingColumn
)
{
// Cannot break at `breakOffset`, must break at `i`
breakOffset
=
i
;
breakOffset
=
charStartOffset
;
breakOffsetVisibleColumn
=
visibleColumn
-
charWidth
;
}
...
...
src/vs/editor/test/common/viewModel/characterHardWrappingLineMapper.test.ts
浏览文件 @
efd7f099
...
...
@@ -154,6 +154,34 @@ suite('Editor ViewModel - CharacterHardWrappingLineMapper', () => {
16
,
'
\t\t
"owner":| |"vscode"|,
'
,
WrappingIndent
.
Same
);
assertIncrementalLineMapping
(
factory
,
'
🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇&👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬
'
,
4
,
51
,
'
🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇&|👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬
'
,
50
,
'
🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇|&|👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬
'
,
WrappingIndent
.
Same
);
assertIncrementalLineMapping
(
factory
,
'
🐇👬&🌞🌖
'
,
4
,
5
,
'
🐇👬&|🌞🌖
'
,
4
,
'
🐇👬|&|🌞🌖
'
,
WrappingIndent
.
Same
);
assertIncrementalLineMapping
(
factory
,
'
\t\t
func(
\'
🌞🏇🍼🌞🏇🍼🐇&👬🌖🌞👬🌖🌞🏇🍼🐇👬
\'
, WrappingIndent.Same);
'
,
4
,
26
,
'
\t\t
func|(
\'
🌞🏇🍼🌞🏇🍼🐇&|👬🌖🌞👬🌖🌞🏇🍼🐇|👬
\'
, |WrappingIndent.|Same);
'
,
27
,
'
\t\t
func|(
\'
🌞🏇🍼🌞🏇🍼🐇&|👬🌖🌞👬🌖🌞🏇🍼🐇|👬
\'
, |WrappingIndent.|Same);
'
,
WrappingIndent
.
Same
);
assertIncrementalLineMapping
(
factory
,
'
factory, "xtxtfunc(x"🌞🏇🍼🌞🏇🍼🐇&👬🌖🌞👬🌖🌞🏇🍼🐇👬x"
'
,
4
,
16
,
'
factory, |"xtxtfunc|(x"🌞🏇🍼🌞🏇🍼|🐇&|👬🌖🌞👬🌖🌞🏇🍼|🐇👬x"
'
,
17
,
'
factory, |"xtxtfunc|(x"🌞🏇🍼🌞🏇🍼🐇|&👬🌖🌞👬🌖🌞🏇🍼|🐇👬x"
'
,
WrappingIndent
.
Same
);
});
...
...
@@ -185,7 +213,17 @@ suite('Editor ViewModel - CharacterHardWrappingLineMapper', () => {
test
(
'
issue #75494: surrogate pairs
'
,
()
=>
{
let
factory
=
new
CharacterHardWrappingLineMapperFactory
(
'
\t
'
,
'
'
);
assertLineMapping
(
factory
,
4
,
49
,
'
🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇|👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬
'
,
WrappingIndent
.
Same
);
assertLineMapping
(
factory
,
4
,
49
,
'
🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼|🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼🐇👬🌖🌞🏇🍼|🐇👬
'
,
WrappingIndent
.
Same
);
});
test
(
'
issue #75494: surrogate pairs overrun 1
'
,
()
=>
{
const
factory
=
new
CharacterHardWrappingLineMapperFactory
(
EditorOptions
.
wordWrapBreakBeforeCharacters
.
defaultValue
,
EditorOptions
.
wordWrapBreakAfterCharacters
.
defaultValue
);
assertLineMapping
(
factory
,
4
,
4
,
'
🐇👬|&|🌞🌖
'
,
WrappingIndent
.
Same
);
});
test
(
'
issue #75494: surrogate pairs overrun 2
'
,
()
=>
{
const
factory
=
new
CharacterHardWrappingLineMapperFactory
(
EditorOptions
.
wordWrapBreakBeforeCharacters
.
defaultValue
,
EditorOptions
.
wordWrapBreakAfterCharacters
.
defaultValue
);
assertLineMapping
(
factory
,
4
,
17
,
'
factory, |"xtxtfunc|(x"🌞🏇🍼🌞🏇🍼🐇|&👬🌖🌞👬🌖🌞🏇🍼|🐇👬x"
'
,
WrappingIndent
.
Same
);
});
test
(
'
CharacterHardWrappingLineMapper - WrappingIndent.DeepIndent
'
,
()
=>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录