Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
7d790610
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,发现更多精彩内容 >>
提交
7d790610
编写于
11月 30, 2016
作者:
S
Sandeep Somavarapu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Apply Fuzzy filter on settings descriptions
Telemetry reporting
上级
4eff0976
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
60 addition
and
16 deletion
+60
-16
src/vs/workbench/parts/preferences/browser/preferencesEditor.ts
.../workbench/parts/preferences/browser/preferencesEditor.ts
+11
-0
src/vs/workbench/parts/preferences/common/preferences.ts
src/vs/workbench/parts/preferences/common/preferences.ts
+1
-0
src/vs/workbench/parts/preferences/common/preferencesModels.ts
...s/workbench/parts/preferences/common/preferencesModels.ts
+48
-16
未找到文件。
src/vs/workbench/parts/preferences/browser/preferencesEditor.ts
浏览文件 @
7d790610
...
...
@@ -7,6 +7,7 @@ import { TPromise } from 'vs/base/common/winjs.base';
import
*
as
nls
from
'
vs/nls
'
;
import
URI
from
'
vs/base/common/uri
'
;
import
*
as
DOM
from
'
vs/base/browser/dom
'
;
import
{
Delayer
}
from
'
vs/base/common/async
'
;
import
{
Dimension
,
Builder
}
from
'
vs/base/browser/builder
'
;
import
{
Disposable
,
IDisposable
,
dispose
}
from
'
vs/base/common/lifecycle
'
;
import
{
flatten
}
from
'
vs/base/common/arrays
'
;
...
...
@@ -106,6 +107,8 @@ export class PreferencesEditor extends BaseEditor {
private
isFocussed
=
false
;
private
toDispose
:
IDisposable
[]
=
[];
private
delayedFilterLogging
:
Delayer
<
void
>
;
constructor
(
@
ITelemetryService
telemetryService
:
ITelemetryService
,
@
IThemeService
private
themeService
:
IThemeService
,
...
...
@@ -115,6 +118,7 @@ export class PreferencesEditor extends BaseEditor {
@
IModeService
private
modeService
:
IModeService
)
{
super
(
PreferencesEditor
.
ID
,
telemetryService
);
this
.
delayedFilterLogging
=
new
Delayer
<
void
>
(
1000
);
}
public
createEditor
(
parent
:
Builder
)
{
...
...
@@ -204,6 +208,7 @@ export class PreferencesEditor extends BaseEditor {
}
private
filterPreferences
(
filter
:
string
)
{
this
.
delayedFilterLogging
.
trigger
(()
=>
this
.
reportFilteringUsed
(
filter
));
(
<
DefaultSettingsRenderer
>
this
.
getDefaultPreferencesContribution
().
getPreferencesRenderer
()).
filterPreferences
(
filter
);
}
...
...
@@ -259,6 +264,12 @@ export class PreferencesEditor extends BaseEditor {
model
.
dispose
();
}
}
private
reportFilteringUsed
(
filter
:
string
):
void
{
let
data
=
{};
data
[
'
filter
'
]
=
filter
;
this
.
telemetryService
.
publicLog
(
'
defaultSettings.filter
'
,
data
);
}
}
class
DefaultPreferencesEditor
extends
CodeEditor
{
...
...
src/vs/workbench/parts/preferences/common/preferences.ts
浏览文件 @
7d790610
...
...
@@ -32,6 +32,7 @@ export interface ISetting {
value
:
any
;
valueRange
:
IRange
;
description
:
string
;
descriptionRange
:
IRange
;
}
export
interface
IFilterResult
{
...
...
src/vs/workbench/parts/preferences/common/preferencesModels.ts
浏览文件 @
7d790610
...
...
@@ -17,9 +17,12 @@ import { ISettingsEditorModel, IKeybindingsEditorModel, ISettingsGroup, ISetting
import
{
IWorkspaceConfigurationService
}
from
'
vs/workbench/services/configuration/common/configuration
'
;
import
{
IKeybindingService
}
from
'
vs/platform/keybinding/common/keybinding
'
;
import
{
ConfigurationTarget
}
from
'
vs/workbench/services/configuration/common/configurationEditing
'
;
import
{
IFilter
,
IMatch
,
or
,
matchesContiguousSubString
,
matchesPrefix
,
matchesFuzzy
,
matchesWords
}
from
'
vs/base/common/filters
'
;
export
abstract
class
AbstractSettingsModel
extends
Disposable
{
static
_fuzzyFilter
:
IFilter
=
or
(
matchesPrefix
,
matchesContiguousSubString
,
matchesWords
,
matchesFuzzy
);
public
get
groupsTerms
():
string
[]
{
return
this
.
settingsGroups
.
map
(
group
=>
'
@
'
+
group
.
id
);
}
...
...
@@ -51,7 +54,7 @@ export abstract class AbstractSettingsModel extends Disposable {
for
(
const
section
of
group
.
sections
)
{
const
settings
:
ISetting
[]
=
[];
for
(
const
setting
of
section
.
settings
)
{
const
settingMatches
=
this
.
_findMatchesInSetting
(
regex
,
setting
);
const
settingMatches
=
this
.
_findMatchesInSetting
(
filter
,
regex
,
setting
);
if
(
groupMatched
||
settingMatches
.
length
>
0
)
{
settings
.
push
(
setting
);
}
...
...
@@ -86,15 +89,7 @@ export abstract class AbstractSettingsModel extends Disposable {
return
null
;
}
private
_findMatchesInSetting
(
searchRegex
:
RegExp
,
setting
:
ISetting
):
IRange
[]
{
const
result
:
IRange
[]
=
[];
for
(
let
lineNumber
=
setting
.
range
.
startLineNumber
;
lineNumber
<=
setting
.
range
.
endLineNumber
;
lineNumber
++
)
{
result
.
push
(...
this
.
_findMatchesInLine
(
searchRegex
,
lineNumber
));
}
return
result
;
}
protected
abstract
_findMatchesInLine
(
searchRegex
:
RegExp
,
lineNumber
:
number
):
IRange
[];
protected
abstract
_findMatchesInSetting
(
searchString
:
string
,
searchRegex
:
RegExp
,
setting
:
ISetting
):
IRange
[];
public
abstract
settingsGroups
:
ISettingsGroup
[];
}
...
...
@@ -192,7 +187,8 @@ export class SettingsEditorModel extends AbstractSettingsModel implements ISetti
},
value
:
null
,
keyRange
:
null
,
valueRange
:
null
valueRange
:
null
,
descriptionRange
:
null
,
});
}
},
...
...
@@ -258,10 +254,18 @@ export class SettingsEditorModel extends AbstractSettingsModel implements ISetti
}]
:
[];
}
protected
_findMatchesInLine
(
searchRegex
:
RegExp
,
lineNumber
:
number
):
IRange
[]
{
return
this
.
model
.
findMatches
(
searchRegex
.
source
,
{
protected
_findMatchesInSetting
(
searchString
:
string
,
searchRegex
:
RegExp
,
setting
:
ISetting
):
IRange
[]
{
const
result
:
IRange
[]
=
[];
for
(
let
lineNumber
=
setting
.
range
.
startLineNumber
;
lineNumber
<=
setting
.
range
.
endLineNumber
;
lineNumber
++
)
{
result
.
push
(...
this
.
_findMatchesInLine
(
searchString
,
lineNumber
));
}
return
result
;
}
private
_findMatchesInLine
(
searchString
:
string
,
lineNumber
:
number
):
IRange
[]
{
return
this
.
model
.
findMatches
(
searchString
,
{
startLineNumber
:
lineNumber
,
startColumn
:
this
.
model
.
getLineMinColumn
(
lineNumber
),
endLineNumber
:
lineNumber
,
endColumn
:
this
.
model
.
getLineMaxColumn
(
lineNumber
),
},
false
,
!
searchRegex
.
ignoreCa
se
,
false
);
},
false
,
fal
se
,
false
);
}
}
...
...
@@ -383,7 +387,7 @@ export class DefaultSettingsEditorModel extends AbstractSettingsModel implements
const
prop
=
config
.
properties
[
key
];
const
value
=
prop
.
default
;
const
description
=
prop
.
description
||
''
;
return
{
key
,
value
,
description
,
range
:
null
,
keyRange
:
null
,
valueRange
:
null
};
return
{
key
,
value
,
description
,
range
:
null
,
keyRange
:
null
,
valueRange
:
null
,
descriptionRange
:
null
};
});
settingsGroup
.
sections
[
settingsGroup
.
sections
.
length
-
1
].
settings
.
push
(...
configurationSettings
);
}
...
...
@@ -429,6 +433,7 @@ export class DefaultSettingsEditorModel extends AbstractSettingsModel implements
for
(
const
setting
of
section
.
settings
)
{
const
settingStart
=
this
.
_contentByLines
.
length
+
1
;
this
.
addDescription
(
setting
.
description
,
this
.
indent
,
this
.
_contentByLines
);
setting
.
descriptionRange
=
{
startLineNumber
:
settingStart
,
startColumn
:
1
,
endLineNumber
:
this
.
_contentByLines
.
length
,
endColumn
:
this
.
_contentByLines
[
this
.
_contentByLines
.
length
-
1
].
length
};
let
preValueConent
=
this
.
indent
;
const
keyString
=
JSON
.
stringify
(
setting
.
key
);
...
...
@@ -473,7 +478,34 @@ export class DefaultSettingsEditorModel extends AbstractSettingsModel implements
}
}
protected
_findMatchesInLine
(
searchRegex
:
RegExp
,
lineNumber
:
number
):
IRange
[]
{
protected
_findMatchesInSetting
(
searchString
:
string
,
searchRegex
:
RegExp
,
setting
:
ISetting
):
IRange
[]
{
const
result
:
IRange
[]
=
[...
this
.
_findMatchesInDescription
(
searchString
,
setting
)];
for
(
let
lineNumber
=
setting
.
valueRange
.
startLineNumber
;
lineNumber
<=
setting
.
valueRange
.
endLineNumber
;
lineNumber
++
)
{
result
.
push
(...
this
.
_findMatchesInLine
(
searchRegex
,
lineNumber
));
}
return
result
;
}
private
_findMatchesInDescription
(
searchString
:
string
,
setting
:
ISetting
):
IRange
[]
{
const
result
:
IRange
[]
=
[];
for
(
let
lineNumber
=
setting
.
descriptionRange
.
startLineNumber
;
lineNumber
<=
setting
.
descriptionRange
.
endLineNumber
;
lineNumber
++
)
{
const
content
=
this
.
_contentByLines
[
lineNumber
-
1
];
const
matches
:
IMatch
[]
=
AbstractSettingsModel
.
_fuzzyFilter
(
searchString
,
content
);
if
(
matches
)
{
result
.
push
(...
matches
.
map
(
match
=>
{
return
<
IRange
>
{
startLineNumber
:
lineNumber
,
startColumn
:
match
.
start
+
1
,
endLineNumber
:
lineNumber
,
endColumn
:
match
.
end
+
1
};
}));
}
}
return
result
;
}
private
_findMatchesInLine
(
searchRegex
:
RegExp
,
lineNumber
:
number
):
IRange
[]
{
const
result
:
IRange
[]
=
[];
const
text
=
this
.
_contentByLines
[
lineNumber
-
1
];
var
m
:
RegExpExecArray
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录