forked from dotnet/sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ReferenceInfo.cs
164 lines (135 loc) · 6.3 KB
/
ReferenceInfo.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
// Copyright (c) .NET Foundation and contributors. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using Microsoft.Build.Framework;
namespace Microsoft.NET.Build.Tasks
{
internal class ReferenceInfo
{
public string Name { get; }
public string Version { get; }
public string FullPath { get; }
public string FileName => Path.GetFileName(FullPath);
public string PackageName { get; }
public string PackageVersion { get; }
public string PathInPackage { get; }
private List<ResourceAssemblyInfo> _resourceAssemblies;
public IEnumerable<ResourceAssemblyInfo> ResourceAssemblies
{
get { return _resourceAssemblies; }
}
private ReferenceInfo(string name, string version, string fullPath,
string packageName, string packageVersion, string pathInPackage)
{
Name = name;
Version = version;
FullPath = fullPath;
PackageName = packageName;
PackageVersion = packageVersion;
PathInPackage = pathInPackage;
_resourceAssemblies = new List<ResourceAssemblyInfo>();
}
public static IEnumerable<ReferenceInfo> CreateReferenceInfos(IEnumerable<ITaskItem> referencePaths)
{
List<ReferenceInfo> referenceInfos = new List<ReferenceInfo>();
foreach (ITaskItem referencePath in referencePaths)
{
referenceInfos.Add(CreateReferenceInfo(referencePath));
}
return referenceInfos;
}
public static IEnumerable<ReferenceInfo> CreateDirectReferenceInfos(
IEnumerable<ITaskItem> referencePaths,
IEnumerable<ITaskItem> referenceSatellitePaths,
bool projectContextHasProjectReferences,
Func<ITaskItem, bool> isRuntimeAssembly)
{
bool filterOutProjectReferenceIfInProjectContextAlready(ITaskItem referencePath)
{
return (projectContextHasProjectReferences ? !IsProjectReference(referencePath) : true);
}
IEnumerable<ITaskItem> directReferencePaths = referencePaths
.Where(r => filterOutProjectReferenceIfInProjectContextAlready(r) && !IsNuGetReference(r) && isRuntimeAssembly(r));
return CreateFilteredReferenceInfos(directReferencePaths, referenceSatellitePaths);
}
private static bool IsNuGetReference(ITaskItem reference)
{
return reference.HasMetadataValue("NuGetSourceType")
&& !reference.HasMetadataValue("NuGetIsFrameworkReference", "true");
}
public static bool IsProjectReference(ITaskItem reference)
{
return reference.HasMetadataValue(MetadataKeys.ReferenceSourceTarget, "ProjectReference");
}
public static IEnumerable<ReferenceInfo> CreateDependencyReferenceInfos(
IEnumerable<ITaskItem> referenceDependencyPaths,
IEnumerable<ITaskItem> referenceSatellitePaths,
Func<ITaskItem, bool> isRuntimeAssembly)
{
IEnumerable<ITaskItem> indirectReferencePaths = referenceDependencyPaths
.Where(r => !IsNuGetReference(r) && isRuntimeAssembly(r));
return CreateFilteredReferenceInfos(indirectReferencePaths, referenceSatellitePaths);
}
private static IEnumerable<ReferenceInfo> CreateFilteredReferenceInfos(
IEnumerable<ITaskItem> referencePaths,
IEnumerable<ITaskItem> referenceSatellitePaths)
{
Dictionary<string, ReferenceInfo> directReferences = new Dictionary<string, ReferenceInfo>();
foreach (ITaskItem referencePath in referencePaths)
{
ReferenceInfo referenceInfo = CreateReferenceInfo(referencePath);
directReferences.Add(referenceInfo.FullPath, referenceInfo);
}
foreach (ITaskItem referenceSatellitePath in referenceSatellitePaths)
{
string originalItemSpec = referenceSatellitePath.GetMetadata("OriginalItemSpec");
if (!string.IsNullOrEmpty(originalItemSpec))
{
ReferenceInfo referenceInfo;
if (directReferences.TryGetValue(originalItemSpec, out referenceInfo))
{
ResourceAssemblyInfo resourceAssemblyInfo =
ResourceAssemblyInfo.CreateFromReferenceSatellitePath(referenceSatellitePath);
referenceInfo._resourceAssemblies.Add(resourceAssemblyInfo);
}
}
}
return directReferences.Values;
}
internal static ReferenceInfo CreateReferenceInfo(ITaskItem referencePath)
{
string fullPath = referencePath.ItemSpec;
string name = Path.GetFileNameWithoutExtension(fullPath);
string version = GetVersion(referencePath);
var packageName = referencePath.GetMetadata(MetadataKeys.NuGetPackageId);
var packageVersion = referencePath.GetMetadata(MetadataKeys.NuGetPackageVersion);
var pathInPackage = referencePath.GetMetadata(MetadataKeys.PathInPackage);
return new ReferenceInfo(name, version, fullPath,
packageName, packageVersion, pathInPackage);
}
private static string GetVersion(ITaskItem referencePath)
{
string version = referencePath.GetMetadata("Version");
if (string.IsNullOrEmpty(version))
{
string fusionName = referencePath.GetMetadata("FusionName");
if (!string.IsNullOrEmpty(fusionName))
{
AssemblyName assemblyName = new AssemblyName(fusionName);
version = assemblyName.Version.ToString();
}
if (string.IsNullOrEmpty(version))
{
// Use 0.0.0.0 as placeholder, if we can't find a version any
// other way
version = "0.0.0.0";
}
}
return version;
}
}
}