Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
d0d4b593
R
roslyn
项目概览
lwm1986
/
roslyn
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
roslyn
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d0d4b593
编写于
9月 02, 2015
作者:
R
Ravi Chande
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #4547 from rchande/asyncclassviewrefresh
Asynchronously determine whether to refresh class view
上级
6e5e9dbc
e91954ec
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
41 addition
and
14 deletion
+41
-14
src/VisualStudio/Core/Def/Implementation/Library/ObjectBrowser/AbstractObjectBrowserLibraryManager.cs
...rary/ObjectBrowser/AbstractObjectBrowserLibraryManager.cs
+41
-14
未找到文件。
src/VisualStudio/Core/Def/Implementation/Library/ObjectBrowser/AbstractObjectBrowserLibraryManager.cs
浏览文件 @
d0d4b593
...
...
@@ -4,6 +4,7 @@
using
System.Diagnostics
;
using
System.Text
;
using
System.Threading
;
using
System.Threading.Tasks
;
using
Microsoft.CodeAnalysis
;
using
Microsoft.VisualStudio.ComponentModelHost
;
using
Microsoft.VisualStudio.LanguageServices.Implementation.Library.ObjectBrowser.Lists
;
...
...
@@ -13,6 +14,7 @@
using
Microsoft.VisualStudio.Shell.Interop
;
using
Roslyn.Utilities
;
using
IServiceProvider
=
System
.
IServiceProvider
;
using
Task
=
System
.
Threading
.
Tasks
.
Task
;
namespace
Microsoft.VisualStudio.LanguageServices.Implementation.Library.ObjectBrowser
{
...
...
@@ -28,6 +30,7 @@ internal abstract partial class AbstractObjectBrowserLibraryManager : AbstractLi
private
ObjectListItem
_activeListItem
;
private
AbstractListItemFactory
_listItemFactory
;
private
object
classMemberGate
=
new
object
();
protected
AbstractObjectBrowserLibraryManager
(
string
languageName
,
Guid
libraryGuid
,
IServiceProvider
serviceProvider
)
:
base
(
libraryGuid
,
serviceProvider
)
...
...
@@ -63,7 +66,7 @@ public void Dispose()
this
.
Workspace
.
WorkspaceChanged
-=
OnWorkspaceChanged
;
}
private
void
OnWorkspaceChanged
(
object
sender
,
WorkspaceChangeEventArgs
e
)
private
async
void
OnWorkspaceChanged
(
object
sender
,
WorkspaceChangeEventArgs
e
)
{
switch
(
e
.
Kind
)
{
...
...
@@ -73,15 +76,7 @@ private void OnWorkspaceChanged(object sender, WorkspaceChangeEventArgs e)
var
oldDocument
=
e
.
OldSolution
.
GetDocument
(
e
.
DocumentId
);
var
newDocument
=
e
.
NewSolution
.
GetDocument
(
e
.
DocumentId
);
var
oldTextVersion
=
oldDocument
.
GetTextVersionAsync
(
CancellationToken
.
None
).
WaitAndGetResult
(
CancellationToken
.
None
);
var
newTextVersion
=
newDocument
.
GetTextVersionAsync
(
CancellationToken
.
None
).
WaitAndGetResult
(
CancellationToken
.
None
);
if
(
oldTextVersion
!=
newTextVersion
)
{
UpdateClassVersion
();
UpdateMembersVersion
();
}
await
DocumentChangedAsync
(
oldDocument
,
newDocument
).
ConfigureAwait
(
false
);
break
;
case
WorkspaceChangeKind
.
ProjectAdded
:
...
...
@@ -101,14 +96,37 @@ private void OnWorkspaceChanged(object sender, WorkspaceChangeEventArgs e)
}
}
private
async
Task
DocumentChangedAsync
(
Document
oldDocument
,
Document
newDocument
)
{
var
oldTextVersion
=
await
oldDocument
.
GetTextVersionAsync
(
CancellationToken
.
None
).
ConfigureAwait
(
false
);
var
newTextVersion
=
await
newDocument
.
GetTextVersionAsync
(
CancellationToken
.
None
).
ConfigureAwait
(
false
);
if
(
oldTextVersion
!=
newTextVersion
)
{
UpdateClassAndMemberVersions
();
}
}
internal
uint
ClassVersion
{
get
{
return
_classVersion
;
}
get
{
lock
(
classMemberGate
)
{
return
_classVersion
;
}
}
}
internal
uint
MembersVersion
{
get
{
return
_membersVersion
;
}
get
{
lock
(
classMemberGate
)
{
return
_membersVersion
;
}
}
}
internal
uint
PackageVersion
...
...
@@ -116,12 +134,21 @@ internal uint PackageVersion
get
{
return
_packageVersion
;
}
}
internal
void
UpdateClassVersion
()
internal
void
UpdateClassAndMemberVersions
()
{
lock
(
classMemberGate
)
{
UpdateClassVersion
();
UpdateMembersVersion
();
}
}
private
void
UpdateClassVersion
()
{
_classVersion
=
unchecked
(
_classVersion
+
1
);
}
internal
void
UpdateMembersVersion
()
private
void
UpdateMembersVersion
()
{
_membersVersion
=
unchecked
(
_membersVersion
+
1
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录