Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
86b8fb26
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,发现更多精彩内容 >>
未验证
提交
86b8fb26
编写于
1月 26, 2018
作者:
J
Johannes Rieken
提交者:
GitHub
1月 26, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #37691 from Krzysztof-Cieslak/resolveInitialRenameValue
Resolve initial rename value
上级
86244d39
403d5d41
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
118 addition
and
27 deletion
+118
-27
src/vs/editor/common/modes.ts
src/vs/editor/common/modes.ts
+6
-0
src/vs/editor/contrib/rename/rename.ts
src/vs/editor/contrib/rename/rename.ts
+67
-24
src/vs/monaco.d.ts
src/vs/monaco.d.ts
+6
-0
src/vs/vscode.d.ts
src/vs/vscode.d.ts
+7
-0
src/vs/workbench/api/electron-browser/mainThreadLanguageFeatures.ts
...kbench/api/electron-browser/mainThreadLanguageFeatures.ts
+5
-1
src/vs/workbench/api/node/extHost.protocol.ts
src/vs/workbench/api/node/extHost.protocol.ts
+2
-1
src/vs/workbench/api/node/extHostLanguageFeatures.ts
src/vs/workbench/api/node/extHostLanguageFeatures.ts
+25
-1
未找到文件。
src/vs/editor/common/modes.ts
浏览文件 @
86b8fb26
...
...
@@ -856,8 +856,14 @@ export interface WorkspaceEdit {
rejectReason
?:
string
;
// TODO@joh, move to rename
}
export
interface
RenameInitialValue
{
range
:
IRange
;
text
?:
string
;
}
export
interface
RenameProvider
{
provideRenameEdits
(
model
:
model
.
ITextModel
,
position
:
Position
,
newName
:
string
,
token
:
CancellationToken
):
WorkspaceEdit
|
Thenable
<
WorkspaceEdit
>
;
resolveInitialRenameValue
?(
model
:
model
.
ITextModel
,
position
:
Position
,
token
:
CancellationToken
):
RenameInitialValue
|
Thenable
<
RenameInitialValue
>
;
}
...
...
src/vs/editor/contrib/rename/rename.ts
浏览文件 @
86b8fb26
...
...
@@ -6,7 +6,7 @@
'
use strict
'
;
import
*
as
nls
from
'
vs/nls
'
;
import
{
isPromiseCanceledError
,
illegalArgument
}
from
'
vs/base/common/errors
'
;
import
{
isPromiseCanceledError
,
illegalArgument
,
onUnexpectedExternalError
}
from
'
vs/base/common/errors
'
;
import
{
KeyMod
,
KeyCode
}
from
'
vs/base/common/keyCodes
'
;
import
Severity
from
'
vs/base/common/severity
'
;
import
{
TPromise
}
from
'
vs/base/common/winjs.base
'
;
...
...
@@ -25,7 +25,7 @@ import { ITextModelService } from 'vs/editor/common/services/resolverService';
import
{
optional
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
IThemeService
}
from
'
vs/platform/theme/common/themeService
'
;
import
{
sequence
,
asWinJsPromise
}
from
'
vs/base/common/async
'
;
import
{
WorkspaceEdit
,
RenameProviderRegistry
}
from
'
vs/editor/common/modes
'
;
import
{
WorkspaceEdit
,
RenameProviderRegistry
,
RenameInitialValue
}
from
'
vs/editor/common/modes
'
;
import
{
Position
}
from
'
vs/editor/common/core/position
'
;
import
{
alert
}
from
'
vs/base/browser/ui/aria/aria
'
;
import
{
Range
}
from
'
vs/editor/common/core/range
'
;
...
...
@@ -79,6 +79,19 @@ export function rename(model: ITextModel, position: Position, newName: string):
});
}
function
resolveInitialRenameValue
(
model
:
ITextModel
,
position
:
Position
):
TPromise
<
RenameInitialValue
>
{
const
supports
=
RenameProviderRegistry
.
ordered
(
model
);
return
asWinJsPromise
((
token
)
=>
supports
.
length
>
0
?
supports
[
0
].
resolveInitialRenameValue
(
model
,
position
,
token
)
//Use first rename provider so that we always use the same for resolving the location and for the actual rename
:
undefined
).
then
(
result
=>
{
return
!
result
?
undefined
:
result
;
},
err
=>
{
onUnexpectedExternalError
(
err
);
return
TPromise
.
wrapError
<
RenameInitialValue
>
(
new
Error
(
'
provider failed
'
));
});
}
// --- register actions and commands
...
...
@@ -116,34 +129,64 @@ class RenameController implements IEditorContribution {
return
RenameController
.
ID
;
}
public
run
():
TPromise
<
void
>
{
public
async
run
():
TPromise
<
void
>
{
const
selection
=
this
.
editor
.
getSelection
();
let
lineNumber
=
selection
.
startLineNumber
,
selectionStart
=
0
,
selectionEnd
=
0
,
wordRange
:
Range
,
word
:
string
;
const
selection
=
this
.
editor
.
getSelection
(),
word
=
this
.
editor
.
getModel
().
getWordAtPosition
(
selection
.
getStartPosition
());
let
initialValue
=
await
resolveInitialRenameValue
(
this
.
editor
.
getModel
(),
this
.
editor
.
getPosition
());
if
(
initialValue
)
{
lineNumber
=
initialValue
.
range
.
startLineNumber
;
if
(
initialValue
.
text
)
{
word
=
initialValue
.
text
;
}
else
{
word
=
this
.
editor
.
getModel
().
getValueInRange
(
initialValue
.
range
);
}
selectionEnd
=
word
.
length
;
if
(
!
selection
.
isEmpty
()
&&
selection
.
startLineNumber
===
selection
.
endLineNumber
)
{
selectionStart
=
Math
.
max
(
0
,
selection
.
startColumn
-
initialValue
.
range
.
startColumn
);
selectionEnd
=
Math
.
min
(
initialValue
.
range
.
endColumn
,
selection
.
endColumn
)
-
initialValue
.
range
.
startColumn
;
}
wordRange
=
new
Range
(
lineNumber
,
initialValue
.
range
.
startColumn
,
lineNumber
,
initialValue
.
range
.
endColumn
);
if
(
!
word
)
{
return
undefined
;
}
else
{
const
wordAtPosition
=
this
.
editor
.
getModel
().
getWordAtPosition
(
selection
.
getStartPosition
());
let
lineNumber
=
selection
.
startLineNumber
,
selectionStart
=
0
,
selectionEnd
=
word
.
word
.
length
,
wordRange
:
Range
;
wordRange
=
new
Range
(
lineNumber
,
word
.
startColumn
,
lineNumber
,
word
.
endColumn
);
if
(
!
selection
.
isEmpty
()
&&
selection
.
startLineNumber
===
selection
.
endLineNumber
)
{
selectionStart
=
Math
.
max
(
0
,
selection
.
startColumn
-
word
.
startColumn
);
selectionEnd
=
Math
.
min
(
word
.
endColumn
,
selection
.
endColumn
)
-
word
.
startColumn
;
if
(
!
wordAtPosition
)
{
return
undefined
;
}
word
=
wordAtPosition
.
word
;
selectionEnd
=
word
.
length
;
if
(
!
selection
.
isEmpty
()
&&
selection
.
startLineNumber
===
selection
.
endLineNumber
)
{
selectionStart
=
Math
.
max
(
0
,
selection
.
startColumn
-
wordAtPosition
.
startColumn
);
selectionEnd
=
Math
.
min
(
wordAtPosition
.
endColumn
,
selection
.
endColumn
)
-
wordAtPosition
.
startColumn
;
}
wordRange
=
new
Range
(
lineNumber
,
wordAtPosition
.
startColumn
,
lineNumber
,
wordAtPosition
.
endColumn
);
}
this
.
_renameInputVisible
.
set
(
true
);
return
this
.
_renameInputField
.
getInput
(
wordRange
,
word
.
word
,
selectionStart
,
selectionEnd
).
then
(
newName
=>
{
return
this
.
_renameInputField
.
getInput
(
wordRange
,
word
,
selectionStart
,
selectionEnd
).
then
(
newName
=>
{
this
.
_renameInputVisible
.
reset
();
this
.
editor
.
focus
();
...
...
@@ -166,7 +209,7 @@ class RenameController implements IEditorContribution {
this
.
editor
.
setSelection
(
selection
);
}
// alert
alert
(
nls
.
localize
(
'
aria
'
,
"
Successfully renamed '{0}' to '{1}'. Summary: {2}
"
,
word
.
word
,
newName
,
edit
.
ariaMessage
()));
alert
(
nls
.
localize
(
'
aria
'
,
"
Successfully renamed '{0}' to '{1}'. Summary: {2}
"
,
word
,
newName
,
edit
.
ariaMessage
()));
});
},
err
=>
{
...
...
src/vs/monaco.d.ts
浏览文件 @
86b8fb26
...
...
@@ -4956,8 +4956,14 @@ declare module monaco.languages {
rejectReason
?:
string
;
}
export
interface
RenameInitialValue
{
range
:
IRange
;
text
?:
string
;
}
export
interface
RenameProvider
{
provideRenameEdits
(
model
:
editor
.
ITextModel
,
position
:
Position
,
newName
:
string
,
token
:
CancellationToken
):
WorkspaceEdit
|
Thenable
<
WorkspaceEdit
>
;
resolveInitialRenameValue
?(
model
:
editor
.
ITextModel
,
position
:
Position
,
token
:
CancellationToken
):
RenameInitialValue
|
Thenable
<
RenameInitialValue
>
;
}
export
interface
Command
{
...
...
src/vs/vscode.d.ts
浏览文件 @
86b8fb26
...
...
@@ -2664,6 +2664,11 @@ declare module 'vscode' {
appendVariable
(
name
:
string
,
defaultValue
:
string
|
((
snippet
:
SnippetString
)
=>
any
)):
SnippetString
;
}
export
interface
RenameInitialValue
{
range
:
Range
text
?:
string
}
/**
* The rename provider interface defines the contract between extensions and
* the [rename](https://code.visualstudio.com/docs/editor/editingevolved#_rename-symbol)-feature.
...
...
@@ -2682,6 +2687,8 @@ declare module 'vscode' {
* signaled by returning `undefined` or `null`.
*/
provideRenameEdits
(
document
:
TextDocument
,
position
:
Position
,
newName
:
string
,
token
:
CancellationToken
):
ProviderResult
<
WorkspaceEdit
>
;
resolveInitialRenameValue
?(
document
:
TextDocument
,
position
:
Position
,
token
:
CancellationToken
):
ProviderResult
<
RenameInitialValue
>
;
}
/**
...
...
src/vs/workbench/api/electron-browser/mainThreadLanguageFeatures.ts
浏览文件 @
86b8fb26
...
...
@@ -251,10 +251,14 @@ export class MainThreadLanguageFeatures implements MainThreadLanguageFeaturesSha
// --- rename
$registerRenameSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
):
void
{
$registerRenameSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
,
supportsResolveInitialValues
:
boolean
):
void
{
this
.
_registrations
[
handle
]
=
modes
.
RenameProviderRegistry
.
register
(
toLanguageSelector
(
selector
),
<
modes
.
RenameProvider
>
{
provideRenameEdits
:
(
model
:
ITextModel
,
position
:
EditorPosition
,
newName
:
string
,
token
:
CancellationToken
):
Thenable
<
modes
.
WorkspaceEdit
>
=>
{
return
wireCancellationToken
(
token
,
this
.
_proxy
.
$provideRenameEdits
(
handle
,
model
.
uri
,
position
,
newName
)).
then
(
reviveWorkspaceEditDto
);
},
resolveInitialRenameValue
:
supportsResolveInitialValues
?
(
model
:
ITextModel
,
position
:
EditorPosition
,
token
:
CancellationToken
):
Thenable
<
modes
.
RenameInitialValue
>
=>
wireCancellationToken
(
token
,
this
.
_proxy
.
$resolveInitialRenameValue
(
handle
,
model
.
uri
,
position
))
:
undefined
}
});
}
...
...
src/vs/workbench/api/node/extHost.protocol.ts
浏览文件 @
86b8fb26
...
...
@@ -277,7 +277,7 @@ export interface MainThreadLanguageFeaturesShape extends IDisposable {
$registerRangeFormattingSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
):
void
;
$registerOnTypeFormattingSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
,
autoFormatTriggerCharacters
:
string
[]):
void
;
$registerNavigateTypeSupport
(
handle
:
number
):
void
;
$registerRenameSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
):
void
;
$registerRenameSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
,
supportsResolveInitialValues
:
boolean
):
void
;
$registerSuggestSupport
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
,
triggerCharacters
:
string
[],
supportsResolveDetails
:
boolean
):
void
;
$registerSignatureHelpProvider
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
,
triggerCharacter
:
string
[]):
void
;
$registerDocumentLinkProvider
(
handle
:
number
,
selector
:
vscode
.
DocumentSelector
):
void
;
...
...
@@ -669,6 +669,7 @@ export interface ExtHostLanguageFeaturesShape {
$resolveWorkspaceSymbol
(
handle
:
number
,
symbol
:
SymbolInformationDto
):
TPromise
<
SymbolInformationDto
>
;
$releaseWorkspaceSymbols
(
handle
:
number
,
id
:
number
):
void
;
$provideRenameEdits
(
handle
:
number
,
resource
:
UriComponents
,
position
:
IPosition
,
newName
:
string
):
TPromise
<
WorkspaceEditDto
>
;
$resolveInitialRenameValue
(
handle
:
number
,
resource
:
UriComponents
,
position
:
IPosition
):
TPromise
<
modes
.
RenameInitialValue
>
;
$provideCompletionItems
(
handle
:
number
,
resource
:
UriComponents
,
position
:
IPosition
,
context
:
modes
.
SuggestContext
):
TPromise
<
SuggestResultDto
>
;
$resolveCompletionItem
(
handle
:
number
,
resource
:
UriComponents
,
position
:
IPosition
,
suggestion
:
modes
.
ISuggestion
):
TPromise
<
modes
.
ISuggestion
>
;
$releaseCompletionItems
(
handle
:
number
,
id
:
number
):
void
;
...
...
src/vs/workbench/api/node/extHostLanguageFeatures.ts
浏览文件 @
86b8fb26
...
...
@@ -470,6 +470,10 @@ class NavigateTypeAdapter {
class
RenameAdapter
{
static
supportsResolving
(
provider
:
vscode
.
RenameProvider
):
boolean
{
return
typeof
provider
.
resolveInitialRenameValue
===
'
function
'
;
}
private
_documents
:
ExtHostDocuments
;
private
_provider
:
vscode
.
RenameProvider
;
...
...
@@ -505,6 +509,22 @@ class RenameAdapter {
}
});
}
resolveInitialRenameValue
(
resource
:
URI
,
position
:
IPosition
)
:
TPromise
<
modes
.
RenameInitialValue
>
{
if
(
typeof
this
.
_provider
.
resolveInitialRenameValue
!==
'
function
'
)
{
return
TPromise
.
as
(
undefined
);
}
let
doc
=
this
.
_documents
.
getDocumentData
(
resource
).
document
;
let
pos
=
TypeConverters
.
toPosition
(
position
);
return
asWinJsPromise
(
token
=>
this
.
_provider
.
resolveInitialRenameValue
(
doc
,
pos
,
token
)).
then
((
value
)
=>
{
return
<
modes
.
RenameInitialValue
>
{
range
:
TypeConverters
.
fromRange
(
value
.
range
),
text
:
value
.
text
};
});
}
}
...
...
@@ -1010,7 +1030,7 @@ export class ExtHostLanguageFeatures implements ExtHostLanguageFeaturesShape {
registerRenameProvider
(
selector
:
vscode
.
DocumentSelector
,
provider
:
vscode
.
RenameProvider
):
vscode
.
Disposable
{
const
handle
=
this
.
_addNewAdapter
(
new
RenameAdapter
(
this
.
_documents
,
provider
));
this
.
_proxy
.
$registerRenameSupport
(
handle
,
selector
);
this
.
_proxy
.
$registerRenameSupport
(
handle
,
selector
,
RenameAdapter
.
supportsResolving
(
provider
)
);
return
this
.
_createDisposable
(
handle
);
}
...
...
@@ -1018,6 +1038,10 @@ export class ExtHostLanguageFeatures implements ExtHostLanguageFeaturesShape {
return
this
.
_withAdapter
(
handle
,
RenameAdapter
,
adapter
=>
adapter
.
provideRenameEdits
(
URI
.
revive
(
resource
),
position
,
newName
));
}
$resolveInitialRenameValue
(
handle
:
number
,
resource
:
URI
,
position
:
IPosition
):
TPromise
<
modes
.
RenameInitialValue
>
{
return
this
.
_withAdapter
(
handle
,
RenameAdapter
,
adapter
=>
adapter
.
resolveInitialRenameValue
(
resource
,
position
));
}
// --- suggestion
registerCompletionItemProvider
(
selector
:
vscode
.
DocumentSelector
,
provider
:
vscode
.
CompletionItemProvider
,
triggerCharacters
:
string
[]):
vscode
.
Disposable
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录