summaryrefslogtreecommitdiff
path: root/src/ext/NetFx/wixext
diff options
context:
space:
mode:
Diffstat (limited to 'src/ext/NetFx/wixext')
-rw-r--r--src/ext/NetFx/wixext/NetFxCompiler.cs166
-rw-r--r--src/ext/NetFx/wixext/NetFxExtensionData.cs3
-rw-r--r--src/ext/NetFx/wixext/Symbols/NetFxNativeImageSymbol.cs23
-rw-r--r--src/ext/NetFx/wixext/Symbols/NetFxNetCoreSearchSymbol.cs77
-rw-r--r--src/ext/NetFx/wixext/Symbols/NetfxSymbolDefinitions.cs49
5 files changed, 301 insertions, 17 deletions
diff --git a/src/ext/NetFx/wixext/NetFxCompiler.cs b/src/ext/NetFx/wixext/NetFxCompiler.cs
index 90aa8bcb..739618e9 100644
--- a/src/ext/NetFx/wixext/NetFxCompiler.cs
+++ b/src/ext/NetFx/wixext/NetFxCompiler.cs
@@ -40,12 +40,178 @@ namespace WixToolset.Netfx
40 break; 40 break;
41 } 41 }
42 break; 42 break;
43 case "Bundle":
44 case "Fragment":
45 switch (element.Name.LocalName)
46 {
47 case "DotNetCoreSearch":
48 this.ParseDotNetCoreSearchElement(intermediate, section, element);
49 break;
50 case "DotNetCoreSearchRef":
51 this.ParseDotNetCoreSearchRefElement(intermediate, section, element);
52 break;
53 }
54
55 break;
43 default: 56 default:
44 this.ParseHelper.UnexpectedElement(parentElement, element); 57 this.ParseHelper.UnexpectedElement(parentElement, element);
45 break; 58 break;
46 } 59 }
47 } 60 }
48 61
62 private void ParseDotNetCoreSearchElement(Intermediate intermediate, IntermediateSection section, XElement element)
63 {
64 var sourceLineNumbers = this.ParseHelper.GetSourceLineNumbers(element);
65 Identifier id = null;
66 string variable = null;
67 string condition = null;
68 string after = null;
69 NetCoreSearchRuntimeType? runtimeType = null;
70 NetCoreSearchPlatform? platform = null;
71 var majorVersion = CompilerConstants.IntegerNotSet;
72
73 foreach (var attrib in element.Attributes())
74 {
75 if (String.IsNullOrEmpty(attrib.Name.NamespaceName) || this.Namespace == attrib.Name.Namespace)
76 {
77 switch (attrib.Name.LocalName)
78 {
79 case "Id":
80 id = this.ParseHelper.GetAttributeIdentifier(sourceLineNumbers, attrib);
81 break;
82 case "Variable":
83 variable = this.ParseHelper.GetAttributeBundleVariableNameValue(sourceLineNumbers, attrib);
84 break;
85 case "Condition":
86 condition = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib);
87 break;
88 case "After":
89 after = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib);
90 break;
91 case "RuntimeType":
92 var runtimeTypeValue = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib);
93 switch (runtimeTypeValue)
94 {
95 case "aspnet":
96 runtimeType = NetCoreSearchRuntimeType.Aspnet;
97 break;
98 case "core":
99 runtimeType = NetCoreSearchRuntimeType.Core;
100 break;
101 case "desktop":
102 runtimeType = NetCoreSearchRuntimeType.Desktop;
103 break;
104 default:
105 this.Messaging.Write(ErrorMessages.IllegalAttributeValue(sourceLineNumbers, element.Name.LocalName, "RuntimeType", runtimeTypeValue, "aspnet", "core", "desktop"));
106 break;
107 }
108 break;
109 case "Platform":
110 var platformValue = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib);
111 switch (platformValue)
112 {
113 case "arm64":
114 platform = NetCoreSearchPlatform.Arm64;
115 break;
116 case "x64":
117 platform = NetCoreSearchPlatform.X64;
118 break;
119 case "x86":
120 platform = NetCoreSearchPlatform.X86;
121 break;
122 default:
123 this.Messaging.Write(ErrorMessages.IllegalAttributeValue(sourceLineNumbers, element.Name.LocalName, "Platform", platformValue, "arm64", "x64", "x86"));
124 break;
125 }
126 break;
127 case "MajorVersion":
128 // .NET Core had a different deployment strategy before .NET Core 3.0 which would require different detection logic.
129 majorVersion = this.ParseHelper.GetAttributeIntegerValue(sourceLineNumbers, attrib, 3, Int32.MaxValue);
130 break;
131 default:
132 this.ParseHelper.UnexpectedAttribute(element, attrib);
133 break;
134 }
135 }
136 else
137 {
138 this.ParseHelper.ParseExtensionAttribute(this.Context.Extensions, intermediate, section, element, attrib);
139 }
140 }
141
142 if (id == null)
143 {
144 id = this.ParseHelper.CreateIdentifier("dncs", variable, condition, after);
145 }
146
147 if (!runtimeType.HasValue)
148 {
149 this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "RuntimeType"));
150 }
151
152 if (!platform.HasValue)
153 {
154 this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "Platform"));
155 }
156
157 if (majorVersion == CompilerConstants.IntegerNotSet)
158 {
159 this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "MajorVersion"));
160 }
161 else if (majorVersion == 4)
162 {
163 this.Messaging.Write(ErrorMessages.IllegalAttributeValue(sourceLineNumbers, element.Name.LocalName, "MajorVersion", "4", "3", "5+"));
164 }
165
166 this.ParseHelper.ParseForExtensionElements(this.Context.Extensions, intermediate, section, element);
167
168 var bundleExtensionId = this.ParseHelper.CreateIdentifierValueFromPlatform("Wix4NetfxBundleExtension", this.Context.Platform, BurnPlatforms.X86 | BurnPlatforms.X64 | BurnPlatforms.ARM64);
169 if (bundleExtensionId == null)
170 {
171 this.Messaging.Write(ErrorMessages.UnsupportedPlatformForElement(sourceLineNumbers, this.Context.Platform.ToString(), element.Name.LocalName));
172 }
173
174 if (!this.Messaging.EncounteredError)
175 {
176 this.ParseHelper.CreateWixSearchSymbol(section, sourceLineNumbers, element.Name.LocalName, id, variable, condition, after, bundleExtensionId);
177
178 section.AddSymbol(new NetFxNetCoreSearchSymbol(sourceLineNumbers, id)
179 {
180 RuntimeType = runtimeType.Value,
181 Platform = platform.Value,
182 MajorVersion = majorVersion,
183 });
184 }
185 }
186
187 private void ParseDotNetCoreSearchRefElement(Intermediate intermediate, IntermediateSection section, XElement element)
188 {
189 var sourceLineNumbers = this.ParseHelper.GetSourceLineNumbers(element);
190
191 foreach (var attrib in element.Attributes())
192 {
193 if (String.IsNullOrEmpty(attrib.Name.NamespaceName) || this.Namespace == attrib.Name.Namespace)
194 {
195 switch (attrib.Name.LocalName)
196 {
197 case "Id":
198 var refId = this.ParseHelper.GetAttributeIdentifierValue(sourceLineNumbers, attrib);
199 this.ParseHelper.CreateSimpleReference(section, sourceLineNumbers, NetfxSymbolDefinitions.NetFxNetCoreSearch, refId);
200 break;
201 default:
202 this.ParseHelper.UnexpectedAttribute(element, attrib);
203 break;
204 }
205 }
206 else
207 {
208 this.ParseHelper.ParseExtensionAttribute(this.Context.Extensions, intermediate, section, element, attrib);
209 }
210 }
211
212 this.ParseHelper.ParseForExtensionElements(this.Context.Extensions, intermediate, section, element);
213 }
214
49 /// <summary> 215 /// <summary>
50 /// Parses a NativeImage element. 216 /// Parses a NativeImage element.
51 /// </summary> 217 /// </summary>
diff --git a/src/ext/NetFx/wixext/NetFxExtensionData.cs b/src/ext/NetFx/wixext/NetFxExtensionData.cs
index 0a24ef1e..61d618cf 100644
--- a/src/ext/NetFx/wixext/NetFxExtensionData.cs
+++ b/src/ext/NetFx/wixext/NetFxExtensionData.cs
@@ -4,7 +4,6 @@ namespace WixToolset.Netfx
4{ 4{
5 using WixToolset.Data; 5 using WixToolset.Data;
6 using WixToolset.Extensibility; 6 using WixToolset.Extensibility;
7 using WixToolset.Netfx.Symbols;
8 7
9 /// <summary> 8 /// <summary>
10 /// The WiX Toolset .NET Framework Extension. 9 /// The WiX Toolset .NET Framework Extension.
@@ -13,7 +12,7 @@ namespace WixToolset.Netfx
13 { 12 {
14 public override bool TryGetSymbolDefinitionByName(string name, out IntermediateSymbolDefinition symbolDefinition) 13 public override bool TryGetSymbolDefinitionByName(string name, out IntermediateSymbolDefinition symbolDefinition)
15 { 14 {
16 symbolDefinition = (name == NetfxSymbolDefinitionNames.NetFxNativeImage) ? NetfxSymbolDefinitions.NetFxNativeImage : null; 15 symbolDefinition = NetfxSymbolDefinitions.ByName(name);
17 return symbolDefinition != null; 16 return symbolDefinition != null;
18 } 17 }
19 18
diff --git a/src/ext/NetFx/wixext/Symbols/NetFxNativeImageSymbol.cs b/src/ext/NetFx/wixext/Symbols/NetFxNativeImageSymbol.cs
index 3803abd6..252c6aba 100644
--- a/src/ext/NetFx/wixext/Symbols/NetFxNativeImageSymbol.cs
+++ b/src/ext/NetFx/wixext/Symbols/NetFxNativeImageSymbol.cs
@@ -1,5 +1,26 @@
1// Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. 1// Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information.
2 2
3namespace WixToolset.Netfx
4{
5 using WixToolset.Data;
6 using WixToolset.Netfx.Symbols;
7
8 public static partial class NetfxSymbolDefinitions
9 {
10 public static readonly IntermediateSymbolDefinition NetFxNativeImage = new IntermediateSymbolDefinition(
11 NetfxSymbolDefinitionType.NetFxNativeImage.ToString(),
12 new[]
13 {
14 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.FileRef), IntermediateFieldType.String),
15 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.Priority), IntermediateFieldType.Number),
16 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.Attributes), IntermediateFieldType.Number),
17 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.ApplicationFileRef), IntermediateFieldType.String),
18 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.ApplicationBaseDirectoryRef), IntermediateFieldType.String),
19 },
20 typeof(NetFxNativeImageSymbol));
21 }
22}
23
3namespace WixToolset.Netfx.Symbols 24namespace WixToolset.Netfx.Symbols
4{ 25{
5 using WixToolset.Data; 26 using WixToolset.Data;
@@ -55,4 +76,4 @@ namespace WixToolset.Netfx.Symbols
55 set => this.Set((int)NetFxNativeImageSymbolFields.ApplicationBaseDirectoryRef, value); 76 set => this.Set((int)NetFxNativeImageSymbolFields.ApplicationBaseDirectoryRef, value);
56 } 77 }
57 } 78 }
58} \ No newline at end of file 79}
diff --git a/src/ext/NetFx/wixext/Symbols/NetFxNetCoreSearchSymbol.cs b/src/ext/NetFx/wixext/Symbols/NetFxNetCoreSearchSymbol.cs
new file mode 100644
index 00000000..8bf0a24c
--- /dev/null
+++ b/src/ext/NetFx/wixext/Symbols/NetFxNetCoreSearchSymbol.cs
@@ -0,0 +1,77 @@
1// Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information.
2
3namespace WixToolset.Netfx
4{
5 using WixToolset.Data;
6 using WixToolset.Netfx.Symbols;
7
8 public static partial class NetfxSymbolDefinitions
9 {
10 public static readonly IntermediateSymbolDefinition NetFxNetCoreSearch = new IntermediateSymbolDefinition(
11 NetfxSymbolDefinitionType.NetFxNetCoreSearch.ToString(),
12 new[]
13 {
14 new IntermediateFieldDefinition(nameof(NetFxNetCoreSearchSymbolFields.RuntimeType), IntermediateFieldType.Number),
15 new IntermediateFieldDefinition(nameof(NetFxNetCoreSearchSymbolFields.Platform), IntermediateFieldType.Number),
16 new IntermediateFieldDefinition(nameof(NetFxNetCoreSearchSymbolFields.MajorVersion), IntermediateFieldType.Number),
17 },
18 typeof(NetFxNetCoreSearchSymbol));
19 }
20}
21
22namespace WixToolset.Netfx.Symbols
23{
24 using WixToolset.Data;
25
26 public enum NetCoreSearchRuntimeType
27 {
28 Core,
29 Aspnet,
30 Desktop,
31 }
32
33 public enum NetCoreSearchPlatform
34 {
35 X86,
36 X64,
37 Arm64,
38 }
39
40 public enum NetFxNetCoreSearchSymbolFields
41 {
42 RuntimeType,
43 Platform,
44 MajorVersion,
45 }
46
47 public class NetFxNetCoreSearchSymbol : IntermediateSymbol
48 {
49 public NetFxNetCoreSearchSymbol() : base(NetfxSymbolDefinitions.NetFxNetCoreSearch, null, null)
50 {
51 }
52
53 public NetFxNetCoreSearchSymbol(SourceLineNumber sourceLineNumber, Identifier id = null) : base(NetfxSymbolDefinitions.NetFxNetCoreSearch, sourceLineNumber, id)
54 {
55 }
56
57 public IntermediateField this[NetFxNetCoreSearchSymbolFields index] => this.Fields[(int)index];
58
59 public NetCoreSearchRuntimeType RuntimeType
60 {
61 get => (NetCoreSearchRuntimeType)this.Fields[(int)NetFxNetCoreSearchSymbolFields.RuntimeType].AsNumber();
62 set => this.Set((int)NetFxNetCoreSearchSymbolFields.RuntimeType, (int)value);
63 }
64
65 public NetCoreSearchPlatform Platform
66 {
67 get => (NetCoreSearchPlatform)this.Fields[(int)NetFxNetCoreSearchSymbolFields.Platform].AsNumber();
68 set => this.Set((int)NetFxNetCoreSearchSymbolFields.Platform, (int)value);
69 }
70
71 public int MajorVersion
72 {
73 get => this.Fields[(int)NetFxNetCoreSearchSymbolFields.MajorVersion].AsNumber();
74 set => this.Set((int)NetFxNetCoreSearchSymbolFields.MajorVersion, value);
75 }
76 }
77}
diff --git a/src/ext/NetFx/wixext/Symbols/NetfxSymbolDefinitions.cs b/src/ext/NetFx/wixext/Symbols/NetfxSymbolDefinitions.cs
index 3c0f1176..862eba16 100644
--- a/src/ext/NetFx/wixext/Symbols/NetfxSymbolDefinitions.cs
+++ b/src/ext/NetFx/wixext/Symbols/NetfxSymbolDefinitions.cs
@@ -1,26 +1,47 @@
1// Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. 1// Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information.
2 2
3namespace WixToolset.Netfx.Symbols 3namespace WixToolset.Netfx
4{ 4{
5 using System;
5 using WixToolset.Data; 6 using WixToolset.Data;
7 using WixToolset.Data.Burn;
6 8
7 public static class NetfxSymbolDefinitionNames 9 public enum NetfxSymbolDefinitionType
8 { 10 {
9 public static string NetFxNativeImage { get; } = "NetFxNativeImage"; 11 NetFxNativeImage,
12 NetFxNetCoreSearch,
10 } 13 }
11 14
12 public static class NetfxSymbolDefinitions 15 public static partial class NetfxSymbolDefinitions
13 { 16 {
14 public static readonly IntermediateSymbolDefinition NetFxNativeImage = new IntermediateSymbolDefinition( 17 public static IntermediateSymbolDefinition ByName(string name)
15 NetfxSymbolDefinitionNames.NetFxNativeImage, 18 {
16 new[] 19 if (!Enum.TryParse(name, out NetfxSymbolDefinitionType type))
17 { 20 {
18 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.FileRef), IntermediateFieldType.String), 21 return null;
19 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.Priority), IntermediateFieldType.Number), 22 }
20 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.Attributes), IntermediateFieldType.Number), 23
21 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.ApplicationFileRef), IntermediateFieldType.String), 24 return ByType(type);
22 new IntermediateFieldDefinition(nameof(NetFxNativeImageSymbolFields.ApplicationBaseDirectoryRef), IntermediateFieldType.String), 25 }
23 }, 26
24 typeof(NetFxNativeImageSymbol)); 27 public static IntermediateSymbolDefinition ByType(NetfxSymbolDefinitionType type)
28 {
29 switch (type)
30 {
31 case NetfxSymbolDefinitionType.NetFxNativeImage:
32 return NetfxSymbolDefinitions.NetFxNativeImage;
33
34 case NetfxSymbolDefinitionType.NetFxNetCoreSearch:
35 return NetfxSymbolDefinitions.NetFxNetCoreSearch;
36
37 default:
38 throw new ArgumentOutOfRangeException(nameof(type));
39 }
40 }
41
42 static NetfxSymbolDefinitions()
43 {
44 NetFxNetCoreSearch.AddTag(BurnConstants.BundleExtensionSearchSymbolDefinitionTag);
45 }
25 } 46 }
26} 47}