Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
cd6e490c
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,发现更多精彩内容 >>
提交
cd6e490c
编写于
1月 07, 2020
作者:
S
Sam Harwell
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Report allocated bytes for AnalyzerRunner
上级
732751bb
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
57 addition
and
5 deletion
+57
-5
src/Tools/AnalyzerRunner/CodeRefactoringRunner.cs
src/Tools/AnalyzerRunner/CodeRefactoringRunner.cs
+1
-1
src/Tools/AnalyzerRunner/DiagnosticAnalyzerRunner.cs
src/Tools/AnalyzerRunner/DiagnosticAnalyzerRunner.cs
+2
-2
src/Tools/AnalyzerRunner/PerformanceTracker.cs
src/Tools/AnalyzerRunner/PerformanceTracker.cs
+48
-0
src/Tools/AnalyzerRunner/Program.cs
src/Tools/AnalyzerRunner/Program.cs
+6
-2
未找到文件。
src/Tools/AnalyzerRunner/CodeRefactoringRunner.cs
浏览文件 @
cd6e490c
...
...
@@ -51,7 +51,7 @@ public async Task RunAsync(Workspace workspace, CancellationToken cancellationTo
}
var
solution
=
workspace
.
CurrentSolution
;
var
stopwatch
=
Stopwatch
.
StartNew
();
var
stopwatch
=
PerformanceTracker
.
StartNew
();
var
updatedSolution
=
solution
;
...
...
src/Tools/AnalyzerRunner/DiagnosticAnalyzerRunner.cs
浏览文件 @
cd6e490c
...
...
@@ -45,12 +45,12 @@ public async Task RunAsync(Workspace workspace, CancellationToken cancellationTo
}
var
solution
=
workspace
.
CurrentSolution
;
var
stopwatch
=
Stopwatch
.
StartNew
();
var
stopwatch
=
PerformanceTracker
.
StartNew
();
var
analysisResult
=
await
GetAnalysisResultAsync
(
solution
,
_analyzers
,
_options
,
cancellationToken
).
ConfigureAwait
(
false
);
var
allDiagnostics
=
analysisResult
.
Where
(
pair
=>
pair
.
Value
!=
null
).
SelectMany
(
pair
=>
pair
.
Value
.
GetAllDiagnostics
()).
ToImmutableArray
();
Console
.
WriteLine
(
$"Found
{
allDiagnostics
.
Length
}
diagnostics in
{
stopwatch
.
ElapsedMilliseconds
}
ms
"
);
Console
.
WriteLine
(
$"Found
{
allDiagnostics
.
Length
}
diagnostics in
{
stopwatch
.
GetSummary
(
preciseMemory
:
true
)}
"
);
WriteTelemetry
(
analysisResult
);
if
(
_options
.
TestDocuments
)
...
...
src/Tools/AnalyzerRunner/PerformanceTracker.cs
0 → 100644
浏览文件 @
cd6e490c
// Copyright (c) Microsoft. All Rights Reserved. Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
using
System
;
using
System.Diagnostics
;
namespace
AnalyzerRunner
{
internal
sealed
class
PerformanceTracker
{
private
readonly
Stopwatch
_stopwatch
;
#if NETCOREAPP
private
readonly
long
_initialTotalAllocatedBytes
;
#endif
public
PerformanceTracker
(
Stopwatch
stopwatch
,
long
initialTotalAllocatedBytes
)
{
#if NETCOREAPP
_initialTotalAllocatedBytes
=
initialTotalAllocatedBytes
;
#endif
_stopwatch
=
stopwatch
;
}
public
static
PerformanceTracker
StartNew
(
bool
preciseMemory
=
true
)
{
#if NETCOREAPP
var
initialTotalAllocatedBytes
=
GC
.
GetTotalAllocatedBytes
(
preciseMemory
);
#else
var
initialTotalAllocatedBytes
=
0L
;
#endif
return
new
PerformanceTracker
(
Stopwatch
.
StartNew
(),
initialTotalAllocatedBytes
);
}
public
TimeSpan
Elapsed
=>
_stopwatch
.
Elapsed
;
public
string
GetSummary
(
bool
preciseMemory
=
true
)
{
#if NETCOREAPP
var
elapsedTime
=
Elapsed
;
var
allocatedBytes
=
GC
.
GetTotalAllocatedBytes
(
preciseMemory
)
-
_initialTotalAllocatedBytes
;
return
$"
{
elapsedTime
.
TotalMilliseconds
:
0
}
ms (
{
allocatedBytes
}
bytes allocated)"
;
#else
return
$"
{
Elapsed
.
TotalMilliseconds
:
0
}
ms"
;
#endif
}
}
}
src/Tools/AnalyzerRunner/Program.cs
浏览文件 @
cd6e490c
...
...
@@ -77,7 +77,7 @@ public static async Task Main(string[] args)
ProfileOptimization
.
SetProfileRoot
(
options
.
ProfileRoot
);
}
Stopwatch
stopwatch
=
Stopwatch
.
StartNew
();
var
stopwatch
=
PerformanceTracker
.
StartNew
();
var
properties
=
new
Dictionary
<
string
,
string
>
{
#if NETCOREAPP
...
...
@@ -105,10 +105,12 @@ public static async Task Main(string[] args)
solution
=
solution
.
WithProjectAnalyzerReferences
(
projectId
,
ImmutableArray
<
AnalyzerReference
>.
Empty
);
}
Console
.
WriteLine
(
$"Loaded solution in
{
stopwatch
.
ElapsedMilliseconds
}
ms
"
);
Console
.
WriteLine
(
$"Loaded solution in
{
stopwatch
.
GetSummary
(
preciseMemory
:
true
)}
"
);
if
(
options
.
ShowStats
)
{
stopwatch
=
PerformanceTracker
.
StartNew
();
List
<
Project
>
projects
=
solution
.
Projects
.
Where
(
project
=>
project
.
Language
==
LanguageNames
.
CSharp
||
project
.
Language
==
LanguageNames
.
VisualBasic
).
ToList
();
Console
.
WriteLine
(
"Number of projects:\t\t"
+
projects
.
Count
);
...
...
@@ -119,6 +121,8 @@ public static async Task Main(string[] args)
Console
.
WriteLine
(
"Number of syntax nodes:\t\t"
+
statistics
.
NumberofNodes
);
Console
.
WriteLine
(
"Number of syntax tokens:\t"
+
statistics
.
NumberOfTokens
);
Console
.
WriteLine
(
"Number of syntax trivia:\t"
+
statistics
.
NumberOfTrivia
);
Console
.
WriteLine
(
$"Statistics gathered in
{
stopwatch
.
GetSummary
(
preciseMemory
:
true
)}
"
);
}
if
(
options
.
ShowCompilerDiagnostics
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录