diff options
Diffstat (limited to 'src')
14 files changed, 253 insertions, 7 deletions
diff --git a/src/api/wix/WixToolset.Extensibility/BaseOptimizerExtension.cs b/src/api/wix/WixToolset.Extensibility/BaseOptimizerExtension.cs new file mode 100644 index 00000000..5bb89272 --- /dev/null +++ b/src/api/wix/WixToolset.Extensibility/BaseOptimizerExtension.cs | |||
| @@ -0,0 +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. | ||
| 2 | |||
| 3 | namespace WixToolset.Extensibility | ||
| 4 | { | ||
| 5 | using WixToolset.Extensibility.Data; | ||
| 6 | |||
| 7 | /// <summary> | ||
| 8 | /// Base class for creating an optimizer extension. | ||
| 9 | /// </summary> | ||
| 10 | public abstract class BaseOptimizerExtension : IOptimizerExtension | ||
| 11 | { | ||
| 12 | /// <summary> | ||
| 13 | /// Called after all files have been compiled, before built-in optimizations, and before all sections are linked into a single section. | ||
| 14 | /// </summary> | ||
| 15 | public virtual void PreOptimize(IOptimizeContext context) | ||
| 16 | { | ||
| 17 | } | ||
| 18 | |||
| 19 | /// <summary> | ||
| 20 | /// Called after all files have been compiled, after built-in optimizations, and before all sections are linked into a single section. | ||
| 21 | /// </summary> | ||
| 22 | public virtual void PostOptimize(IOptimizeContext context) | ||
| 23 | { | ||
| 24 | } | ||
| 25 | } | ||
| 26 | } | ||
diff --git a/src/api/wix/WixToolset.Extensibility/Data/ICompileContext.cs b/src/api/wix/WixToolset.Extensibility/Data/ICompileContext.cs index 7006fde8..cfccd0a9 100644 --- a/src/api/wix/WixToolset.Extensibility/Data/ICompileContext.cs +++ b/src/api/wix/WixToolset.Extensibility/Data/ICompileContext.cs | |||
| @@ -55,7 +55,7 @@ namespace WixToolset.Extensibility.Data | |||
| 55 | XDocument Source { get; set; } | 55 | XDocument Source { get; set; } |
| 56 | 56 | ||
| 57 | /// <summary> | 57 | /// <summary> |
| 58 | /// Cancellation token to abort cancellation. | 58 | /// Cancellation token. |
| 59 | /// </summary> | 59 | /// </summary> |
| 60 | CancellationToken CancellationToken { get; set; } | 60 | CancellationToken CancellationToken { get; set; } |
| 61 | } | 61 | } |
diff --git a/src/api/wix/WixToolset.Extensibility/Data/IOptimizeContext.cs b/src/api/wix/WixToolset.Extensibility/Data/IOptimizeContext.cs new file mode 100644 index 00000000..5684ebcd --- /dev/null +++ b/src/api/wix/WixToolset.Extensibility/Data/IOptimizeContext.cs | |||
| @@ -0,0 +1,61 @@ | |||
| 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 | |||
| 3 | namespace WixToolset.Extensibility.Data | ||
| 4 | { | ||
| 5 | using System; | ||
| 6 | using System.Collections.Generic; | ||
| 7 | using System.Threading; | ||
| 8 | using WixToolset.Data; | ||
| 9 | |||
| 10 | /// <summary> | ||
| 11 | /// Context provided to the optimizer. | ||
| 12 | /// </summary> | ||
| 13 | public interface IOptimizeContext | ||
| 14 | { | ||
| 15 | /// <summary> | ||
| 16 | /// Service provider made available to the optimizer and its extensions. | ||
| 17 | /// </summary> | ||
| 18 | IServiceProvider ServiceProvider { get; } | ||
| 19 | |||
| 20 | /// <summary> | ||
| 21 | /// Set of extensions provided to the optimizer. | ||
| 22 | /// </summary> | ||
| 23 | IReadOnlyCollection<IOptimizerExtension> Extensions { get; set; } | ||
| 24 | |||
| 25 | /// <summary> | ||
| 26 | /// Intermediate folder. | ||
| 27 | /// </summary> | ||
| 28 | string IntermediateFolder { get; set; } | ||
| 29 | |||
| 30 | /// <summary> | ||
| 31 | /// Collection of bindpaths used to bind files. | ||
| 32 | /// </summary> | ||
| 33 | IReadOnlyCollection<IBindPath> BindPaths { get; set; } | ||
| 34 | |||
| 35 | /// <summary> | ||
| 36 | /// Bind variables used during optimization. | ||
| 37 | /// </summary> | ||
| 38 | IDictionary<string, string> BindVariables { get; set; } | ||
| 39 | |||
| 40 | /// <summary> | ||
| 41 | /// Gets or sets the platform which the optimizer will use when defaulting 64-bit symbol properties. | ||
| 42 | /// </summary> | ||
| 43 | /// <value>The platform which the optimizer will use when defaulting 64-bit symbol properties.</value> | ||
| 44 | Platform Platform { get; set; } | ||
| 45 | |||
| 46 | /// <summary> | ||
| 47 | /// Collection of intermediates to optimize. | ||
| 48 | /// </summary> | ||
| 49 | IReadOnlyCollection<Intermediate> Intermediates { get; set; } | ||
| 50 | |||
| 51 | /// <summary> | ||
| 52 | /// Collection of localization files to use in the optimizer. | ||
| 53 | /// </summary> | ||
| 54 | IReadOnlyCollection<Localization> Localizations { get; set; } | ||
| 55 | |||
| 56 | /// <summary> | ||
| 57 | /// Cancellation token. | ||
| 58 | /// </summary> | ||
| 59 | CancellationToken CancellationToken { get; set; } | ||
| 60 | } | ||
| 61 | } | ||
diff --git a/src/api/wix/WixToolset.Extensibility/IOptimizerExtension.cs b/src/api/wix/WixToolset.Extensibility/IOptimizerExtension.cs new file mode 100644 index 00000000..589e7ecc --- /dev/null +++ b/src/api/wix/WixToolset.Extensibility/IOptimizerExtension.cs | |||
| @@ -0,0 +1,22 @@ | |||
| 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 | |||
| 3 | namespace WixToolset.Extensibility | ||
| 4 | { | ||
| 5 | using WixToolset.Extensibility.Data; | ||
| 6 | |||
| 7 | /// <summary> | ||
| 8 | /// Interface that all optimizer extensions implement. | ||
| 9 | /// </summary> | ||
| 10 | public interface IOptimizerExtension | ||
| 11 | { | ||
| 12 | /// <summary> | ||
| 13 | /// Called after all files have been compiled, before built-in optimizations, and before all sections are linked into a single section. | ||
| 14 | /// </summary> | ||
| 15 | void PreOptimize(IOptimizeContext context); | ||
| 16 | |||
| 17 | /// <summary> | ||
| 18 | /// Called after all files have been compiled, after built-in optimizations, and before all sections are linked into a single section. | ||
| 19 | /// </summary> | ||
| 20 | void PostOptimize(IOptimizeContext context); | ||
| 21 | } | ||
| 22 | } | ||
diff --git a/src/wix/WixToolset.Core/CommandLine/BuildCommand.cs b/src/wix/WixToolset.Core/CommandLine/BuildCommand.cs index 68dbd768..2ad18073 100644 --- a/src/wix/WixToolset.Core/CommandLine/BuildCommand.cs +++ b/src/wix/WixToolset.Core/CommandLine/BuildCommand.cs | |||
| @@ -10,7 +10,6 @@ namespace WixToolset.Core.CommandLine | |||
| 10 | using System.Threading.Tasks; | 10 | using System.Threading.Tasks; |
| 11 | using System.Xml.Linq; | 11 | using System.Xml.Linq; |
| 12 | using WixToolset.Data; | 12 | using WixToolset.Data; |
| 13 | using WixToolset.Data.Bind; | ||
| 14 | using WixToolset.Extensibility; | 13 | using WixToolset.Extensibility; |
| 15 | using WixToolset.Extensibility.Data; | 14 | using WixToolset.Extensibility.Data; |
| 16 | using WixToolset.Extensibility.Services; | 15 | using WixToolset.Extensibility.Services; |
| @@ -112,6 +111,8 @@ namespace WixToolset.Core.CommandLine | |||
| 112 | return Task.FromResult(this.Messaging.LastErrorNumber); | 111 | return Task.FromResult(this.Messaging.LastErrorNumber); |
| 113 | } | 112 | } |
| 114 | 113 | ||
| 114 | this.OptimizePhase(wixobjs, wxls, this.commandLine.BindPaths, this.commandLine.BindVariables, cancellationToken); | ||
| 115 | |||
| 115 | if (inputsOutputs.OutputType == OutputType.Library) | 116 | if (inputsOutputs.OutputType == OutputType.Library) |
| 116 | { | 117 | { |
| 117 | using (new IntermediateFieldContext("wix.lib")) | 118 | using (new IntermediateFieldContext("wix.lib")) |
| @@ -207,6 +208,22 @@ namespace WixToolset.Core.CommandLine | |||
| 207 | return intermediates; | 208 | return intermediates; |
| 208 | } | 209 | } |
| 209 | 210 | ||
| 211 | private void OptimizePhase(IReadOnlyCollection<Intermediate> intermediates, IReadOnlyCollection<Localization> localizations, IReadOnlyCollection<IBindPath> bindPaths, Dictionary<string, string> bindVariables, CancellationToken cancellationToken) | ||
| 212 | { | ||
| 213 | var context = this.ServiceProvider.GetService<IOptimizeContext>(); | ||
| 214 | context.Extensions = this.ExtensionManager.GetServices<IOptimizerExtension>(); | ||
| 215 | context.IntermediateFolder = this.IntermediateFolder; | ||
| 216 | context.BindPaths = bindPaths; | ||
| 217 | context.BindVariables = bindVariables; | ||
| 218 | context.Platform = this.Platform; | ||
| 219 | context.Intermediates = intermediates; | ||
| 220 | context.Localizations = localizations; | ||
| 221 | context.CancellationToken = cancellationToken; | ||
| 222 | |||
| 223 | var optimizer = this.ServiceProvider.GetService<IOptimizer>(); | ||
| 224 | optimizer.Optimize(context); | ||
| 225 | } | ||
| 226 | |||
| 210 | private void LibraryPhase(IReadOnlyCollection<Intermediate> intermediates, IReadOnlyCollection<Localization> localizations, IEnumerable<string> libraryFiles, ISymbolDefinitionCreator creator, bool bindFiles, IReadOnlyCollection<IBindPath> bindPaths, Dictionary<string, string> bindVariables, string outputPath, CancellationToken cancellationToken) | 227 | private void LibraryPhase(IReadOnlyCollection<Intermediate> intermediates, IReadOnlyCollection<Localization> localizations, IEnumerable<string> libraryFiles, ISymbolDefinitionCreator creator, bool bindFiles, IReadOnlyCollection<IBindPath> bindPaths, Dictionary<string, string> bindVariables, string outputPath, CancellationToken cancellationToken) |
| 211 | { | 228 | { |
| 212 | var libraries = this.LoadLibraries(libraryFiles, creator); | 229 | var libraries = this.LoadLibraries(libraryFiles, creator); |
diff --git a/src/wix/WixToolset.Core/IOptimizer.cs b/src/wix/WixToolset.Core/IOptimizer.cs new file mode 100644 index 00000000..85c90b80 --- /dev/null +++ b/src/wix/WixToolset.Core/IOptimizer.cs | |||
| @@ -0,0 +1,17 @@ | |||
| 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 | |||
| 3 | namespace WixToolset.Core | ||
| 4 | { | ||
| 5 | using WixToolset.Extensibility.Data; | ||
| 6 | |||
| 7 | /// <summary> | ||
| 8 | /// Interface for built-in optimizer. | ||
| 9 | /// </summary> | ||
| 10 | public interface IOptimizer | ||
| 11 | { | ||
| 12 | /// <summary> | ||
| 13 | /// Called after all files have been compiled and before all sections are linked into a single section. | ||
| 14 | /// </summary> | ||
| 15 | void Optimize(IOptimizeContext context); | ||
| 16 | } | ||
| 17 | } | ||
diff --git a/src/wix/WixToolset.Core/OptimizeContext.cs b/src/wix/WixToolset.Core/OptimizeContext.cs new file mode 100644 index 00000000..93b6c354 --- /dev/null +++ b/src/wix/WixToolset.Core/OptimizeContext.cs | |||
| @@ -0,0 +1,39 @@ | |||
| 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 | |||
| 3 | namespace WixToolset.Core | ||
| 4 | { | ||
| 5 | using System; | ||
| 6 | using System.Collections.Generic; | ||
| 7 | using System.Threading; | ||
| 8 | using WixToolset.Data; | ||
| 9 | using WixToolset.Extensibility; | ||
| 10 | using WixToolset.Extensibility.Data; | ||
| 11 | |||
| 12 | internal class OptimizeContext : IOptimizeContext | ||
| 13 | { | ||
| 14 | internal OptimizeContext(IServiceProvider serviceProvider) | ||
| 15 | { | ||
| 16 | this.ServiceProvider = serviceProvider; | ||
| 17 | } | ||
| 18 | |||
| 19 | public IServiceProvider ServiceProvider { get; } | ||
| 20 | |||
| 21 | public IReadOnlyCollection<IOptimizerExtension> Extensions { get; set; } | ||
| 22 | |||
| 23 | public string IntermediateFolder { get; set; } | ||
| 24 | |||
| 25 | public IReadOnlyCollection<IBindPath> BindPaths { get; set; } | ||
| 26 | |||
| 27 | public IDictionary<string, string> BindVariables { get; set; } | ||
| 28 | |||
| 29 | public Platform Platform { get; set; } | ||
| 30 | |||
| 31 | public bool IsCurrentPlatform64Bit => this.Platform == Platform.ARM64 || this.Platform == Platform.X64; | ||
| 32 | |||
| 33 | public IReadOnlyCollection<Intermediate> Intermediates { get; set; } | ||
| 34 | |||
| 35 | public IReadOnlyCollection<Localization> Localizations { get; set; } | ||
| 36 | |||
| 37 | public CancellationToken CancellationToken { get; set; } | ||
| 38 | } | ||
| 39 | } | ||
diff --git a/src/wix/WixToolset.Core/Optimizer.cs b/src/wix/WixToolset.Core/Optimizer.cs new file mode 100644 index 00000000..5864121e --- /dev/null +++ b/src/wix/WixToolset.Core/Optimizer.cs | |||
| @@ -0,0 +1,36 @@ | |||
| 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 | |||
| 3 | namespace WixToolset.Core | ||
| 4 | { | ||
| 5 | using System; | ||
| 6 | using WixToolset.Extensibility.Data; | ||
| 7 | using WixToolset.Extensibility.Services; | ||
| 8 | |||
| 9 | internal class Optimizer : IOptimizer | ||
| 10 | { | ||
| 11 | internal Optimizer(IServiceProvider serviceProvider) | ||
| 12 | { | ||
| 13 | this.ServiceProvider = serviceProvider; | ||
| 14 | this.Messaging = this.ServiceProvider.GetService<IMessaging>(); | ||
| 15 | } | ||
| 16 | |||
| 17 | private IServiceProvider ServiceProvider { get; } | ||
| 18 | |||
| 19 | private IMessaging Messaging { get; } | ||
| 20 | |||
| 21 | public void Optimize(IOptimizeContext context) | ||
| 22 | { | ||
| 23 | foreach (var extension in context.Extensions) | ||
| 24 | { | ||
| 25 | extension.PreOptimize(context); | ||
| 26 | } | ||
| 27 | |||
| 28 | // TODO: Fill with useful optimization features. | ||
| 29 | |||
| 30 | foreach (var extension in context.Extensions) | ||
| 31 | { | ||
| 32 | extension.PostOptimize(context); | ||
| 33 | } | ||
| 34 | } | ||
| 35 | } | ||
| 36 | } | ||
diff --git a/src/wix/WixToolset.Core/WixToolsetServiceProvider.cs b/src/wix/WixToolset.Core/WixToolsetServiceProvider.cs index 5620bcd2..cb8dbd87 100644 --- a/src/wix/WixToolset.Core/WixToolsetServiceProvider.cs +++ b/src/wix/WixToolset.Core/WixToolsetServiceProvider.cs | |||
| @@ -37,6 +37,7 @@ namespace WixToolset.Core | |||
| 37 | this.AddService<ICommandLine>((provider, singletons) => new CommandLine.CommandLine(provider)); | 37 | this.AddService<ICommandLine>((provider, singletons) => new CommandLine.CommandLine(provider)); |
| 38 | this.AddService<IPreprocessContext>((provider, singletons) => new PreprocessContext(provider)); | 38 | this.AddService<IPreprocessContext>((provider, singletons) => new PreprocessContext(provider)); |
| 39 | this.AddService<ICompileContext>((provider, singletons) => new CompileContext(provider)); | 39 | this.AddService<ICompileContext>((provider, singletons) => new CompileContext(provider)); |
| 40 | this.AddService<IOptimizeContext>((provider, singletons) => new OptimizeContext(provider)); | ||
| 40 | this.AddService<ILibraryContext>((provider, singletons) => new LibraryContext(provider)); | 41 | this.AddService<ILibraryContext>((provider, singletons) => new LibraryContext(provider)); |
| 41 | this.AddService<ILibraryResult>((provider, singletons) => new LibraryResult()); | 42 | this.AddService<ILibraryResult>((provider, singletons) => new LibraryResult()); |
| 42 | this.AddService<ILinkContext>((provider, singletons) => new LinkContext(provider)); | 43 | this.AddService<ILinkContext>((provider, singletons) => new LinkContext(provider)); |
| @@ -58,6 +59,7 @@ namespace WixToolset.Core | |||
| 58 | 59 | ||
| 59 | this.AddService<IBinder>((provider, singletons) => new Binder(provider)); | 60 | this.AddService<IBinder>((provider, singletons) => new Binder(provider)); |
| 60 | this.AddService<ICompiler>((provider, singletons) => new Compiler(provider)); | 61 | this.AddService<ICompiler>((provider, singletons) => new Compiler(provider)); |
| 62 | this.AddService<IOptimizer>((provider, singletons) => new Optimizer(provider)); | ||
| 61 | this.AddService<ILayoutCreator>((provider, singletons) => new LayoutCreator(provider)); | 63 | this.AddService<ILayoutCreator>((provider, singletons) => new LayoutCreator(provider)); |
| 62 | this.AddService<IPreprocessor>((provider, singletons) => new Preprocessor(provider)); | 64 | this.AddService<IPreprocessor>((provider, singletons) => new Preprocessor(provider)); |
| 63 | this.AddService<ILibrarian>((provider, singletons) => new Librarian(provider)); | 65 | this.AddService<ILibrarian>((provider, singletons) => new Librarian(provider)); |
diff --git a/src/wix/test/Example.Extension/ExampleExtensionFactory.cs b/src/wix/test/Example.Extension/ExampleExtensionFactory.cs index 0b0fb836..16eea6dc 100644 --- a/src/wix/test/Example.Extension/ExampleExtensionFactory.cs +++ b/src/wix/test/Example.Extension/ExampleExtensionFactory.cs | |||
| @@ -35,6 +35,10 @@ namespace Example.Extension | |||
| 35 | { | 35 | { |
| 36 | extension = new ExampleCompilerExtension(); | 36 | extension = new ExampleCompilerExtension(); |
| 37 | } | 37 | } |
| 38 | else if (extensionType == typeof(IOptimizerExtension)) | ||
| 39 | { | ||
| 40 | extension = new ExampleOptimizerExtension(); | ||
| 41 | } | ||
| 38 | else if (extensionType == typeof(IExtensionData)) | 42 | else if (extensionType == typeof(IExtensionData)) |
| 39 | { | 43 | { |
| 40 | extension = new ExampleExtensionData(); | 44 | extension = new ExampleExtensionData(); |
diff --git a/src/wix/test/Example.Extension/ExampleOptimizerExtension.cs b/src/wix/test/Example.Extension/ExampleOptimizerExtension.cs new file mode 100644 index 00000000..6a2cb91e --- /dev/null +++ b/src/wix/test/Example.Extension/ExampleOptimizerExtension.cs | |||
| @@ -0,0 +1,22 @@ | |||
| 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 | |||
| 3 | namespace Example.Extension | ||
| 4 | { | ||
| 5 | using System.Linq; | ||
| 6 | using WixToolset.Extensibility; | ||
| 7 | using WixToolset.Extensibility.Data; | ||
| 8 | |||
| 9 | internal class ExampleOptimizerExtension : BaseOptimizerExtension | ||
| 10 | { | ||
| 11 | public override void PostOptimize(IOptimizeContext context) | ||
| 12 | { | ||
| 13 | foreach (var intermediate in context.Intermediates) | ||
| 14 | { | ||
| 15 | foreach (var symbol in intermediate.Sections.SelectMany(s=>s.Symbols).OfType<ExampleSymbol>()) | ||
| 16 | { | ||
| 17 | symbol.Value = $"{symbol.Value} <optimized>"; | ||
| 18 | } | ||
| 19 | } | ||
| 20 | } | ||
| 21 | } | ||
| 22 | } | ||
diff --git a/src/wix/test/WixToolsetTest.CoreIntegration/ExtensionFixture.cs b/src/wix/test/WixToolsetTest.CoreIntegration/ExtensionFixture.cs index 710f3b8d..429226f5 100644 --- a/src/wix/test/WixToolsetTest.CoreIntegration/ExtensionFixture.cs +++ b/src/wix/test/WixToolsetTest.CoreIntegration/ExtensionFixture.cs | |||
| @@ -24,7 +24,7 @@ namespace WixToolsetTest.CoreIntegration | |||
| 24 | var results = build.BuildAndQuery(Build, "Wix4Example"); | 24 | var results = build.BuildAndQuery(Build, "Wix4Example"); |
| 25 | WixAssert.CompareLineByLine(new[] | 25 | WixAssert.CompareLineByLine(new[] |
| 26 | { | 26 | { |
| 27 | "Wix4Example:Foo\tfilF5_pLhBuF5b4N9XEo52g_hUM5Lo\tBar" | 27 | "Wix4Example:Foo\tfilF5_pLhBuF5b4N9XEo52g_hUM5Lo\tBar <optimized>" |
| 28 | }, results); | 28 | }, results); |
| 29 | } | 29 | } |
| 30 | 30 | ||
| @@ -92,7 +92,7 @@ namespace WixToolsetTest.CoreIntegration | |||
| 92 | var example = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).Single(); | 92 | var example = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).Single(); |
| 93 | WixAssert.StringEqual("Foo", example.Id?.Id); | 93 | WixAssert.StringEqual("Foo", example.Id?.Id); |
| 94 | WixAssert.StringEqual("filF5_pLhBuF5b4N9XEo52g_hUM5Lo", example[0].AsString()); | 94 | WixAssert.StringEqual("filF5_pLhBuF5b4N9XEo52g_hUM5Lo", example[0].AsString()); |
| 95 | WixAssert.StringEqual("Bar", example[1].AsString()); | 95 | WixAssert.StringEqual("Bar <optimized>", example[1].AsString()); |
| 96 | } | 96 | } |
| 97 | } | 97 | } |
| 98 | 98 | ||
diff --git a/src/wix/test/WixToolsetTest.CoreIntegration/TestData/ExampleExtension/Decompiled-Expected.xml b/src/wix/test/WixToolsetTest.CoreIntegration/TestData/ExampleExtension/Decompiled-Expected.xml index 42ececb1..0375b3b6 100644 --- a/src/wix/test/WixToolsetTest.CoreIntegration/TestData/ExampleExtension/Decompiled-Expected.xml +++ b/src/wix/test/WixToolsetTest.CoreIntegration/TestData/ExampleExtension/Decompiled-Expected.xml | |||
| @@ -5,7 +5,7 @@ | |||
| 5 | <StandardDirectory Id="ProgramFilesFolder"> | 5 | <StandardDirectory Id="ProgramFilesFolder"> |
| 6 | <Directory Id="INSTALLFOLDER" ShortName="oekcr5lq" Name="MsiPackage"> | 6 | <Directory Id="INSTALLFOLDER" ShortName="oekcr5lq" Name="MsiPackage"> |
| 7 | <Component Id="filF5_pLhBuF5b4N9XEo52g_hUM5Lo" Guid="{GUID}" Bitness="always32"> | 7 | <Component Id="filF5_pLhBuF5b4N9XEo52g_hUM5Lo" Guid="{GUID}" Bitness="always32"> |
| 8 | <Example Id="Foo" Value="Bar" xmlns="http://www.example.com/scheams/v1/wxs" /> | 8 | <Example Id="Foo" Value="Bar <optimized>" xmlns="http://www.example.com/scheams/v1/wxs" /> |
| 9 | <File Id="filF5_pLhBuF5b4N9XEo52g_hUM5Lo" Name="example.txt" KeyPath="yes" Source="PFiles\MsiPackage\example.txt" /> | 9 | <File Id="filF5_pLhBuF5b4N9XEo52g_hUM5Lo" Name="example.txt" KeyPath="yes" Source="PFiles\MsiPackage\example.txt" /> |
| 10 | </Component> | 10 | </Component> |
| 11 | </Directory> | 11 | </Directory> |
diff --git a/src/wix/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs b/src/wix/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs index 76326741..0cd8a542 100644 --- a/src/wix/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs +++ b/src/wix/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs | |||
| @@ -288,7 +288,7 @@ namespace WixToolsetTest.CoreIntegration | |||
| 288 | 288 | ||
| 289 | var example = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).Single(); | 289 | var example = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).Single(); |
| 290 | WixAssert.StringEqual("Foo", example.Id?.Id); | 290 | WixAssert.StringEqual("Foo", example.Id?.Id); |
| 291 | WixAssert.StringEqual("Bar", example[1].AsString()); | 291 | WixAssert.StringEqual("Bar <optimized>", example[1].AsString()); |
| 292 | } | 292 | } |
| 293 | } | 293 | } |
| 294 | 294 | ||
| @@ -351,7 +351,7 @@ namespace WixToolsetTest.CoreIntegration | |||
| 351 | var examples = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).ToArray(); | 351 | var examples = section.Symbols.Where(t => t.Definition.Type == SymbolDefinitionType.MustBeFromAnExtension).ToArray(); |
| 352 | WixAssert.CompareLineByLine(new[] { "Foo", "Other" }, examples.Select(t => t.Id?.Id).ToArray()); | 352 | WixAssert.CompareLineByLine(new[] { "Foo", "Other" }, examples.Select(t => t.Id?.Id).ToArray()); |
| 353 | WixAssert.CompareLineByLine(new[] { "filF5_pLhBuF5b4N9XEo52g_hUM5Lo", "filvxdStJhRE_M5kbpLsTZJXbs34Sg" }, examples.Select(t => t[0].AsString()).ToArray()); | 353 | WixAssert.CompareLineByLine(new[] { "filF5_pLhBuF5b4N9XEo52g_hUM5Lo", "filvxdStJhRE_M5kbpLsTZJXbs34Sg" }, examples.Select(t => t[0].AsString()).ToArray()); |
| 354 | WixAssert.CompareLineByLine(new[] { "Bar", "Value" }, examples.Select(t => t[1].AsString()).ToArray()); | 354 | WixAssert.CompareLineByLine(new[] { "Bar <optimized>", "Value <optimized>" }, examples.Select(t => t[1].AsString()).ToArray()); |
| 355 | } | 355 | } |
| 356 | } | 356 | } |
| 357 | } | 357 | } |
