diff options
Diffstat (limited to 'src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs')
| -rw-r--r-- | src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs | 121 |
1 files changed, 109 insertions, 12 deletions
diff --git a/src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs b/src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs index 0fa48d8c..e8df25ed 100644 --- a/src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs +++ b/src/WixToolset.Core/Link/FlattenAndProcessBundleTablesCommand.cs | |||
| @@ -42,46 +42,143 @@ namespace WixToolset.Core.Link | |||
| 42 | // We need to flatten the nested PayloadGroups and PackageGroups under | 42 | // We need to flatten the nested PayloadGroups and PackageGroups under |
| 43 | // UX, Chain, and any Containers. When we're done, the WixGroups table | 43 | // UX, Chain, and any Containers. When we're done, the WixGroups table |
| 44 | // will hold Payloads under UX, ChainPackages (references?) under Chain, | 44 | // will hold Payloads under UX, ChainPackages (references?) under Chain, |
| 45 | // and ChainPackages/Payloads under the attached and any detatched | 45 | // and ContainerPackages/Payloads under any authored Containers. |
| 46 | // Containers. | ||
| 47 | var groups = new WixGroupingOrdering(this.EntrySection, this.Messaging); | 46 | var groups = new WixGroupingOrdering(this.EntrySection, this.Messaging); |
| 48 | 47 | ||
| 49 | // Create UX payloads and Package payloads | 48 | // Create UX payloads and Package payloads and Container packages |
| 50 | groups.UseTypes(new[] { ComplexReferenceParentType.Container, ComplexReferenceParentType.Layout, ComplexReferenceParentType.PackageGroup, ComplexReferenceParentType.PayloadGroup, ComplexReferenceParentType.Package }, | 49 | groups.UseTypes(new[] { ComplexReferenceParentType.Container, ComplexReferenceParentType.Layout, ComplexReferenceParentType.PackageGroup, ComplexReferenceParentType.PayloadGroup, ComplexReferenceParentType.Package }, |
| 51 | new[] { ComplexReferenceChildType.PackageGroup, ComplexReferenceChildType.Package, ComplexReferenceChildType.PackagePayload, ComplexReferenceChildType.PayloadGroup, ComplexReferenceChildType.Payload }); | 50 | new[] { ComplexReferenceChildType.ContainerPackage, ComplexReferenceChildType.PackageGroup, ComplexReferenceChildType.Package, ComplexReferenceChildType.PackagePayload, ComplexReferenceChildType.PayloadGroup, ComplexReferenceChildType.Payload }); |
| 52 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Package, false); | 51 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Package, false); |
| 53 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Container, false); | 52 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Container, false); |
| 54 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Layout, false); | 53 | groups.FlattenAndRewriteGroups(ComplexReferenceParentType.Layout, false); |
| 55 | 54 | ||
| 56 | // Create Chain packages... | 55 | // Create Chain packages... |
| 57 | groups.UseTypes(new[] { ComplexReferenceParentType.PackageGroup }, new[] { ComplexReferenceChildType.Package, ComplexReferenceChildType.PackageGroup }); | 56 | groups.UseTypes(new[] { ComplexReferenceParentType.PackageGroup }, new[] { ComplexReferenceChildType.Package, ComplexReferenceChildType.PackageGroup }); |
| 58 | groups.FlattenAndRewriteRows(ComplexReferenceChildType.PackageGroup, "WixChain", false); | 57 | groups.FlattenAndRewriteRows(ComplexReferenceParentType.PackageGroup, "WixChain", false); |
| 59 | 58 | ||
| 60 | groups.RemoveUsedGroupRows(); | 59 | groups.RemoveUsedGroupRows(); |
| 61 | } | 60 | } |
| 62 | 61 | ||
| 63 | private void ProcessBundleComplexReferences() | 62 | private void ProcessBundleComplexReferences() |
| 64 | { | 63 | { |
| 64 | var containersById = this.EntrySection.Symbols.OfType<WixBundleContainerSymbol>().ToDictionary(c => c.Id.Id); | ||
| 65 | var groups = this.EntrySection.Symbols.OfType<WixGroupSymbol>().ToList(); | 65 | var groups = this.EntrySection.Symbols.OfType<WixGroupSymbol>().ToList(); |
| 66 | var payloadsById = this.EntrySection.Symbols.OfType<WixBundlePayloadSymbol>().ToDictionary(c => c.Id.Id); | 66 | var payloadsById = this.EntrySection.Symbols.OfType<WixBundlePayloadSymbol>().ToDictionary(c => c.Id.Id); |
| 67 | 67 | ||
| 68 | var containerByPackage = new Dictionary<string, WixBundleContainerSymbol>(); | ||
| 69 | var referencedPackages = new HashSet<string>(); | ||
| 70 | var payloadsInBA = new HashSet<string>(); | ||
| 71 | var payloadsInPackageOrLayout = new HashSet<string>(); | ||
| 72 | |||
| 73 | foreach (var groupSymbol in groups) | ||
| 74 | { | ||
| 75 | switch (groupSymbol.ChildType) | ||
| 76 | { | ||
| 77 | case ComplexReferenceChildType.ContainerPackage: | ||
| 78 | switch (groupSymbol.ParentType) | ||
| 79 | { | ||
| 80 | case ComplexReferenceParentType.Container: | ||
| 81 | if (containerByPackage.TryGetValue(groupSymbol.ChildId, out var collisionContainer)) | ||
| 82 | { | ||
| 83 | this.Messaging.Write(LinkerErrors.PackageInMultipleContainers(groupSymbol.SourceLineNumbers, groupSymbol.ChildId, groupSymbol.ParentId, collisionContainer.Id.Id)); | ||
| 84 | } | ||
| 85 | else | ||
| 86 | { | ||
| 87 | containerByPackage.Add(groupSymbol.ChildId, containersById[groupSymbol.ParentId]); | ||
| 88 | } | ||
| 89 | break; | ||
| 90 | } | ||
| 91 | break; | ||
| 92 | case ComplexReferenceChildType.Package: | ||
| 93 | switch (groupSymbol.ParentType) | ||
| 94 | { | ||
| 95 | case ComplexReferenceParentType.PackageGroup: | ||
| 96 | if (groupSymbol.ParentId == "WixChain") | ||
| 97 | { | ||
| 98 | referencedPackages.Add(groupSymbol.ChildId); | ||
| 99 | } | ||
| 100 | break; | ||
| 101 | } | ||
| 102 | break; | ||
| 103 | case ComplexReferenceChildType.Payload: | ||
| 104 | switch (groupSymbol.ParentType) | ||
| 105 | { | ||
| 106 | case ComplexReferenceParentType.Container: | ||
| 107 | if (groupSymbol.ParentId == BurnConstants.BurnUXContainerName) | ||
| 108 | { | ||
| 109 | payloadsInBA.Add(groupSymbol.ChildId); | ||
| 110 | } | ||
| 111 | break; | ||
| 112 | case ComplexReferenceParentType.Layout: | ||
| 113 | payloadsById[groupSymbol.ChildId].LayoutOnly = true; | ||
| 114 | payloadsInPackageOrLayout.Add(groupSymbol.ChildId); | ||
| 115 | break; | ||
| 116 | case ComplexReferenceParentType.Package: | ||
| 117 | payloadsInPackageOrLayout.Add(groupSymbol.ChildId); | ||
| 118 | break; | ||
| 119 | } | ||
| 120 | break; | ||
| 121 | } | ||
| 122 | } | ||
| 123 | |||
| 124 | foreach (var package in this.EntrySection.Symbols.OfType<WixBundlePackageSymbol>()) | ||
| 125 | { | ||
| 126 | if (!referencedPackages.Contains(package.Id.Id)) | ||
| 127 | { | ||
| 128 | this.Messaging.Write(LinkerErrors.UnscheduledChainPackage(package.SourceLineNumbers, package.Id.Id)); | ||
| 129 | } | ||
| 130 | } | ||
| 131 | |||
| 132 | foreach (var rollbackBoundary in this.EntrySection.Symbols.OfType<WixBundleRollbackBoundarySymbol>()) | ||
| 133 | { | ||
| 134 | if (!referencedPackages.Contains(rollbackBoundary.Id.Id)) | ||
| 135 | { | ||
| 136 | this.Messaging.Write(LinkerErrors.UnscheduledRollbackBoundary(rollbackBoundary.SourceLineNumbers, rollbackBoundary.Id.Id)); | ||
| 137 | } | ||
| 138 | } | ||
| 139 | |||
| 140 | foreach (var payload in payloadsById.Values) | ||
| 141 | { | ||
| 142 | var payloadId = payload.Id.Id; | ||
| 143 | if (payloadsInBA.Contains(payloadId)) | ||
| 144 | { | ||
| 145 | if (payloadsInPackageOrLayout.Contains(payloadId)) | ||
| 146 | { | ||
| 147 | this.Messaging.Write(LinkerErrors.PayloadSharedWithBA(payload.SourceLineNumbers, payloadId)); | ||
| 148 | } | ||
| 149 | } | ||
| 150 | else if (!payloadsInPackageOrLayout.Contains(payloadId)) | ||
| 151 | { | ||
| 152 | this.Messaging.Write(LinkerErrors.OrphanedPayload(payload.SourceLineNumbers, payloadId)); | ||
| 153 | } | ||
| 154 | } | ||
| 155 | |||
| 156 | if (this.Messaging.EncounteredError) | ||
| 157 | { | ||
| 158 | return; | ||
| 159 | } | ||
| 160 | |||
| 68 | // Assign authored payloads to authored containers. | 161 | // Assign authored payloads to authored containers. |
| 69 | // Compressed Payloads not assigned to a container here will get assigned to the default attached container during binding. | 162 | // Compressed Payloads not assigned to a container here will get assigned to the default attached container during binding. |
| 70 | foreach (var groupSymbol in groups) | 163 | foreach (var groupSymbol in groups) |
| 71 | { | 164 | { |
| 72 | if (ComplexReferenceChildType.Payload == groupSymbol.ChildType) | 165 | if (groupSymbol.ChildType == ComplexReferenceChildType.Payload && groupSymbol.ParentType == ComplexReferenceParentType.Container) |
| 73 | { | 166 | { |
| 74 | var payloadSymbol = payloadsById[groupSymbol.ChildId]; | 167 | var payloadSymbol = payloadsById[groupSymbol.ChildId]; |
| 168 | var containerId = groupSymbol.ParentId; | ||
| 75 | 169 | ||
| 76 | if (ComplexReferenceParentType.Container == groupSymbol.ParentType) | 170 | if (String.IsNullOrEmpty(payloadSymbol.ContainerRef)) |
| 171 | { | ||
| 172 | payloadSymbol.ContainerRef = containerId; | ||
| 173 | } | ||
| 174 | else | ||
| 77 | { | 175 | { |
| 78 | // TODO: v3 didn't warn if we overwrote the payload's container. | 176 | this.Messaging.Write(LinkerWarnings.PayloadInMultipleContainers(groupSymbol.SourceLineNumbers, groupSymbol.ChildId, containerId, payloadSymbol.ContainerRef)); |
| 79 | // Should we warn now? | ||
| 80 | payloadSymbol.ContainerRef = groupSymbol.ParentId; | ||
| 81 | } | 177 | } |
| 82 | else if (ComplexReferenceParentType.Layout == groupSymbol.ParentType) | 178 | |
| 179 | if (payloadSymbol.LayoutOnly) | ||
| 83 | { | 180 | { |
| 84 | payloadSymbol.LayoutOnly = true; | 181 | this.Messaging.Write(LinkerWarnings.LayoutPayloadInContainer(groupSymbol.SourceLineNumbers, groupSymbol.ChildId, containerId)); |
| 85 | } | 182 | } |
| 86 | } | 183 | } |
| 87 | } | 184 | } |
