Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
9a0b59c5
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,发现更多精彩内容 >>
提交
9a0b59c5
编写于
2月 21, 2018
作者:
P
Pine Wu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
basic completion
上级
2fee5d4f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
87 addition
and
3 deletion
+87
-3
extensions/html/server/src/htmlServerMain.ts
extensions/html/server/src/htmlServerMain.ts
+11
-3
extensions/html/server/src/modes/htmlMode.ts
extensions/html/server/src/modes/htmlMode.ts
+11
-0
extensions/html/server/src/modes/pathCompletion.ts
extensions/html/server/src/modes/pathCompletion.ts
+65
-0
未找到文件。
extensions/html/server/src/htmlServerMain.ts
浏览文件 @
9a0b59c5
...
...
@@ -18,6 +18,7 @@ import { getDocumentContext } from './utils/documentContext';
import
uri
from
'
vscode-uri
'
;
import
{
formatError
,
runSafe
}
from
'
./utils/errors
'
;
import
{
doComplete
as
emmetDoComplete
,
updateExtensionsPath
as
updateEmmetExtensionsPath
,
getEmmetCompletionParticipants
}
from
'
vscode-emmet-helper
'
;
import
{
getPathCompletionParticipant
}
from
'
./modes/pathCompletion
'
;
namespace
TagCloseRequest
{
export
const
type
:
RequestType
<
TextDocumentPositionParams
,
string
|
null
,
any
,
any
>
=
new
RequestType
(
'
html/tag
'
);
...
...
@@ -272,9 +273,16 @@ connection.onCompletion(async textDocumentPosition => {
isIncomplete
:
true
,
items
:
undefined
};
let
pathCompletionList
:
CompletionList
=
{
isIncomplete
:
false
,
items
:
undefined
};
if
(
mode
.
setCompletionParticipants
)
{
const
emmetCompletionParticipant
=
getEmmetCompletionParticipants
(
document
,
textDocumentPosition
.
position
,
mode
.
getId
(),
emmetSettings
,
emmetCompletionList
);
mode
.
setCompletionParticipants
([
emmetCompletionParticipant
]);
const
pathCompletionParticipant
=
getPathCompletionParticipant
(
document
,
textDocumentPosition
.
position
,
pathCompletionList
,
workspaceFolders
);
mode
.
setCompletionParticipants
([
emmetCompletionParticipant
,
pathCompletionParticipant
]);
}
let
settings
=
await
getDocumentSettings
(
document
,
()
=>
mode
.
doComplete
.
length
>
2
);
...
...
@@ -284,9 +292,9 @@ connection.onCompletion(async textDocumentPosition => {
if
(
emmetCompletionList
.
items
.
length
&&
hexColorRegex
.
test
(
emmetCompletionList
.
items
[
0
].
label
)
&&
result
.
items
.
some
(
x
=>
x
.
label
===
emmetCompletionList
.
items
[
0
].
label
))
{
emmetCompletionList
.
items
.
shift
();
}
return
{
isIncomplete
:
true
,
items
:
[...
emmetCompletionList
.
items
,
...
result
.
items
]
};
return
{
isIncomplete
:
true
,
items
:
[...
emmetCompletionList
.
items
,
...
pathCompletionList
.
items
,
...
result
.
items
]
};
}
return
result
;
return
{
isIncomplete
:
false
,
items
:
[...
pathCompletionList
.
items
,
...
result
.
items
]
}
;
},
null
,
`Error while computing completions for
${
textDocumentPosition
.
textDocument
.
uri
}
`
);
});
...
...
extensions/html/server/src/modes/htmlMode.ts
浏览文件 @
9a0b59c5
...
...
@@ -32,10 +32,21 @@ export function getHTMLMode(htmlLanguageService: HTMLLanguageService): LanguageM
const
node
=
htmlDocument
.
findNodeBefore
(
offset
);
const
scanner
=
htmlLanguageService
.
createScanner
(
document
.
getText
(),
node
.
start
);
let
token
=
scanner
.
scan
();
let
prevTag
,
prevAttributeName
;
while
(
token
!==
TokenType
.
EOS
&&
scanner
.
getTokenOffset
()
<=
offset
)
{
if
(
token
===
TokenType
.
Content
&&
offset
<=
scanner
.
getTokenEnd
())
{
completionParticipants
.
forEach
(
participant
=>
{
if
(
participant
.
onHtmlContent
)
{
participant
.
onHtmlContent
();
}
});
break
;
}
else
if
(
token
===
TokenType
.
AttributeName
)
{
prevAttributeName
=
scanner
.
getTokenText
();
}
else
if
(
token
===
TokenType
.
StartTag
)
{
prevTag
=
scanner
.
getTokenText
();
}
else
if
(
token
===
TokenType
.
AttributeValue
&&
offset
<=
scanner
.
getTokenEnd
())
{
completionParticipants
.
forEach
(
participant
=>
{
if
(
participant
.
onHtmlAttributeValue
)
{
participant
.
onHtmlAttributeValue
(
prevTag
,
prevAttributeName
,
scanner
.
getTokenText
());
}
});
}
token
=
scanner
.
scan
();
}
...
...
extensions/html/server/src/modes/pathCompletion.ts
0 → 100644
浏览文件 @
9a0b59c5
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
{
TextDocument
,
Position
,
CompletionList
,
CompletionItemKind
}
from
'
vscode-languageserver-types
'
;
import
{
WorkspaceFolder
}
from
'
vscode-languageserver-protocol/lib/protocol.workspaceFolders.proposed
'
;
import
*
as
path
from
'
path
'
;
import
*
as
fs
from
'
fs
'
;
import
uri
from
'
vscode-uri
'
;
export
function
getPathCompletionParticipant
(
document
:
TextDocument
,
position
:
Position
,
result
:
CompletionList
,
workspaceFolders
:
WorkspaceFolder
[]
|
undefined
)
{
return
{
onHtmlAttributeValue
:
(
tag
,
attributeName
,
attributeValue
)
=>
{
const
pathTagAndAttribute
:
{
[
t
:
string
]:
string
}
=
{
a
:
'
href
'
,
script
:
'
src
'
,
img
:
'
src
'
,
link
:
'
href
'
};
const
isDir
=
(
p
:
string
)
=>
fs
.
statSync
(
p
).
isDirectory
();
if
(
pathTagAndAttribute
[
tag
]
&&
pathTagAndAttribute
[
tag
]
===
attributeName
)
{
const
currPath
=
attributeValue
.
replace
(
/
[
'"
]
/g
,
''
);
let
resolvedPath
;
if
(
currPath
.
startsWith
(
'
/
'
))
{
if
(
!
workspaceFolders
||
workspaceFolders
.
length
===
0
)
{
return
;
}
for
(
let
i
=
0
;
i
<
workspaceFolders
.
length
;
i
++
)
{
if
(
document
.
uri
.
indexOf
(
workspaceFolders
[
i
].
uri
)
!==
-
1
)
{
resolvedPath
=
path
.
resolve
(
uri
.
parse
(
workspaceFolders
[
i
].
uri
).
fsPath
);
}
}
}
else
{
resolvedPath
=
path
.
resolve
(
uri
.
parse
(
document
.
uri
).
fsPath
,
'
..
'
,
currPath
);
}
if
(
resolvedPath
&&
isDir
(
resolvedPath
))
{
const
filesAndFolders
=
fs
.
readdirSync
(
resolvedPath
);
if
(
!
result
.
items
)
{
result
.
items
=
[];
}
for
(
let
i
=
0
;
i
<
filesAndFolders
.
length
;
i
++
)
{
const
kind
=
isDir
(
path
.
resolve
(
resolvedPath
,
filesAndFolders
[
i
]))
?
CompletionItemKind
.
Folder
:
CompletionItemKind
.
File
;
result
.
items
.
push
({
label
:
filesAndFolders
[
i
],
kind
});
}
}
}
}
};
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录