diff options
| author | Rob Mensching <rob@firegiant.com> | 2017-12-07 14:19:05 -0800 |
|---|---|---|
| committer | Rob Mensching <rob@firegiant.com> | 2017-12-07 14:19:05 -0800 |
| commit | 49f1209035aac1fcfad5dbbe25f7b2306d3be86c (patch) | |
| tree | 6ce5921493eb751b6d89c3faf0ebdf64110cbb65 /src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs | |
| parent | b1e662bd480241ea914f0f3d6bd174d9ffd03f5f (diff) | |
| download | wix-49f1209035aac1fcfad5dbbe25f7b2306d3be86c.tar.gz wix-49f1209035aac1fcfad5dbbe25f7b2306d3be86c.tar.bz2 wix-49f1209035aac1fcfad5dbbe25f7b2306d3be86c.zip | |
Support MSI backends creating custom tables and remove WixToolset.Data.WindowsInstaller
Diffstat (limited to 'src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs')
| -rw-r--r-- | src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs b/src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs index a19a53f1..4e053c12 100644 --- a/src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs +++ b/src/WixToolset.Core.WindowsInstaller/Bind/CreateOutputFromIRCommand.cs | |||
| @@ -3,20 +3,26 @@ | |||
| 3 | namespace WixToolset.Core.WindowsInstaller.Bind | 3 | namespace WixToolset.Core.WindowsInstaller.Bind |
| 4 | { | 4 | { |
| 5 | using System; | 5 | using System; |
| 6 | using System.Collections.Generic; | ||
| 6 | using System.Linq; | 7 | using System.Linq; |
| 7 | using WixToolset.Core.Native; | 8 | using WixToolset.Core.Native; |
| 8 | using WixToolset.Data; | 9 | using WixToolset.Data; |
| 9 | using WixToolset.Data.Rows; | ||
| 10 | using WixToolset.Data.Tuples; | 10 | using WixToolset.Data.Tuples; |
| 11 | using WixToolset.Data.WindowsInstaller; | ||
| 12 | using WixToolset.Data.WindowsInstaller.Rows; | ||
| 13 | using WixToolset.Extensibility; | ||
| 11 | 14 | ||
| 12 | internal class CreateOutputFromIRCommand | 15 | internal class CreateOutputFromIRCommand |
| 13 | { | 16 | { |
| 14 | public CreateOutputFromIRCommand(IntermediateSection section, TableDefinitionCollection tableDefinitions) | 17 | public CreateOutputFromIRCommand(IntermediateSection section, TableDefinitionCollection tableDefinitions, IEnumerable<IWindowsInstallerBackendExtension> backendExtensions) |
| 15 | { | 18 | { |
| 16 | this.Section = section; | 19 | this.Section = section; |
| 17 | this.TableDefinitions = tableDefinitions; | 20 | this.TableDefinitions = tableDefinitions; |
| 21 | this.BackendExtensions = backendExtensions; | ||
| 18 | } | 22 | } |
| 19 | 23 | ||
| 24 | private IEnumerable<IWindowsInstallerBackendExtension> BackendExtensions { get; } | ||
| 25 | |||
| 20 | private TableDefinitionCollection TableDefinitions { get; } | 26 | private TableDefinitionCollection TableDefinitions { get; } |
| 21 | 27 | ||
| 22 | private IntermediateSection Section { get; } | 28 | private IntermediateSection Section { get; } |
| @@ -60,6 +66,10 @@ namespace WixToolset.Core.WindowsInstaller.Bind | |||
| 60 | // Ignored. | 66 | // Ignored. |
| 61 | break; | 67 | break; |
| 62 | 68 | ||
| 69 | case TupleDefinitionType.MustBeFromAnExtension: | ||
| 70 | this.AddTupleFromExtension(tuple, output); | ||
| 71 | break; | ||
| 72 | |||
| 63 | default: | 73 | default: |
| 64 | this.AddTupleDefaultly(tuple, output); | 74 | this.AddTupleDefaultly(tuple, output); |
| 65 | break; | 75 | break; |
| @@ -206,6 +216,17 @@ namespace WixToolset.Core.WindowsInstaller.Bind | |||
| 206 | } | 216 | } |
| 207 | } | 217 | } |
| 208 | 218 | ||
| 219 | private void AddTupleFromExtension(IntermediateTuple tuple, Output output) | ||
| 220 | { | ||
| 221 | foreach (var extension in this.BackendExtensions) | ||
| 222 | { | ||
| 223 | if (extension.TryAddTupleToOutput(tuple, output)) | ||
| 224 | { | ||
| 225 | break; | ||
| 226 | } | ||
| 227 | } | ||
| 228 | } | ||
| 229 | |||
| 209 | private void AddTupleDefaultly(IntermediateTuple tuple, Output output) | 230 | private void AddTupleDefaultly(IntermediateTuple tuple, Output output) |
| 210 | { | 231 | { |
| 211 | if (!this.TableDefinitions.TryGet(tuple.Definition.Name, out var tableDefinition)) | 232 | if (!this.TableDefinitions.TryGet(tuple.Definition.Name, out var tableDefinition)) |
