Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
7c548667
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,发现更多精彩内容 >>
提交
7c548667
编写于
12月 07, 2015
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
suggest: remove SuggestWidget.setModel
上级
ef0b0ea0
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
124 addition
and
123 deletion
+124
-123
src/vs/editor/contrib/suggest/browser/suggest.ts
src/vs/editor/contrib/suggest/browser/suggest.ts
+18
-11
src/vs/editor/contrib/suggest/browser/suggestWidget.ts
src/vs/editor/contrib/suggest/browser/suggestWidget.ts
+106
-112
未找到文件。
src/vs/editor/contrib/suggest/browser/suggest.ts
浏览文件 @
7c548667
...
...
@@ -39,20 +39,27 @@ export class SuggestController implements EditorCommon.IEditorContribution {
private
triggerCharacterListeners
:
Function
[];
private
suggestWidgetVisible
:
IKeybindingContextKey
<
boolean
>
;
constructor
(
editor
:
EditorBrowser
.
ICodeEditor
,
@
IKeybindingService
keybindingService
:
IKeybindingService
,
@
ITelemetryService
telemetryService
:
ITelemetryService
)
{
constructor
(
editor
:
EditorBrowser
.
ICodeEditor
,
@
IKeybindingService
keybindingService
:
IKeybindingService
,
@
ITelemetryService
telemetryService
:
ITelemetryService
)
{
this
.
editor
=
editor
;
this
.
suggestWidgetVisible
=
keybindingService
.
createKey
(
CONTEXT_SUGGEST_WIDGET_VISIBLE
,
false
);
this
.
model
=
new
SuggestModel
.
SuggestModel
(
this
.
editor
,
(
snippet
:
Snippet
.
CodeSnippet
,
overwriteBefore
:
number
,
overwriteAfter
:
number
)
=>
{
Snippet
.
get
(
this
.
editor
).
run
(
snippet
,
overwriteBefore
,
overwriteAfter
);
});
this
.
suggestWidget
=
new
SuggestWidget
.
SuggestWidget
(
this
.
editor
,
telemetryService
,
keybindingService
,
()
=>
{
this
.
suggestWidgetVisible
.
set
(
true
);
},
()
=>
{
this
.
suggestWidgetVisible
.
reset
();
});
this
.
suggestWidget
.
setModel
(
this
.
model
);
this
.
model
=
new
SuggestModel
.
SuggestModel
(
this
.
editor
,
(
snippet
:
Snippet
.
CodeSnippet
,
overwriteBefore
:
number
,
overwriteAfter
:
number
)
=>
Snippet
.
get
(
this
.
editor
).
run
(
snippet
,
overwriteBefore
,
overwriteAfter
)
);
this
.
suggestWidget
=
new
SuggestWidget
.
SuggestWidget
(
this
.
editor
,
this
.
model
,
telemetryService
,
keybindingService
,
()
=>
this
.
suggestWidgetVisible
.
set
(
true
),
()
=>
this
.
suggestWidgetVisible
.
reset
()
);
this
.
triggerCharacterListeners
=
[];
...
...
src/vs/editor/contrib/suggest/browser/suggestWidget.ts
浏览文件 @
7c548667
...
...
@@ -15,7 +15,7 @@ import Tree = require('vs/base/parts/tree/common/tree');
import
TreeImpl
=
require
(
'
vs/base/parts/tree/browser/treeImpl
'
);
import
TreeDefaults
=
require
(
'
vs/base/parts/tree/browser/treeDefaults
'
);
import
HighlightedLabel
=
require
(
'
vs/base/browser/ui/highlightedlabel/highlightedLabel
'
);
import
{
SuggestModel
,
SuggestDataEvent
,
CompletionItem
}
from
'
./suggestModel
'
;
import
{
SuggestModel
,
SuggestDataEvent
,
CompletionItem
,
ICancelEvent
,
ISuggestEvent
,
ITriggerEvent
}
from
'
./suggestModel
'
;
import
Mouse
=
require
(
'
vs/base/browser/mouseEvent
'
);
import
EditorBrowser
=
require
(
'
vs/editor/browser/editorBrowser
'
);
import
EditorCommon
=
require
(
'
vs/editor/common/editorCommon
'
);
...
...
@@ -259,11 +259,12 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
private
isAuto
:
boolean
;
private
listenersToRemove
:
EventEmitter
.
ListenerUnbind
[];
private
modelListenersToRemove
:
IDisposable
[];
private
model
:
SuggestModel
;
private
suggestionSupportsAutoAccept
:
IKeybindingContextKey
<
boolean
>
;
private
loadingTimeout
:
number
;
private
telemetryData
:
ITelemetryData
;
private
telemetryService
:
ITelemetryService
;
private
telemetryTimer
:
Timer
.
ITimerEvent
;
private
element
:
HTMLElement
;
private
tree
:
Tree
.
ITree
;
...
...
@@ -275,7 +276,14 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
private
_onShown
:
()
=>
void
;
private
_onHidden
:
()
=>
void
;
constructor
(
editor
:
EditorBrowser
.
ICodeEditor
,
telemetryService
:
ITelemetryService
,
keybindingService
:
IKeybindingService
,
onShown
:
()
=>
void
,
onHidden
:
()
=>
void
)
{
constructor
(
editor
:
EditorBrowser
.
ICodeEditor
,
private
model
:
SuggestModel
,
telemetryService
:
ITelemetryService
,
keybindingService
:
IKeybindingService
,
onShown
:
()
=>
void
,
onHidden
:
()
=>
void
)
{
this
.
editor
=
editor
;
this
.
_onShown
=
onShown
;
this
.
_onHidden
=
onHidden
;
...
...
@@ -284,7 +292,6 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
this
.
isLoading
=
false
;
this
.
isAuto
=
false
;
this
.
modelListenersToRemove
=
[];
this
.
model
=
null
;
this
.
suggestionSupportsAutoAccept
=
keybindingService
.
createKey
<
boolean
>
(
CONTEXT_SUGGESTION_SUPPORTS_ACCEPT_ON_KEY
,
true
);
this
.
telemetryData
=
null
;
...
...
@@ -399,130 +406,121 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
}));
this
.
hide
();
}
public
setModel
(
newModel
:
SuggestModel
)
:
void
{
this
.
releaseModel
();
this
.
model
=
newModel
;
var
timer
:
Timer
.
ITimerEvent
=
null
,
loadingHandle
:
number
;
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidTrigger
(
e
=>
this
.
onDidTrigger
(
e
)));
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidSuggest
(
e
=>
this
.
onDidSuggest
(
e
)));
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidCancel
(
e
=>
this
.
onDidCancel
(
e
)));
}
private
onDidTrigger
(
e
:
ITriggerEvent
)
{
if
(
!
this
.
isActive
)
{
this
.
telemetryTimer
=
this
.
telemetryService
.
start
(
'
suggestWidgetLoadingTime
'
);
this
.
isLoading
=
true
;
this
.
isAuto
=
!!
e
.
auto
;
if
(
!
this
.
isAuto
)
{
this
.
loadingTimeout
=
setTimeout
(()
=>
{
this
.
loadingTimeout
=
null
;
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
SuggestWidget
.
LOADING_MESSAGE
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
updateWidgetHeight
();
this
.
show
();
},
50
);
}
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidTrigger
(
e
=>
{
if
(
!
this
.
isActive
)
{
timer
=
this
.
telemetryService
.
start
(
'
suggestWidgetLoadingTime
'
);
this
.
isLoading
=
true
;
this
.
isAuto
=
!!
e
.
auto
;
if
(
!
this
.
isAuto
)
{
loadingHandle
=
setTimeout
(()
=>
{
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
SuggestWidget
.
LOADING_MESSAGE
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
updateWidgetHeight
();
this
.
show
();
},
50
);
}
if
(
!
e
.
retrigger
)
{
this
.
telemetryData
=
{
wasAutomaticallyTriggered
:
e
.
characterTriggered
};
}
if
(
!
e
.
retrigger
)
{
this
.
telemetryData
=
{
wasAutomaticallyTriggered
:
e
.
characterTriggered
};
}
}));
}
}
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidSuggest
(
e
=>
{
if
(
!
e
.
suggestions
)
{
// empty
const
wasLoading
=
this
.
isLoading
;
this
.
isLoading
=
false
;
private
onDidSuggest
(
e
:
ISuggestEvent
)
{
const
wasLoading
=
this
.
isLoading
;
this
.
isLoading
=
false
;
clearTimeout
(
this
.
loadingTimeout
)
;
if
(
typeof
loadingHandle
!==
'
undefined
'
)
{
clearTimeout
(
loadingHandle
);
}
if
(
!
e
.
suggestions
)
{
// empty
if
(
e
.
auto
)
{
this
.
hide
();
}
else
if
(
wasLoading
)
{
if
(
this
.
shouldShowEmptySuggestionList
)
{
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
SuggestWidget
.
NO_SUGGESTIONS_MESSAGE
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
updateWidgetHeight
();
this
.
show
();
}
else
{
this
.
hide
();
}
if
(
e
.
auto
)
{
this
.
hide
();
}
else
if
(
wasLoading
)
{
if
(
this
.
shouldShowEmptySuggestionList
)
{
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
SuggestWidget
.
NO_SUGGESTIONS_MESSAGE
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
updateWidgetHeight
();
this
.
show
();
}
else
{
dom
.
addClass
(
this
.
element
,
'
empty
'
);
}
if
(
timer
)
{
timer
.
data
=
{
reason
:
'
empty
'
};
timer
.
stop
();
timer
=
null
;
this
.
hide
();
}
return
;
}
else
{
dom
.
addClass
(
this
.
element
,
'
empty
'
)
;
}
this
.
isLoading
=
false
;
if
(
typeof
loadingHandle
!==
'
undefined
'
)
{
clearTimeout
(
loadingHandle
)
;
if
(
this
.
telemetryTimer
)
{
this
.
telemetryTimer
.
data
=
{
reason
:
'
empty
'
};
this
.
telemetryTimer
.
stop
();
this
.
telemetryTimer
=
null
;
}
var
currentWord
=
e
.
suggestions
.
currentWord
;
var
currentWordLowerCase
=
currentWord
.
toLowerCase
();
var
suggestions
=
e
.
suggestions
.
completionItems
;
return
;
}
const
currentWord
=
e
.
suggestions
.
currentWord
;
const
currentWordLowerCase
=
currentWord
.
toLowerCase
();
const
suggestions
=
e
.
suggestions
.
completionItems
;
var
bestSuggestionIndex
=
-
1
;
var
bestSuggestion
=
suggestions
[
0
];
var
bestScore
=
-
1
;
let
bestSuggestionIndex
=
-
1
;
let
bestSuggestion
=
suggestions
[
0
];
let
bestScore
=
-
1
;
for
(
var
i
=
0
,
len
=
suggestions
.
length
;
i
<
len
;
i
++
)
{
var
score
=
computeScore
(
suggestions
[
i
].
suggestion
.
label
,
currentWord
,
currentWordLowerCase
);
if
(
score
>
bestScore
)
{
bestScore
=
score
;
bestSuggestion
=
suggestions
[
i
];
bestSuggestionIndex
=
i
;
}
for
(
var
i
=
0
,
len
=
suggestions
.
length
;
i
<
len
;
i
++
)
{
var
score
=
computeScore
(
suggestions
[
i
].
suggestion
.
label
,
currentWord
,
currentWordLowerCase
);
if
(
score
>
bestScore
)
{
bestScore
=
score
;
bestSuggestion
=
suggestions
[
i
];
bestSuggestionIndex
=
i
;
}
}
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
e
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
tree
.
setFocus
(
bestSuggestion
,
{
firstSuggestion
:
true
});
this
.
updateWidgetHeight
();
this
.
show
();
this
.
telemetryData
=
this
.
telemetryData
||
{};
this
.
telemetryData
.
suggestionCount
=
suggestions
.
length
;
this
.
telemetryData
.
suggestedIndex
=
bestSuggestionIndex
;
this
.
telemetryData
.
hintLength
=
currentWord
.
length
;
if
(
t
imer
)
{
t
imer
.
data
=
{
reason
:
'
results
'
};
t
imer
.
stop
();
t
imer
=
null
;
}
}));
dom
.
removeClass
(
this
.
element
,
'
empty
'
);
this
.
tree
.
setInput
(
e
).
done
(
null
,
Errors
.
onUnexpectedError
);
this
.
tree
.
setFocus
(
bestSuggestion
,
{
firstSuggestion
:
true
});
this
.
updateWidgetHeight
();
this
.
show
();
this
.
telemetryData
=
this
.
telemetryData
||
{};
this
.
telemetryData
.
suggestionCount
=
suggestions
.
length
;
this
.
telemetryData
.
suggestedIndex
=
bestSuggestionIndex
;
this
.
telemetryData
.
hintLength
=
currentWord
.
length
;
if
(
this
.
telemetryT
imer
)
{
this
.
telemetryT
imer
.
data
=
{
reason
:
'
results
'
};
this
.
telemetryT
imer
.
stop
();
this
.
telemetryT
imer
=
null
;
}
}
this
.
modelListenersToRemove
.
push
(
this
.
model
.
onDidCancel
(
e
=>
{
this
.
isLoading
=
false
;
private
onDidCancel
(
e
:
ICancelEvent
)
{
this
.
isLoading
=
false
;
if
(
!
e
.
retrigger
)
{
this
.
hide
();
if
(
!
e
.
retrigger
)
{
this
.
hide
();
if
(
this
.
telemetryData
)
{
this
.
telemetryData
.
selectedIndex
=
-
1
;
this
.
telemetryData
.
wasCancelled
=
true
;
this
.
submitTelemetryData
();
}
if
(
this
.
telemetryData
)
{
this
.
telemetryData
.
selectedIndex
=
-
1
;
this
.
telemetryData
.
wasCancelled
=
true
;
this
.
submitTelemetryData
();
}
}
if
(
timer
)
{
timer
.
data
=
{
reason
:
'
cancel
'
};
timer
.
stop
();
timer
=
null
;
}
}));
if
(
this
.
telemetryTimer
)
{
this
.
telemetryTimer
.
data
=
{
reason
:
'
cancel
'
};
this
.
telemetryTimer
.
stop
();
this
.
telemetryTimer
=
null
;
}
}
private
currentSuggestionDetails
:
TPromise
<
CompletionItem
>
;
...
...
@@ -613,11 +611,6 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
return
false
;
}
private
releaseModel
()
:
void
{
this
.
modelListenersToRemove
=
disposeAll
(
this
.
modelListenersToRemove
);
this
.
model
=
null
;
}
public
show
():
void
{
this
.
_onShown
();
this
.
isActive
=
true
;
...
...
@@ -687,7 +680,8 @@ export class SuggestWidget implements EditorBrowser.IContentWidget {
}
public
destroy
()
:
void
{
this
.
releaseModel
();
this
.
modelListenersToRemove
=
disposeAll
(
this
.
modelListenersToRemove
);
this
.
model
=
null
;
this
.
tree
.
dispose
();
this
.
tree
=
null
;
this
.
element
=
null
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录