diff options
Diffstat (limited to 'src/wixext/UtilCompiler.cs')
| -rw-r--r-- | src/wixext/UtilCompiler.cs | 103 |
1 files changed, 97 insertions, 6 deletions
diff --git a/src/wixext/UtilCompiler.cs b/src/wixext/UtilCompiler.cs index 63f2b469..45079150 100644 --- a/src/wixext/UtilCompiler.cs +++ b/src/wixext/UtilCompiler.cs | |||
| @@ -35,12 +35,6 @@ namespace WixToolset.Util | |||
| 35 | internal const int UserDontCreateUser = 0x00000200; | 35 | internal const int UserDontCreateUser = 0x00000200; |
| 36 | internal const int UserNonVital = 0x00000400; | 36 | internal const int UserNonVital = 0x00000400; |
| 37 | 37 | ||
| 38 | internal enum WixRegistrySearchFormat | ||
| 39 | { | ||
| 40 | Raw, | ||
| 41 | Compatible, | ||
| 42 | } | ||
| 43 | |||
| 44 | private static readonly Regex FindPropertyBrackets = new Regex(@"\[(?!\\|\])|(?<!\[\\\]|\[\\|\\\[)\]", RegexOptions.ExplicitCapture | RegexOptions.Compiled); | 38 | private static readonly Regex FindPropertyBrackets = new Regex(@"\[(?!\\|\])|(?<!\[\\\]|\[\\|\\\[)\]", RegexOptions.ExplicitCapture | RegexOptions.Compiled); |
| 45 | 39 | ||
| 46 | public override XNamespace Namespace => "http://wixtoolset.org/schemas/v4/wxs/util"; | 40 | public override XNamespace Namespace => "http://wixtoolset.org/schemas/v4/wxs/util"; |
| @@ -135,6 +129,9 @@ namespace WixToolset.Util | |||
| 135 | case "RemoveFolderEx": | 129 | case "RemoveFolderEx": |
| 136 | this.ParseRemoveFolderExElement(intermediate, section, element, componentId); | 130 | this.ParseRemoveFolderExElement(intermediate, section, element, componentId); |
| 137 | break; | 131 | break; |
| 132 | case "RemoveRegistryKey": | ||
| 133 | this.ParseRemoveRegistryKeyExElement(intermediate, section, element, componentId); | ||
| 134 | break; | ||
| 138 | case "RestartResource": | 135 | case "RestartResource": |
| 139 | this.ParseRestartResourceElement(intermediate, section, element, componentId); | 136 | this.ParseRestartResourceElement(intermediate, section, element, componentId); |
| 140 | break; | 137 | break; |
| @@ -2888,6 +2885,100 @@ namespace WixToolset.Util | |||
| 2888 | } | 2885 | } |
| 2889 | 2886 | ||
| 2890 | /// <summary> | 2887 | /// <summary> |
| 2888 | /// Parses a RemoveRegistryKeyEx element. | ||
| 2889 | /// </summary> | ||
| 2890 | /// <param name="node">Element to parse.</param> | ||
| 2891 | /// <param name="componentId">Identifier of parent component.</param> | ||
| 2892 | private void ParseRemoveRegistryKeyExElement(Intermediate intermediate, IntermediateSection section, XElement element, string componentId) | ||
| 2893 | { | ||
| 2894 | var sourceLineNumbers = this.ParseHelper.GetSourceLineNumbers(element); | ||
| 2895 | Identifier id = null; | ||
| 2896 | var mode = WixRemoveRegistryKeyExInstallMode.Uninstall; | ||
| 2897 | string condition = null; | ||
| 2898 | RegistryRootType? root = null; | ||
| 2899 | string key = null; | ||
| 2900 | |||
| 2901 | foreach (var attrib in element.Attributes()) | ||
| 2902 | { | ||
| 2903 | if (String.IsNullOrEmpty(attrib.Name.NamespaceName) || this.Namespace == attrib.Name.Namespace) | ||
| 2904 | { | ||
| 2905 | switch (attrib.Name.LocalName) | ||
| 2906 | { | ||
| 2907 | case "Condition": | ||
| 2908 | condition = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib); | ||
| 2909 | break; | ||
| 2910 | case "Id": | ||
| 2911 | id = this.ParseHelper.GetAttributeIdentifier(sourceLineNumbers, attrib); | ||
| 2912 | break; | ||
| 2913 | case "On": | ||
| 2914 | var actionValue = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib); | ||
| 2915 | switch (actionValue) | ||
| 2916 | { | ||
| 2917 | case "": | ||
| 2918 | break; | ||
| 2919 | case "install": | ||
| 2920 | mode = WixRemoveRegistryKeyExInstallMode.Install; | ||
| 2921 | break; | ||
| 2922 | case "uninstall": | ||
| 2923 | mode = WixRemoveRegistryKeyExInstallMode.Uninstall; | ||
| 2924 | break; | ||
| 2925 | default: | ||
| 2926 | this.Messaging.Write(ErrorMessages.IllegalAttributeValue(sourceLineNumbers, element.Name.LocalName, "On", actionValue, "install", "uninstall")); | ||
| 2927 | break; | ||
| 2928 | } | ||
| 2929 | break; | ||
| 2930 | case "Root": | ||
| 2931 | root = this.ParseHelper.GetAttributeRegistryRootValue(sourceLineNumbers, attrib, false); | ||
| 2932 | break; | ||
| 2933 | case "Key": | ||
| 2934 | key = this.ParseHelper.GetAttributeValue(sourceLineNumbers, attrib); | ||
| 2935 | break; | ||
| 2936 | default: | ||
| 2937 | this.ParseHelper.UnexpectedAttribute(element, attrib); | ||
| 2938 | break; | ||
| 2939 | } | ||
| 2940 | } | ||
| 2941 | else | ||
| 2942 | { | ||
| 2943 | this.ParseHelper.ParseExtensionAttribute(this.Context.Extensions, intermediate, section, element, attrib); | ||
| 2944 | } | ||
| 2945 | } | ||
| 2946 | |||
| 2947 | if (!root.HasValue) | ||
| 2948 | { | ||
| 2949 | this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "Root")); | ||
| 2950 | } | ||
| 2951 | |||
| 2952 | if (key == null) | ||
| 2953 | { | ||
| 2954 | this.Messaging.Write(ErrorMessages.ExpectedAttribute(sourceLineNumbers, element.Name.LocalName, "Key")); | ||
| 2955 | } | ||
| 2956 | |||
| 2957 | if (id == null) | ||
| 2958 | { | ||
| 2959 | id = this.ParseHelper.CreateIdentifier("rrx", componentId, condition, root.ToString(), key, mode.ToString()); | ||
| 2960 | } | ||
| 2961 | |||
| 2962 | this.ParseHelper.ParseForExtensionElements(this.Context.Extensions, intermediate, section, element); | ||
| 2963 | |||
| 2964 | if (!this.Messaging.EncounteredError) | ||
| 2965 | { | ||
| 2966 | this.ParseHelper.EnsureTable(section, sourceLineNumbers, "Registry"); | ||
| 2967 | this.ParseHelper.EnsureTable(section, sourceLineNumbers, "RemoveRegistry"); | ||
| 2968 | this.ParseHelper.CreateCustomActionReference(sourceLineNumbers, section, "Wix4RemoveRegistryKeysEx", this.Context.Platform, CustomActionPlatforms.X86 | CustomActionPlatforms.X64 | CustomActionPlatforms.ARM64); | ||
| 2969 | |||
| 2970 | section.AddSymbol(new WixRemoveRegistryKeyExSymbol(sourceLineNumbers, id) | ||
| 2971 | { | ||
| 2972 | ComponentRef = componentId, | ||
| 2973 | Root = root.Value, | ||
| 2974 | Key = key, | ||
| 2975 | InstallMode = mode, | ||
| 2976 | Condition = condition | ||
| 2977 | }); | ||
| 2978 | } | ||
| 2979 | } | ||
| 2980 | |||
| 2981 | /// <summary> | ||
| 2891 | /// Parses a RestartResource element. | 2982 | /// Parses a RestartResource element. |
| 2892 | /// </summary> | 2983 | /// </summary> |
| 2893 | /// <param name="element">The element to parse.</param> | 2984 | /// <param name="element">The element to parse.</param> |
