Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
98106c48
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,发现更多精彩内容 >>
提交
98106c48
编写于
12月 31, 2020
作者:
R
Rob Lourens
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
No need to create fake workspace folder for query builder
Fix #111348
上级
3283ade7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
23 addition
and
21 deletion
+23
-21
src/vs/workbench/api/browser/mainThreadWorkspace.ts
src/vs/workbench/api/browser/mainThreadWorkspace.ts
+12
-12
src/vs/workbench/contrib/search/common/queryBuilder.ts
src/vs/workbench/contrib/search/common/queryBuilder.ts
+11
-9
未找到文件。
src/vs/workbench/api/browser/mainThreadWorkspace.ts
浏览文件 @
98106c48
...
...
@@ -6,25 +6,25 @@
import
{
CancellationToken
,
CancellationTokenSource
}
from
'
vs/base/common/cancellation
'
;
import
{
isPromiseCanceledError
}
from
'
vs/base/common/errors
'
;
import
{
DisposableStore
}
from
'
vs/base/common/lifecycle
'
;
import
{
isNative
}
from
'
vs/base/common/platform
'
;
import
{
withNullAsUndefined
}
from
'
vs/base/common/types
'
;
import
{
URI
,
UriComponents
}
from
'
vs/base/common/uri
'
;
import
{
localize
}
from
'
vs/nls
'
;
import
{
isNative
}
from
'
vs/base/common/platform
'
;
import
{
IEnvironmentService
}
from
'
vs/platform/environment/common/environment
'
;
import
{
IFileService
}
from
'
vs/platform/files/common/files
'
;
import
{
IInstantiationService
}
from
'
vs/platform/instantiation/common/instantiation
'
;
import
{
ILabelService
}
from
'
vs/platform/label/common/label
'
;
import
{
IFileMatch
,
IPatternInfo
,
ISearchProgressItem
,
ISearchService
}
from
'
vs/workbench/services/search/common/search
'
;
import
{
IWorkspaceContextService
,
WorkbenchState
,
IWorkspace
,
toWorkspaceFolder
}
from
'
vs/platform/workspace/common/workspace
'
;
import
{
INotificationService
}
from
'
vs/platform/notification/common/notification
'
;
import
{
IRequestService
}
from
'
vs/platform/request/common/request
'
;
import
{
IWorkspace
,
IWorkspaceContextService
,
WorkbenchState
}
from
'
vs/platform/workspace/common/workspace
'
;
import
{
isUntitledWorkspace
}
from
'
vs/platform/workspaces/common/workspaces
'
;
import
{
extHostNamedCustomer
}
from
'
vs/workbench/api/common/extHostCustomers
'
;
import
{
checkGlobFileExists
}
from
'
vs/workbench/api/common/shared/workspaceContains
'
;
import
{
ITextQueryBuilderOptions
,
QueryBuilder
}
from
'
vs/workbench/contrib/search/common/queryBuilder
'
;
import
{
IEditorService
}
from
'
vs/workbench/services/editor/common/editorService
'
;
import
{
IFileMatch
,
IPatternInfo
,
ISearchProgressItem
,
ISearchService
}
from
'
vs/workbench/services/search/common/search
'
;
import
{
IWorkspaceEditingService
}
from
'
vs/workbench/services/workspaces/common/workspaceEditing
'
;
import
{
ExtHostContext
,
ExtHostWorkspaceShape
,
IExtHostContext
,
MainContext
,
MainThreadWorkspaceShape
,
IWorkspaceData
,
ITextSearchComplete
}
from
'
../common/extHost.protocol
'
;
import
{
IEnvironmentService
}
from
'
vs/platform/environment/common/environment
'
;
import
{
isUntitledWorkspace
}
from
'
vs/platform/workspaces/common/workspaces
'
;
import
{
INotificationService
}
from
'
vs/platform/notification/common/notification
'
;
import
{
withNullAsUndefined
}
from
'
vs/base/common/types
'
;
import
{
IFileService
}
from
'
vs/platform/files/common/files
'
;
import
{
IRequestService
}
from
'
vs/platform/request/common/request
'
;
import
{
checkGlobFileExists
}
from
'
vs/workbench/api/common/shared/workspaceContains
'
;
import
{
ExtHostContext
,
ExtHostWorkspaceShape
,
IExtHostContext
,
ITextSearchComplete
,
IWorkspaceData
,
MainContext
,
MainThreadWorkspaceShape
}
from
'
../common/extHost.protocol
'
;
@
extHostNamedCustomer
(
MainContext
.
MainThreadWorkspace
)
export
class
MainThreadWorkspace
implements
MainThreadWorkspaceShape
{
...
...
@@ -139,7 +139,7 @@ export class MainThreadWorkspace implements MainThreadWorkspaceShape {
}
const
query
=
this
.
_queryBuilder
.
file
(
includeFolder
?
[
toWorkspaceFolder
(
includeFolder
)
]
:
workspace
.
folders
,
includeFolder
?
[
includeFolder
]
:
workspace
.
folders
,
{
maxResults
:
withNullAsUndefined
(
maxResults
),
disregardExcludeSettings
:
(
excludePatternOrDisregardExcludes
===
false
)
||
undefined
,
...
...
src/vs/workbench/contrib/search/common/queryBuilder.ts
浏览文件 @
98106c48
...
...
@@ -9,9 +9,9 @@ import * as glob from 'vs/base/common/glob';
import
{
untildify
}
from
'
vs/base/common/labels
'
;
import
{
Schemas
}
from
'
vs/base/common/network
'
;
import
*
as
path
from
'
vs/base/common/path
'
;
import
{
isEqual
}
from
'
vs/base/common/resources
'
;
import
{
isEqual
,
basename
}
from
'
vs/base/common/resources
'
;
import
*
as
strings
from
'
vs/base/common/strings
'
;
import
{
URI
as
uri
}
from
'
vs/base/common/uri
'
;
import
{
URI
,
URI
as
uri
}
from
'
vs/base/common/uri
'
;
import
{
isMultilineRegexSource
}
from
'
vs/editor/common/model/textModelSearch
'
;
import
*
as
nls
from
'
vs/nls
'
;
import
{
IConfigurationService
}
from
'
vs/platform/configuration/common/configuration
'
;
...
...
@@ -134,7 +134,7 @@ export class QueryBuilder {
return
newPattern
;
}
file
(
folders
:
IWorkspaceFolderData
[],
options
:
IFileQueryBuilderOptions
=
{}):
IFileQuery
{
file
(
folders
:
(
IWorkspaceFolderData
|
URI
)
[],
options
:
IFileQueryBuilderOptions
=
{}):
IFileQuery
{
const
commonQuery
=
this
.
commonQuery
(
folders
,
options
);
return
<
IFileQuery
>
{
...
commonQuery
,
...
...
@@ -159,7 +159,7 @@ export class QueryBuilder {
{
pattern
:
patternListToIExpression
(...(
Array
.
isArray
(
pattern
)
?
pattern
:
[
pattern
]))
};
}
private
commonQuery
(
folderResources
:
IWorkspaceFolderData
[]
=
[],
options
:
ICommonQueryBuilderOptions
=
{}):
ICommonQueryProps
<
uri
>
{
private
commonQuery
(
folderResources
:
(
IWorkspaceFolderData
|
URI
)
[]
=
[],
options
:
ICommonQueryBuilderOptions
=
{}):
ICommonQueryProps
<
uri
>
{
const
includeSearchPathsInfo
:
ISearchPathsInfo
=
this
.
handleIncludeExclude
(
options
.
includePattern
,
options
.
expandPatterns
);
const
excludeSearchPathsInfo
:
ISearchPathsInfo
=
this
.
handleIncludeExclude
(
options
.
excludePattern
,
options
.
expandPatterns
);
...
...
@@ -423,10 +423,11 @@ export class QueryBuilder {
};
}
private
getFolderQueryForRoot
(
folder
:
IWorkspaceFolderData
,
options
:
ICommonQueryBuilderOptions
,
searchPathExcludes
:
ISearchPathsInfo
,
includeFolderName
:
boolean
):
IFolderQuery
|
null
{
private
getFolderQueryForRoot
(
folder
:
(
IWorkspaceFolderData
|
URI
)
,
options
:
ICommonQueryBuilderOptions
,
searchPathExcludes
:
ISearchPathsInfo
,
includeFolderName
:
boolean
):
IFolderQuery
|
null
{
let
thisFolderExcludeSearchPathPattern
:
glob
.
IExpression
|
undefined
;
const
folderUri
=
URI
.
isUri
(
folder
)
?
folder
:
folder
.
uri
;
if
(
searchPathExcludes
.
searchPaths
)
{
const
thisFolderExcludeSearchPath
=
searchPathExcludes
.
searchPaths
.
filter
(
sp
=>
isEqual
(
sp
.
searchPath
,
folder
.
u
ri
))[
0
];
const
thisFolderExcludeSearchPath
=
searchPathExcludes
.
searchPaths
.
filter
(
sp
=>
isEqual
(
sp
.
searchPath
,
folder
U
ri
))[
0
];
if
(
thisFolderExcludeSearchPath
&&
!
thisFolderExcludeSearchPath
.
pattern
)
{
// entire folder is excluded
return
null
;
...
...
@@ -435,16 +436,17 @@ export class QueryBuilder {
}
}
const
folderConfig
=
this
.
configurationService
.
getValue
<
ISearchConfiguration
>
({
resource
:
folder
.
u
ri
});
const
folderConfig
=
this
.
configurationService
.
getValue
<
ISearchConfiguration
>
({
resource
:
folder
U
ri
});
const
settingExcludes
=
this
.
getExcludesForFolder
(
folderConfig
,
options
);
const
excludePattern
:
glob
.
IExpression
=
{
...(
settingExcludes
||
{}),
...(
thisFolderExcludeSearchPathPattern
||
{})
};
const
folderName
=
URI
.
isUri
(
folder
)
?
basename
(
folder
)
:
folder
.
name
;
return
<
IFolderQuery
>
{
folder
:
folder
.
u
ri
,
folderName
:
includeFolderName
?
folder
.
n
ame
:
undefined
,
folder
:
folder
U
ri
,
folderName
:
includeFolderName
?
folder
N
ame
:
undefined
,
excludePattern
:
Object
.
keys
(
excludePattern
).
length
>
0
?
excludePattern
:
undefined
,
fileEncoding
:
folderConfig
.
files
&&
folderConfig
.
files
.
encoding
,
disregardIgnoreFiles
:
typeof
options
.
disregardIgnoreFiles
===
'
boolean
'
?
options
.
disregardIgnoreFiles
:
!
folderConfig
.
search
.
useIgnoreFiles
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录