diff options
author | Sean Hall <r.sean.hall@gmail.com> | 2022-10-06 16:37:14 -0500 |
---|---|---|
committer | Sean Hall <r.sean.hall@gmail.com> | 2022-10-10 11:40:02 -0500 |
commit | 21a0685ef69e9d634600622b19ea970c6f58ef03 (patch) | |
tree | 5d37e316803f06d97d4aefd3df8ab45f3f7e7257 | |
parent | 3c11c1389f67824fb1f368cedacbaf566645e56f (diff) | |
download | wix-21a0685ef69e9d634600622b19ea970c6f58ef03.tar.gz wix-21a0685ef69e9d634600622b19ea970c6f58ef03.tar.bz2 wix-21a0685ef69e9d634600622b19ea970c6f58ef03.zip |
Add Netfx bundle extension and netfx:DotNetCoreSearch.
Remove built-in .NET Core packages since they update too quickly.
Fixes 6257
55 files changed, 1569 insertions, 151 deletions
diff --git a/src/ext/NetFx/NetFx.wixext.sln b/src/ext/NetFx/NetFx.wixext.sln index 8316ac91..b8b72eb8 100644 --- a/src/ext/NetFx/NetFx.wixext.sln +++ b/src/ext/NetFx/NetFx.wixext.sln | |||
@@ -1,8 +1,12 @@ | |||
1 | | 1 | |
2 | Microsoft Visual Studio Solution File, Format Version 12.00 | 2 | Microsoft Visual Studio Solution File, Format Version 12.00 |
3 | # Visual Studio 15 | 3 | # Visual Studio Version 17 |
4 | VisualStudioVersion = 15.0.27130.2010 | 4 | VisualStudioVersion = 17.3.32811.315 |
5 | MinimumVisualStudioVersion = 15.0.26124.0 | 5 | MinimumVisualStudioVersion = 15.0.26124.0 |
6 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "netcoresearch", "netcoresearch\netcoresearch.vcxproj", "{A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}" | ||
7 | EndProject | ||
8 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "netfxbe", "be\netfxbe.vcxproj", "{B65719C0-B2CC-45F9-AF33-6F147F741ADB}" | ||
9 | EndProject | ||
6 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "netfxca", "ca\netfxca.vcxproj", "{F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}" | 10 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "netfxca", "ca\netfxca.vcxproj", "{F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}" |
7 | EndProject | 11 | EndProject |
8 | Project("{930C7802-8A8C-48F9-8165-68863BCCD9DD}") = "netfx", "wixlib\netfx.wixproj", "{45E4A6AC-3190-4E17-83F0-9935FFA5DC2B}" | 12 | Project("{930C7802-8A8C-48F9-8165-68863BCCD9DD}") = "netfx", "wixlib\netfx.wixproj", "{45E4A6AC-3190-4E17-83F0-9935FFA5DC2B}" |
@@ -21,14 +25,40 @@ Global | |||
21 | Release|x86 = Release|x86 | 25 | Release|x86 = Release|x86 |
22 | EndGlobalSection | 26 | EndGlobalSection |
23 | GlobalSection(ProjectConfigurationPlatforms) = postSolution | 27 | GlobalSection(ProjectConfigurationPlatforms) = postSolution |
28 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|Any CPU.ActiveCfg = Debug|Win32 | ||
29 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|Any CPU.Build.0 = Debug|Win32 | ||
30 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|x64.ActiveCfg = Debug|x64 | ||
31 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|x64.Build.0 = Debug|x64 | ||
32 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|x86.ActiveCfg = Debug|Win32 | ||
33 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Debug|x86.Build.0 = Debug|Win32 | ||
34 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|Any CPU.ActiveCfg = Release|Win32 | ||
35 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|Any CPU.Build.0 = Release|Win32 | ||
36 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|x64.ActiveCfg = Release|x64 | ||
37 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|x64.Build.0 = Release|x64 | ||
38 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|x86.ActiveCfg = Release|Win32 | ||
39 | {A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}.Release|x86.Build.0 = Release|Win32 | ||
40 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|Any CPU.ActiveCfg = Debug|Win32 | ||
41 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|Any CPU.Build.0 = Debug|Win32 | ||
42 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|x64.ActiveCfg = Debug|x64 | ||
43 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|x64.Build.0 = Debug|x64 | ||
44 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|x86.ActiveCfg = Debug|Win32 | ||
45 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Debug|x86.Build.0 = Debug|Win32 | ||
46 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|Any CPU.ActiveCfg = Release|Win32 | ||
47 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|Any CPU.Build.0 = Release|Win32 | ||
48 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|x64.ActiveCfg = Release|x64 | ||
49 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|x64.Build.0 = Release|x64 | ||
50 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|x86.ActiveCfg = Release|Win32 | ||
51 | {B65719C0-B2CC-45F9-AF33-6F147F741ADB}.Release|x86.Build.0 = Release|Win32 | ||
24 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|Any CPU.ActiveCfg = Debug|Win32 | 52 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|Any CPU.ActiveCfg = Debug|Win32 |
25 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|Any CPU.Build.0 = Debug|Win32 | 53 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|Any CPU.Build.0 = Debug|Win32 |
26 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x64.ActiveCfg = Debug|Win32 | 54 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x64.ActiveCfg = Debug|x64 |
55 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x64.Build.0 = Debug|x64 | ||
27 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x86.ActiveCfg = Debug|Win32 | 56 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x86.ActiveCfg = Debug|Win32 |
28 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x86.Build.0 = Debug|Win32 | 57 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Debug|x86.Build.0 = Debug|Win32 |
29 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|Any CPU.ActiveCfg = Release|Win32 | 58 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|Any CPU.ActiveCfg = Release|Win32 |
30 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|Any CPU.Build.0 = Release|Win32 | 59 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|Any CPU.Build.0 = Release|Win32 |
31 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x64.ActiveCfg = Release|Win32 | 60 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x64.ActiveCfg = Release|x64 |
61 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x64.Build.0 = Release|x64 | ||
32 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x86.ActiveCfg = Release|Win32 | 62 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x86.ActiveCfg = Release|Win32 |
33 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x86.Build.0 = Release|Win32 | 63 | {F72D34CA-48DA-4DFD-91A9-A0C78BEF6981}.Release|x86.Build.0 = Release|Win32 |
34 | {45E4A6AC-3190-4E17-83F0-9935FFA5DC2B}.Debug|Any CPU.ActiveCfg = Debug|x86 | 64 | {45E4A6AC-3190-4E17-83F0-9935FFA5DC2B}.Debug|Any CPU.ActiveCfg = Debug|x86 |
diff --git a/src/ext/NetFx/be/NetfxBundleExtension.cpp b/src/ext/NetFx/be/NetfxBundleExtension.cpp new file mode 100644 index 00000000..838a97c1 --- /dev/null +++ b/src/ext/NetFx/be/NetfxBundleExtension.cpp | |||
@@ -0,0 +1,102 @@ | |||
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 | #include "precomp.h" | ||
4 | #include "BextBaseBundleExtension.h" | ||
5 | |||
6 | class CWixNetfxBundleExtension : public CBextBaseBundleExtension | ||
7 | { | ||
8 | public: // IBundleExtension | ||
9 | virtual STDMETHODIMP Search( | ||
10 | __in LPCWSTR wzId, | ||
11 | __in LPCWSTR wzVariable | ||
12 | ) | ||
13 | { | ||
14 | HRESULT hr = S_OK; | ||
15 | |||
16 | hr = NetfxSearchExecute(&m_searches, wzId, wzVariable, m_pEngine, m_sczBaseDirectory); | ||
17 | |||
18 | return hr; | ||
19 | } | ||
20 | |||
21 | public: //CBextBaseBundleExtension | ||
22 | virtual STDMETHODIMP Initialize( | ||
23 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pCreateArgs | ||
24 | ) | ||
25 | { | ||
26 | HRESULT hr = S_OK; | ||
27 | LPWSTR sczModulePath = NULL; | ||
28 | IXMLDOMDocument* pixdManifest = NULL; | ||
29 | IXMLDOMNode* pixnBundleExtension = NULL; | ||
30 | |||
31 | hr = __super::Initialize(pCreateArgs); | ||
32 | BextExitOnFailure(hr, "CBextBaseBundleExtension initialization failed."); | ||
33 | |||
34 | hr = PathForCurrentProcess(&sczModulePath, m_hInstance); | ||
35 | BextExitOnFailure(hr, "Failed to get bundle extension path."); | ||
36 | |||
37 | hr = PathGetDirectory(sczModulePath, &m_sczBaseDirectory); | ||
38 | BextExitOnFailure(hr, "Failed to get bundle extension base directory."); | ||
39 | |||
40 | hr = XmlLoadDocumentFromFile(m_sczBundleExtensionDataPath, &pixdManifest); | ||
41 | BextExitOnFailure(hr, "Failed to load bundle extension manifest from path: %ls", m_sczBundleExtensionDataPath); | ||
42 | |||
43 | hr = BextGetBundleExtensionDataNode(pixdManifest, NETFX_BUNDLE_EXTENSION_ID, &pixnBundleExtension); | ||
44 | BextExitOnFailure(hr, "Failed to get BundleExtension '%ls'", NETFX_BUNDLE_EXTENSION_ID); | ||
45 | |||
46 | hr = NetfxSearchParseFromXml(&m_searches, pixnBundleExtension); | ||
47 | BextExitOnFailure(hr, "Failed to parse searches from bundle extension manifest."); | ||
48 | |||
49 | LExit: | ||
50 | ReleaseObject(pixnBundleExtension); | ||
51 | ReleaseObject(pixdManifest); | ||
52 | ReleaseStr(sczModulePath); | ||
53 | |||
54 | return hr; | ||
55 | } | ||
56 | |||
57 | public: | ||
58 | CWixNetfxBundleExtension( | ||
59 | __in HINSTANCE hInstance, | ||
60 | __in IBundleExtensionEngine* pEngine | ||
61 | ) : CBextBaseBundleExtension(pEngine) | ||
62 | { | ||
63 | m_searches = { }; | ||
64 | m_hInstance = hInstance; | ||
65 | m_sczBaseDirectory = NULL; | ||
66 | } | ||
67 | |||
68 | ~CWixNetfxBundleExtension() | ||
69 | { | ||
70 | NetfxSearchUninitialize(&m_searches); | ||
71 | ReleaseStr(m_sczBaseDirectory); | ||
72 | } | ||
73 | |||
74 | private: | ||
75 | NETFX_SEARCHES m_searches; | ||
76 | HINSTANCE m_hInstance; | ||
77 | LPWSTR m_sczBaseDirectory; | ||
78 | }; | ||
79 | |||
80 | HRESULT NetfxBundleExtensionCreate( | ||
81 | __in HINSTANCE hInstance, | ||
82 | __in IBundleExtensionEngine* pEngine, | ||
83 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, | ||
84 | __out IBundleExtension** ppBundleExtension | ||
85 | ) | ||
86 | { | ||
87 | HRESULT hr = S_OK; | ||
88 | CWixNetfxBundleExtension* pExtension = NULL; | ||
89 | |||
90 | pExtension = new CWixNetfxBundleExtension(hInstance, pEngine); | ||
91 | BextExitOnNull(pExtension, hr, E_OUTOFMEMORY, "Failed to create new CWixNetfxBundleExtension."); | ||
92 | |||
93 | hr = pExtension->Initialize(pArgs); | ||
94 | BextExitOnFailure(hr, "CWixNetfxBundleExtension initialization failed."); | ||
95 | |||
96 | *ppBundleExtension = pExtension; | ||
97 | pExtension = NULL; | ||
98 | |||
99 | LExit: | ||
100 | ReleaseObject(pExtension); | ||
101 | return hr; | ||
102 | } | ||
diff --git a/src/ext/NetFx/be/NetfxBundleExtension.h b/src/ext/NetFx/be/NetfxBundleExtension.h new file mode 100644 index 00000000..0746dbed --- /dev/null +++ b/src/ext/NetFx/be/NetfxBundleExtension.h | |||
@@ -0,0 +1,17 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | |||
5 | // constants | ||
6 | |||
7 | #define NETFX_BUNDLE_EXTENSION_ID BUNDLE_EXTENSION_DECORATION(L"NetfxBundleExtension") | ||
8 | |||
9 | |||
10 | // function declarations | ||
11 | |||
12 | HRESULT NetfxBundleExtensionCreate( | ||
13 | __in HINSTANCE hInstance, | ||
14 | __in IBundleExtensionEngine* pEngine, | ||
15 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, | ||
16 | __out IBundleExtension** ppBundleExtension | ||
17 | ); | ||
diff --git a/src/ext/NetFx/be/detectnetcore.cpp b/src/ext/NetFx/be/detectnetcore.cpp new file mode 100644 index 00000000..42156692 --- /dev/null +++ b/src/ext/NetFx/be/detectnetcore.cpp | |||
@@ -0,0 +1,140 @@ | |||
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 | #include "precomp.h" | ||
4 | |||
5 | HRESULT DetectNetCore( | ||
6 | __in NETFX_NET_CORE_PLATFORM platform, | ||
7 | __in NETFX_NET_CORE_RUNTIME_TYPE runtimeType, | ||
8 | __in LPCWSTR wzMajorVersion, | ||
9 | __in LPCWSTR wzBaseDirectory, | ||
10 | __inout LPWSTR* psczLatestVersion | ||
11 | ) | ||
12 | { | ||
13 | HRESULT hr = S_OK; | ||
14 | LPCWSTR wzRuntimeType = NULL; | ||
15 | LPCWSTR wzPlatformName = NULL; | ||
16 | LPWSTR sczExePath = NULL; | ||
17 | LPWSTR sczCommandLine = NULL; | ||
18 | HANDLE hProcess = NULL; | ||
19 | HANDLE hStdOutErr = INVALID_HANDLE_VALUE; | ||
20 | BYTE* rgbOutput = NULL; | ||
21 | DWORD cbOutput = 0; | ||
22 | DWORD cbTotalRead = 0; | ||
23 | DWORD cbRead = 0; | ||
24 | DWORD dwExitCode = 0; | ||
25 | |||
26 | ReleaseNullStr(*psczLatestVersion); | ||
27 | |||
28 | switch (runtimeType) | ||
29 | { | ||
30 | case NETFX_NET_CORE_RUNTIME_TYPE_ASPNET: | ||
31 | wzRuntimeType = L"Microsoft.AspNetCore.App"; | ||
32 | break; | ||
33 | case NETFX_NET_CORE_RUNTIME_TYPE_CORE: | ||
34 | wzRuntimeType = L"Microsoft.NETCore.App"; | ||
35 | break; | ||
36 | case NETFX_NET_CORE_RUNTIME_TYPE_DESKTOP: | ||
37 | wzRuntimeType = L"Microsoft.WindowsDesktop.App"; | ||
38 | break; | ||
39 | default: | ||
40 | BextExitWithRootFailure(hr, E_INVALIDARG, "Unknown runtime type: %u", runtimeType); | ||
41 | break; | ||
42 | } | ||
43 | |||
44 | switch (platform) | ||
45 | { | ||
46 | case NETFX_NET_CORE_PLATFORM_ARM64: | ||
47 | wzPlatformName = L"arm64"; | ||
48 | break; | ||
49 | case NETFX_NET_CORE_PLATFORM_X64: | ||
50 | wzPlatformName = L"x64"; | ||
51 | break; | ||
52 | case NETFX_NET_CORE_PLATFORM_X86: | ||
53 | wzPlatformName = L"x86"; | ||
54 | break; | ||
55 | default: | ||
56 | BextExitWithRootFailure(hr, E_INVALIDARG, "Unknown platform: %u", platform); | ||
57 | break; | ||
58 | } | ||
59 | |||
60 | hr = StrAllocFormatted(&sczExePath, L"%ls%ls\\netcoresearch.exe", wzBaseDirectory, wzPlatformName); | ||
61 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe path."); | ||
62 | |||
63 | hr = StrAllocFormatted(&sczCommandLine, L"\"%ls\" %ls %ls", sczExePath, wzMajorVersion, wzRuntimeType); | ||
64 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe command line."); | ||
65 | |||
66 | hr = ProcExecute(sczExePath, sczCommandLine, &hProcess, NULL, &hStdOutErr); | ||
67 | if (HRESULT_FROM_WIN32(ERROR_EXE_MACHINE_TYPE_MISMATCH) == hr) | ||
68 | { | ||
69 | ExitFunction1(hr = S_FALSE); | ||
70 | } | ||
71 | BextExitOnFailure(hr, "Failed to run: %ls", sczCommandLine); | ||
72 | |||
73 | cbOutput = 64; | ||
74 | |||
75 | rgbOutput = reinterpret_cast<BYTE*>(MemAlloc(cbOutput, TRUE)); | ||
76 | BextExitOnNull(rgbOutput, hr, E_OUTOFMEMORY, "Failed to alloc output string."); | ||
77 | |||
78 | while (::ReadFile(hStdOutErr, rgbOutput + cbTotalRead, cbOutput - cbTotalRead, &cbRead, NULL)) | ||
79 | { | ||
80 | cbTotalRead += cbRead; | ||
81 | |||
82 | if (cbTotalRead == cbOutput) | ||
83 | { | ||
84 | cbOutput *= 2; | ||
85 | |||
86 | LPVOID pvNew = MemReAlloc(rgbOutput, cbOutput, TRUE); | ||
87 | BextExitOnNull(pvNew, hr, E_OUTOFMEMORY, "Failed to realloc output string."); | ||
88 | |||
89 | rgbOutput = reinterpret_cast<BYTE*>(pvNew); | ||
90 | } | ||
91 | } | ||
92 | |||
93 | if (ERROR_BROKEN_PIPE != ::GetLastError()) | ||
94 | { | ||
95 | BextExitWithLastError(hr, "Failed to read netcoresearch.exe output."); | ||
96 | } | ||
97 | |||
98 | hr = ProcWaitForCompletion(hProcess, INFINITE, &dwExitCode); | ||
99 | BextExitOnFailure(hr, "Failed to wait for netcoresearch.exe to exit."); | ||
100 | |||
101 | if (0 != dwExitCode) | ||
102 | { | ||
103 | BextExitWithRootFailure(hr, E_UNEXPECTED, "netcoresearch.exe failed with exit code: 0x%x\r\nOutput:\r\n%hs", dwExitCode, rgbOutput); | ||
104 | } | ||
105 | |||
106 | if (*rgbOutput) | ||
107 | { | ||
108 | hr = StrAllocStringAnsi(psczLatestVersion, reinterpret_cast<LPSTR>(rgbOutput), 0, CP_UTF8); | ||
109 | BextExitOnFailure(hr, "Failed to widen output string: %hs", rgbOutput); | ||
110 | } | ||
111 | |||
112 | LExit: | ||
113 | ReleaseFileHandle(hStdOutErr); | ||
114 | ReleaseHandle(hProcess); | ||
115 | ReleaseMem(rgbOutput); | ||
116 | ReleaseStr(sczCommandLine); | ||
117 | ReleaseStr(sczExePath); | ||
118 | |||
119 | return hr; | ||
120 | } | ||
121 | |||
122 | HRESULT NetfxPerformDetectNetCore( | ||
123 | __in LPCWSTR wzVariable, | ||
124 | __in NETFX_SEARCH* pSearch, | ||
125 | __in IBundleExtensionEngine* pEngine, | ||
126 | __in LPCWSTR wzBaseDirectory | ||
127 | ) | ||
128 | { | ||
129 | HRESULT hr = S_OK; | ||
130 | LPWSTR sczLatestVersion = FALSE; | ||
131 | |||
132 | hr = DetectNetCore(pSearch->NetCoreSearch.platform, pSearch->NetCoreSearch.runtimeType, pSearch->NetCoreSearch.sczMajorVersion, wzBaseDirectory, &sczLatestVersion); | ||
133 | BextExitOnFailure(hr, "DetectNetCore failed."); | ||
134 | |||
135 | hr = pEngine->SetVariableVersion(wzVariable, sczLatestVersion); | ||
136 | BextExitOnFailure(hr, "Failed to set variable '%ls' to '%ls'", wzVariable, sczLatestVersion); | ||
137 | |||
138 | LExit: | ||
139 | return hr; | ||
140 | } | ||
diff --git a/src/ext/NetFx/be/detectnetcore.h b/src/ext/NetFx/be/detectnetcore.h new file mode 100644 index 00000000..ef93b39b --- /dev/null +++ b/src/ext/NetFx/be/detectnetcore.h | |||
@@ -0,0 +1,9 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | HRESULT NetfxPerformDetectNetCore( | ||
5 | __in LPCWSTR wzVariable, | ||
6 | __in NETFX_SEARCH* pSearch, | ||
7 | __in IBundleExtensionEngine* pEngine, | ||
8 | __in LPCWSTR wzBaseDirectory | ||
9 | ); | ||
diff --git a/src/ext/NetFx/be/netfxbe.cpp b/src/ext/NetFx/be/netfxbe.cpp new file mode 100644 index 00000000..3a34cea3 --- /dev/null +++ b/src/ext/NetFx/be/netfxbe.cpp | |||
@@ -0,0 +1,62 @@ | |||
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 | #include "precomp.h" | ||
4 | #include "BextBaseBundleExtensionProc.h" | ||
5 | |||
6 | static HINSTANCE vhInstance = NULL; | ||
7 | static IBundleExtension* vpBundleExtension = NULL; | ||
8 | |||
9 | // function definitions | ||
10 | |||
11 | extern "C" BOOL WINAPI DllMain( | ||
12 | __in HINSTANCE hInstance, | ||
13 | __in DWORD dwReason, | ||
14 | __in LPVOID /*pvReserved*/ | ||
15 | ) | ||
16 | { | ||
17 | switch(dwReason) | ||
18 | { | ||
19 | case DLL_PROCESS_ATTACH: | ||
20 | vhInstance = hInstance; | ||
21 | break; | ||
22 | |||
23 | case DLL_PROCESS_DETACH: | ||
24 | vhInstance = NULL; | ||
25 | break; | ||
26 | } | ||
27 | |||
28 | return TRUE; | ||
29 | } | ||
30 | |||
31 | extern "C" HRESULT WINAPI BundleExtensionCreate( | ||
32 | __in const BUNDLE_EXTENSION_CREATE_ARGS* pArgs, | ||
33 | __inout BUNDLE_EXTENSION_CREATE_RESULTS* pResults | ||
34 | ) | ||
35 | { | ||
36 | HRESULT hr = S_OK; | ||
37 | IBundleExtensionEngine* pEngine = NULL; | ||
38 | |||
39 | hr = XmlInitialize(); | ||
40 | ExitOnFailure(hr, "Failed to initialize XML."); | ||
41 | |||
42 | hr = BextInitializeFromCreateArgs(pArgs, &pEngine); | ||
43 | ExitOnFailure(hr, "Failed to initialize bext"); | ||
44 | |||
45 | hr = NetfxBundleExtensionCreate(vhInstance, pEngine, pArgs, &vpBundleExtension); | ||
46 | BextExitOnFailure(hr, "Failed to create WixNetfxBundleExtension"); | ||
47 | |||
48 | pResults->pfnBundleExtensionProc = BextBaseBundleExtensionProc; | ||
49 | pResults->pvBundleExtensionProcContext = vpBundleExtension; | ||
50 | |||
51 | LExit: | ||
52 | ReleaseObject(pEngine); | ||
53 | |||
54 | return hr; | ||
55 | } | ||
56 | |||
57 | extern "C" void WINAPI BundleExtensionDestroy() | ||
58 | { | ||
59 | BextUninitialize(); | ||
60 | ReleaseNullObject(vpBundleExtension); | ||
61 | XmlUninitialize(); | ||
62 | } | ||
diff --git a/src/ext/NetFx/be/netfxbe.def b/src/ext/NetFx/be/netfxbe.def new file mode 100644 index 00000000..c6605241 --- /dev/null +++ b/src/ext/NetFx/be/netfxbe.def | |||
@@ -0,0 +1,8 @@ | |||
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 | |||
4 | LIBRARY "netfxbe" | ||
5 | |||
6 | EXPORTS | ||
7 | BundleExtensionCreate | ||
8 | BundleExtensionDestroy | ||
diff --git a/src/ext/NetFx/be/netfxbe.vcxproj b/src/ext/NetFx/be/netfxbe.vcxproj new file mode 100644 index 00000000..00588764 --- /dev/null +++ b/src/ext/NetFx/be/netfxbe.vcxproj | |||
@@ -0,0 +1,77 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | ||
2 | <!-- 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. --> | ||
3 | |||
4 | <Project DefaultTargets="Build" Toolsxmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||
5 | <ItemGroup Label="ProjectConfigurations"> | ||
6 | <ProjectConfiguration Include="Debug|ARM64"> | ||
7 | <Configuration>Debug</Configuration> | ||
8 | <Platform>ARM64</Platform> | ||
9 | </ProjectConfiguration> | ||
10 | <ProjectConfiguration Include="Release|ARM64"> | ||
11 | <Configuration>Release</Configuration> | ||
12 | <Platform>ARM64</Platform> | ||
13 | </ProjectConfiguration> | ||
14 | <ProjectConfiguration Include="Debug|X64"> | ||
15 | <Configuration>Debug</Configuration> | ||
16 | <Platform>X64</Platform> | ||
17 | </ProjectConfiguration> | ||
18 | <ProjectConfiguration Include="Release|X64"> | ||
19 | <Configuration>Release</Configuration> | ||
20 | <Platform>X64</Platform> | ||
21 | </ProjectConfiguration> | ||
22 | <ProjectConfiguration Include="Debug|Win32"> | ||
23 | <Configuration>Debug</Configuration> | ||
24 | <Platform>Win32</Platform> | ||
25 | </ProjectConfiguration> | ||
26 | <ProjectConfiguration Include="Release|Win32"> | ||
27 | <Configuration>Release</Configuration> | ||
28 | <Platform>Win32</Platform> | ||
29 | </ProjectConfiguration> | ||
30 | </ItemGroup> | ||
31 | |||
32 | <PropertyGroup Label="Globals"> | ||
33 | <ProjectGuid>{B65719C0-B2CC-45F9-AF33-6F147F741ADB}</ProjectGuid> | ||
34 | <ConfigurationType>DynamicLibrary</ConfigurationType> | ||
35 | <TargetName>netfxbe</TargetName> | ||
36 | <CharacterSet>Unicode</CharacterSet> | ||
37 | <ProjectModuleDefinitionFile>netfxbe.def</ProjectModuleDefinitionFile> | ||
38 | <Description>WiX Toolset Netfx BundleExtension</Description> | ||
39 | </PropertyGroup> | ||
40 | |||
41 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> | ||
42 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> | ||
43 | |||
44 | <PropertyGroup> | ||
45 | <ProjectAdditionalLinkLibraries>msi.lib</ProjectAdditionalLinkLibraries> | ||
46 | </PropertyGroup> | ||
47 | |||
48 | <ItemGroup> | ||
49 | <ClCompile Include="detectnetcore.cpp" /> | ||
50 | <ClCompile Include="netfxbe.cpp" /> | ||
51 | <ClCompile Include="NetfxBundleExtension.cpp" /> | ||
52 | <ClCompile Include="netfxsearch.cpp" /> | ||
53 | <ClCompile Include="precomp.cpp"> | ||
54 | <PrecompiledHeader>Create</PrecompiledHeader> | ||
55 | </ClCompile> | ||
56 | </ItemGroup> | ||
57 | |||
58 | <ItemGroup> | ||
59 | <ClInclude Include="detectnetcore.h" /> | ||
60 | <ClInclude Include="NetfxBundleExtension.h" /> | ||
61 | <ClInclude Include="netfxsearch.h" /> | ||
62 | <ClInclude Include="precomp.h" /> | ||
63 | </ItemGroup> | ||
64 | |||
65 | <ItemGroup> | ||
66 | <None Include="netfxbe.def" /> | ||
67 | </ItemGroup> | ||
68 | |||
69 | <ItemGroup> | ||
70 | <PackageReference Include="WixToolset.BextUtil" /> | ||
71 | |||
72 | <PackageReference Include="Microsoft.SourceLink.GitHub" PrivateAssets="All" /> | ||
73 | <PackageReference Include="GitInfo" PrivateAssets="All" /> | ||
74 | </ItemGroup> | ||
75 | |||
76 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | ||
77 | </Project> | ||
diff --git a/src/ext/NetFx/be/netfxsearch.cpp b/src/ext/NetFx/be/netfxsearch.cpp new file mode 100644 index 00000000..3c12161d --- /dev/null +++ b/src/ext/NetFx/be/netfxsearch.cpp | |||
@@ -0,0 +1,149 @@ | |||
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 | #include "precomp.h" | ||
4 | |||
5 | |||
6 | STDMETHODIMP NetfxSearchParseFromXml( | ||
7 | __in NETFX_SEARCHES* pSearches, | ||
8 | __in IXMLDOMNode* pixnBundleExtension | ||
9 | ) | ||
10 | { | ||
11 | HRESULT hr = S_OK; | ||
12 | IXMLDOMNodeList* pixnNodes = NULL; | ||
13 | IXMLDOMNode* pixnNode = NULL; | ||
14 | DWORD cNodes = 0; | ||
15 | BSTR bstrNodeName = NULL; | ||
16 | |||
17 | // Select Netfx search nodes. | ||
18 | hr = XmlSelectNodes(pixnBundleExtension, L"NetFxNetCoreSearch", &pixnNodes); | ||
19 | BextExitOnFailure(hr, "Failed to select Netfx search nodes."); | ||
20 | |||
21 | // Get Netfx search node count. | ||
22 | hr = pixnNodes->get_length((long*)&cNodes); | ||
23 | BextExitOnFailure(hr, "Failed to get Netfx search node count."); | ||
24 | |||
25 | if (!cNodes) | ||
26 | { | ||
27 | ExitFunction(); | ||
28 | } | ||
29 | |||
30 | // Allocate memory for searches. | ||
31 | pSearches->rgSearches = (NETFX_SEARCH*)MemAlloc(sizeof(NETFX_SEARCH) * cNodes, TRUE); | ||
32 | BextExitOnNull(pSearches->rgSearches, hr, E_OUTOFMEMORY, "Failed to allocate memory for search structs."); | ||
33 | |||
34 | pSearches->cSearches = cNodes; | ||
35 | |||
36 | // Parse search elements. | ||
37 | for (DWORD i = 0; i < cNodes; ++i) | ||
38 | { | ||
39 | NETFX_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
40 | |||
41 | hr = XmlNextElement(pixnNodes, &pixnNode, &bstrNodeName); | ||
42 | BextExitOnFailure(hr, "Failed to get next node."); | ||
43 | |||
44 | // @Id | ||
45 | hr = XmlGetAttributeEx(pixnNode, L"Id", &pSearch->sczId); | ||
46 | BextExitOnFailure(hr, "Failed to get @Id."); | ||
47 | |||
48 | // Read type specific attributes. | ||
49 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, bstrNodeName, -1, L"NetFxNetCoreSearch", -1)) | ||
50 | { | ||
51 | pSearch->Type = NETFX_SEARCH_TYPE_NET_CORE_SEARCH; | ||
52 | |||
53 | // @RuntimeType | ||
54 | hr = XmlGetAttributeUInt32(pixnNode, L"RuntimeType", reinterpret_cast<DWORD*>(&pSearch->NetCoreSearch.runtimeType)); | ||
55 | BextExitOnFailure(hr, "Failed to get @RuntimeType."); | ||
56 | |||
57 | // @Platform | ||
58 | hr = XmlGetAttributeUInt32(pixnNode, L"Platform", reinterpret_cast<DWORD*>(&pSearch->NetCoreSearch.platform)); | ||
59 | BextExitOnFailure(hr, "Failed to get @Platform."); | ||
60 | |||
61 | // @MajorVersion | ||
62 | hr = XmlGetAttributeEx(pixnNode, L"MajorVersion", &pSearch->NetCoreSearch.sczMajorVersion); | ||
63 | BextExitOnFailure(hr, "Failed to get @MajorVersion."); | ||
64 | } | ||
65 | else | ||
66 | { | ||
67 | BextExitWithRootFailure(hr, E_UNEXPECTED, "Unexpected element name: %ls", bstrNodeName); | ||
68 | } | ||
69 | |||
70 | // prepare next iteration | ||
71 | ReleaseNullObject(pixnNode); | ||
72 | ReleaseNullBSTR(bstrNodeName); | ||
73 | } | ||
74 | |||
75 | LExit: | ||
76 | ReleaseBSTR(bstrNodeName); | ||
77 | ReleaseObject(pixnNode); | ||
78 | ReleaseObject(pixnNodes); | ||
79 | |||
80 | return hr; | ||
81 | } | ||
82 | |||
83 | void NetfxSearchUninitialize( | ||
84 | __in NETFX_SEARCHES* pSearches | ||
85 | ) | ||
86 | { | ||
87 | if (pSearches->rgSearches) | ||
88 | { | ||
89 | for (DWORD i = 0; i < pSearches->cSearches; ++i) | ||
90 | { | ||
91 | NETFX_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
92 | |||
93 | ReleaseStr(pSearch->sczId); | ||
94 | } | ||
95 | MemFree(pSearches->rgSearches); | ||
96 | } | ||
97 | } | ||
98 | |||
99 | STDMETHODIMP NetfxSearchExecute( | ||
100 | __in NETFX_SEARCHES* pSearches, | ||
101 | __in LPCWSTR wzSearchId, | ||
102 | __in LPCWSTR wzVariable, | ||
103 | __in IBundleExtensionEngine* pEngine, | ||
104 | __in LPCWSTR wzBaseDirectory | ||
105 | ) | ||
106 | { | ||
107 | HRESULT hr = S_OK; | ||
108 | NETFX_SEARCH* pSearch = NULL; | ||
109 | |||
110 | hr = NetfxSearchFindById(pSearches, wzSearchId, &pSearch); | ||
111 | BextExitOnFailure(hr, "Search id '%ls' is unknown to the util extension.", wzSearchId); | ||
112 | |||
113 | switch (pSearch->Type) | ||
114 | { | ||
115 | case NETFX_SEARCH_TYPE_NET_CORE_SEARCH: | ||
116 | hr = NetfxPerformDetectNetCore(wzVariable, pSearch, pEngine, wzBaseDirectory); | ||
117 | break; | ||
118 | default: | ||
119 | hr = E_UNEXPECTED; | ||
120 | } | ||
121 | |||
122 | LExit: | ||
123 | return hr; | ||
124 | } | ||
125 | |||
126 | STDMETHODIMP NetfxSearchFindById( | ||
127 | __in NETFX_SEARCHES* pSearches, | ||
128 | __in LPCWSTR wzId, | ||
129 | __out NETFX_SEARCH** ppSearch | ||
130 | ) | ||
131 | { | ||
132 | HRESULT hr = S_OK; | ||
133 | |||
134 | for (DWORD i = 0; i < pSearches->cSearches; ++i) | ||
135 | { | ||
136 | NETFX_SEARCH* pSearch = &pSearches->rgSearches[i]; | ||
137 | |||
138 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, pSearch->sczId, -1, wzId, -1)) | ||
139 | { | ||
140 | *ppSearch = pSearch; | ||
141 | ExitFunction1(hr = S_OK); | ||
142 | } | ||
143 | } | ||
144 | |||
145 | hr = E_NOTFOUND; | ||
146 | |||
147 | LExit: | ||
148 | return hr; | ||
149 | } | ||
diff --git a/src/ext/NetFx/be/netfxsearch.h b/src/ext/NetFx/be/netfxsearch.h new file mode 100644 index 00000000..ae250690 --- /dev/null +++ b/src/ext/NetFx/be/netfxsearch.h | |||
@@ -0,0 +1,76 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | |||
5 | // constants | ||
6 | |||
7 | enum NETFX_SEARCH_TYPE | ||
8 | { | ||
9 | NETFX_SEARCH_TYPE_NONE, | ||
10 | NETFX_SEARCH_TYPE_NET_CORE_SEARCH, | ||
11 | }; | ||
12 | |||
13 | enum NETFX_NET_CORE_RUNTIME_TYPE | ||
14 | { | ||
15 | NETFX_NET_CORE_RUNTIME_TYPE_CORE, | ||
16 | NETFX_NET_CORE_RUNTIME_TYPE_ASPNET, | ||
17 | NETFX_NET_CORE_RUNTIME_TYPE_DESKTOP, | ||
18 | }; | ||
19 | |||
20 | enum NETFX_NET_CORE_PLATFORM | ||
21 | { | ||
22 | NETFX_NET_CORE_PLATFORM_X86, | ||
23 | NETFX_NET_CORE_PLATFORM_X64, | ||
24 | NETFX_NET_CORE_PLATFORM_ARM64, | ||
25 | }; | ||
26 | |||
27 | |||
28 | // structs | ||
29 | |||
30 | typedef struct _NETFX_SEARCH | ||
31 | { | ||
32 | LPWSTR sczId; | ||
33 | |||
34 | NETFX_SEARCH_TYPE Type; | ||
35 | union | ||
36 | { | ||
37 | struct | ||
38 | { | ||
39 | NETFX_NET_CORE_RUNTIME_TYPE runtimeType; | ||
40 | NETFX_NET_CORE_PLATFORM platform; | ||
41 | LPWSTR sczMajorVersion; | ||
42 | } NetCoreSearch; | ||
43 | }; | ||
44 | } NETFX_SEARCH; | ||
45 | |||
46 | typedef struct _NETFX_SEARCHES | ||
47 | { | ||
48 | NETFX_SEARCH* rgSearches; | ||
49 | DWORD cSearches; | ||
50 | } NETFX_SEARCHES; | ||
51 | |||
52 | |||
53 | // function declarations | ||
54 | |||
55 | STDMETHODIMP NetfxSearchParseFromXml( | ||
56 | __in NETFX_SEARCHES* pSearches, | ||
57 | __in IXMLDOMNode* pixnBundleExtension | ||
58 | ); | ||
59 | |||
60 | void NetfxSearchUninitialize( | ||
61 | __in NETFX_SEARCHES* pSearches | ||
62 | ); | ||
63 | |||
64 | STDMETHODIMP NetfxSearchExecute( | ||
65 | __in NETFX_SEARCHES* pSearches, | ||
66 | __in LPCWSTR wzSearchId, | ||
67 | __in LPCWSTR wzVariable, | ||
68 | __in IBundleExtensionEngine* pEngine, | ||
69 | __in LPCWSTR wzBaseDirectory | ||
70 | ); | ||
71 | |||
72 | STDMETHODIMP NetfxSearchFindById( | ||
73 | __in NETFX_SEARCHES* pSearches, | ||
74 | __in LPCWSTR wzId, | ||
75 | __out NETFX_SEARCH** ppSearch | ||
76 | ); | ||
diff --git a/src/ext/NetFx/be/precomp.cpp b/src/ext/NetFx/be/precomp.cpp new file mode 100644 index 00000000..37664a1c --- /dev/null +++ b/src/ext/NetFx/be/precomp.cpp | |||
@@ -0,0 +1,3 @@ | |||
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 | #include "precomp.h" | ||
diff --git a/src/ext/NetFx/be/precomp.h b/src/ext/NetFx/be/precomp.h new file mode 100644 index 00000000..33aea9bc --- /dev/null +++ b/src/ext/NetFx/be/precomp.h | |||
@@ -0,0 +1,33 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | |||
5 | #include <windows.h> | ||
6 | #include <msiquery.h> | ||
7 | #include <msidefs.h> | ||
8 | #include <stierr.h> | ||
9 | |||
10 | #include <strsafe.h> | ||
11 | |||
12 | #include <msxml2.h> | ||
13 | |||
14 | #include <dutil.h> | ||
15 | #include <fileutil.h> | ||
16 | #include <memutil.h> | ||
17 | #include <strutil.h> | ||
18 | #include <pathutil.h> | ||
19 | #include <procutil.h> | ||
20 | #include <xmlutil.h> | ||
21 | |||
22 | #include <BundleExtensionEngine.h> | ||
23 | #include <BundleExtension.h> | ||
24 | |||
25 | #include <IBundleExtensionEngine.h> | ||
26 | #include <IBundleExtension.h> | ||
27 | #include <bextutil.h> | ||
28 | #include <BextBundleExtensionEngine.h> | ||
29 | |||
30 | #include "..\..\beDecor.h" | ||
31 | #include "netfxsearch.h" | ||
32 | #include "detectnetcore.h" | ||
33 | #include "NetfxBundleExtension.h" | ||
diff --git a/src/ext/NetFx/netcoresearch/netcoresearch.cpp b/src/ext/NetFx/netcoresearch/netcoresearch.cpp new file mode 100644 index 00000000..b2dad9a8 --- /dev/null +++ b/src/ext/NetFx/netcoresearch/netcoresearch.cpp | |||
@@ -0,0 +1,158 @@ | |||
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 | #include "precomp.h" | ||
4 | |||
5 | struct NETCORESEARCH_STATE | ||
6 | { | ||
7 | LPCWSTR wzTargetName; | ||
8 | DWORD dwMajorVersion; | ||
9 | VERUTIL_VERSION* pVersion; | ||
10 | }; | ||
11 | |||
12 | static HRESULT GetDotnetEnvironmentInfo( | ||
13 | __in DWORD dwMajorVersion, | ||
14 | __in_z LPCWSTR wzTargetName, | ||
15 | __inout VERUTIL_VERSION** ppVersion | ||
16 | ); | ||
17 | static void HOSTFXR_CALLTYPE GetDotnetEnvironmentInfoResult( | ||
18 | __in const hostfxr_dotnet_environment_info* pInfo, | ||
19 | __in LPVOID pvContext | ||
20 | ); | ||
21 | |||
22 | int __cdecl wmain(int argc, LPWSTR argv[]) | ||
23 | { | ||
24 | HRESULT hr = S_OK; | ||
25 | DWORD dwMajorVersion = 0; | ||
26 | VERUTIL_VERSION* pVersion = NULL; | ||
27 | LPSTR pszVersion = NULL; | ||
28 | |||
29 | ::SetConsoleCP(CP_UTF8); | ||
30 | |||
31 | ConsoleInitialize(); | ||
32 | |||
33 | if (argc != 3) | ||
34 | { | ||
35 | ExitFunction1(hr = E_INVALIDARG); | ||
36 | } | ||
37 | |||
38 | hr = StrStringToUInt32(argv[1], 0, reinterpret_cast<UINT*>(&dwMajorVersion)); | ||
39 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to get target version from: %ls", argv[1]); | ||
40 | |||
41 | hr = GetDotnetEnvironmentInfo(dwMajorVersion, argv[2], &pVersion); | ||
42 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to search for .NET Core."); | ||
43 | |||
44 | if (pVersion) | ||
45 | { | ||
46 | hr = StrAnsiAllocString(&pszVersion, pVersion->sczVersion, 0, CP_UTF8); | ||
47 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to convert version to UTF-8."); | ||
48 | |||
49 | ConsoleWrite(CONSOLE_COLOR_NORMAL, "%hs", pszVersion); | ||
50 | } | ||
51 | |||
52 | LExit: | ||
53 | ReleaseStr(pszVersion); | ||
54 | ReleaseVerutilVersion(pVersion); | ||
55 | ConsoleUninitialize(); | ||
56 | return hr; | ||
57 | } | ||
58 | |||
59 | static HRESULT GetDotnetEnvironmentInfo( | ||
60 | __in DWORD dwMajorVersion, | ||
61 | __in_z LPCWSTR wzTargetName, | ||
62 | __inout VERUTIL_VERSION** ppVersion | ||
63 | ) | ||
64 | { | ||
65 | HRESULT hr = S_OK; | ||
66 | LPWSTR sczProcessPath = NULL; | ||
67 | LPWSTR sczHostfxrPath = NULL; | ||
68 | HMODULE hModule = NULL; | ||
69 | hostfxr_get_dotnet_environment_info_fn pfnGetDotnetEnvironmentInfo = NULL; | ||
70 | NETCORESEARCH_STATE state = { }; | ||
71 | |||
72 | state.dwMajorVersion = dwMajorVersion; | ||
73 | state.wzTargetName = wzTargetName; | ||
74 | |||
75 | hr = PathForCurrentProcess(&sczProcessPath, NULL); | ||
76 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to get process path."); | ||
77 | |||
78 | hr = PathGetDirectory(sczProcessPath, &sczHostfxrPath); | ||
79 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to get process directory."); | ||
80 | |||
81 | hr = StrAllocConcat(&sczHostfxrPath, L"hostfxr.dll", 0); | ||
82 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to build hostfxr path."); | ||
83 | |||
84 | hModule = ::LoadLibraryExW(sczHostfxrPath, NULL, LOAD_WITH_ALTERED_SEARCH_PATH); | ||
85 | ConsoleExitOnNullWithLastError(hModule, hr, CONSOLE_COLOR_RED, "Failed to load hostfxr."); | ||
86 | |||
87 | pfnGetDotnetEnvironmentInfo = (hostfxr_get_dotnet_environment_info_fn)::GetProcAddress(hModule, "hostfxr_get_dotnet_environment_info"); | ||
88 | ConsoleExitOnNullWithLastError(pfnGetDotnetEnvironmentInfo, hr, CONSOLE_COLOR_RED, "Failed to get address for hostfxr_get_dotnet_environment_info."); | ||
89 | |||
90 | hr = pfnGetDotnetEnvironmentInfo(NULL, NULL, GetDotnetEnvironmentInfoResult, &state); | ||
91 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to get .NET Core environment info."); | ||
92 | |||
93 | if (state.pVersion) | ||
94 | { | ||
95 | *ppVersion = state.pVersion; | ||
96 | state.pVersion = NULL; | ||
97 | } | ||
98 | |||
99 | LExit: | ||
100 | ReleaseVerutilVersion(state.pVersion); | ||
101 | ReleaseStr(sczHostfxrPath); | ||
102 | ReleaseStr(sczProcessPath); | ||
103 | |||
104 | if (hModule) | ||
105 | { | ||
106 | ::FreeLibrary(hModule); | ||
107 | } | ||
108 | |||
109 | return hr; | ||
110 | } | ||
111 | |||
112 | static void HOSTFXR_CALLTYPE GetDotnetEnvironmentInfoResult( | ||
113 | __in const hostfxr_dotnet_environment_info* pInfo, | ||
114 | __in LPVOID pvContext | ||
115 | ) | ||
116 | { | ||
117 | NETCORESEARCH_STATE* pState = reinterpret_cast<NETCORESEARCH_STATE*>(pvContext); | ||
118 | HRESULT hr = S_OK; | ||
119 | VERUTIL_VERSION* pFrameworkVersion = NULL; | ||
120 | int nCompare = 0; | ||
121 | |||
122 | for (size_t i = 0; i < pInfo->framework_count; ++i) | ||
123 | { | ||
124 | const hostfxr_dotnet_environment_framework_info* pFrameworkInfo = pInfo->frameworks + i; | ||
125 | ReleaseVerutilVersion(pFrameworkVersion); | ||
126 | |||
127 | if (CSTR_EQUAL != ::CompareStringW(LOCALE_INVARIANT, NORM_IGNORECASE, pState->wzTargetName, -1, pFrameworkInfo->name, -1)) | ||
128 | { | ||
129 | continue; | ||
130 | } | ||
131 | |||
132 | hr = VerParseVersion(pFrameworkInfo->version, 0, FALSE, &pFrameworkVersion); | ||
133 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to parse framework version: %ls", pFrameworkInfo->version); | ||
134 | |||
135 | if (pFrameworkVersion->dwMajor != pState->dwMajorVersion) | ||
136 | { | ||
137 | continue; | ||
138 | } | ||
139 | |||
140 | if (pState->pVersion) | ||
141 | { | ||
142 | hr = VerCompareParsedVersions(pState->pVersion, pFrameworkVersion, &nCompare); | ||
143 | ConsoleExitOnFailure(hr, CONSOLE_COLOR_RED, "Failed to compare versions."); | ||
144 | |||
145 | if (nCompare > -1) | ||
146 | { | ||
147 | continue; | ||
148 | } | ||
149 | } | ||
150 | |||
151 | ReleaseVerutilVersion(pState->pVersion); | ||
152 | pState->pVersion = pFrameworkVersion; | ||
153 | pFrameworkVersion = NULL; | ||
154 | } | ||
155 | |||
156 | LExit: | ||
157 | ReleaseVerutilVersion(pFrameworkVersion); | ||
158 | } | ||
diff --git a/src/ext/NetFx/netcoresearch/netcoresearch.h b/src/ext/NetFx/netcoresearch/netcoresearch.h new file mode 100644 index 00000000..d25b13f9 --- /dev/null +++ b/src/ext/NetFx/netcoresearch/netcoresearch.h | |||
@@ -0,0 +1,10 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | // TODO: remove when definition is provided in hostfxr.h. | ||
5 | typedef int32_t(HOSTFXR_CALLTYPE* hostfxr_get_dotnet_environment_info_fn)( | ||
6 | const char_t* dotnet_root, | ||
7 | void* reserved, | ||
8 | hostfxr_get_dotnet_environment_info_result_fn result, | ||
9 | void* result_context | ||
10 | ); | ||
diff --git a/src/ext/NetFx/netcoresearch/netcoresearch.vcxproj b/src/ext/NetFx/netcoresearch/netcoresearch.vcxproj new file mode 100644 index 00000000..b5f12f07 --- /dev/null +++ b/src/ext/NetFx/netcoresearch/netcoresearch.vcxproj | |||
@@ -0,0 +1,73 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | ||
2 | <!-- 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. --> | ||
3 | <Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||
4 | <ItemGroup Label="ProjectConfigurations"> | ||
5 | <ProjectConfiguration Include="Debug|ARM64"> | ||
6 | <Configuration>Debug</Configuration> | ||
7 | <Platform>ARM64</Platform> | ||
8 | </ProjectConfiguration> | ||
9 | <ProjectConfiguration Include="Release|ARM64"> | ||
10 | <Configuration>Release</Configuration> | ||
11 | <Platform>ARM64</Platform> | ||
12 | </ProjectConfiguration> | ||
13 | <ProjectConfiguration Include="Debug|Win32"> | ||
14 | <Configuration>Debug</Configuration> | ||
15 | <Platform>Win32</Platform> | ||
16 | </ProjectConfiguration> | ||
17 | <ProjectConfiguration Include="Release|Win32"> | ||
18 | <Configuration>Release</Configuration> | ||
19 | <Platform>Win32</Platform> | ||
20 | </ProjectConfiguration> | ||
21 | <ProjectConfiguration Include="Debug|x64"> | ||
22 | <Configuration>Debug</Configuration> | ||
23 | <Platform>x64</Platform> | ||
24 | </ProjectConfiguration> | ||
25 | <ProjectConfiguration Include="Release|x64"> | ||
26 | <Configuration>Release</Configuration> | ||
27 | <Platform>x64</Platform> | ||
28 | </ProjectConfiguration> | ||
29 | </ItemGroup> | ||
30 | |||
31 | <PropertyGroup Label="Globals"> | ||
32 | <ProjectGuid>{A7FD9EF2-68CF-4C8E-AD81-3E8A6C7E1937}</ProjectGuid> | ||
33 | <ConfigurationType>Application</ConfigurationType> | ||
34 | <CharacterSet>Unicode</CharacterSet> | ||
35 | <ProjectSubSystem>Console</ProjectSubSystem> | ||
36 | <TargetName>netcoresearch</TargetName> | ||
37 | </PropertyGroup> | ||
38 | |||
39 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> | ||
40 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> | ||
41 | |||
42 | <PropertyGroup> | ||
43 | <NetHostPlatform>$(Platform)</NetHostPlatform> | ||
44 | <NetHostPlatform Condition=" '$(NetHostPlatform)'=='Win32' ">x86</NetHostPlatform> | ||
45 | <NetHostPath>..\..\..\..\packages\runtime.win-$(NetHostPlatform).Microsoft.NETCore.DotNetAppHost.6.0.4\runtimes\win-$(NetHostPlatform)\native\</NetHostPath> | ||
46 | <HostfxrPath>..\..\..\..\packages\runtime.win-$(NetHostPlatform).Microsoft.NETCore.DotNetHostResolver.6.0.4\runtimes\win-$(NetHostPlatform)\native\</HostfxrPath> | ||
47 | <ProjectAdditionalIncludeDirectories>$(NetHostPath)</ProjectAdditionalIncludeDirectories> | ||
48 | </PropertyGroup> | ||
49 | |||
50 | <ItemGroup> | ||
51 | <ClCompile Include="netcoresearch.cpp" /> | ||
52 | <ClCompile Include="precomp.cpp"> | ||
53 | <PrecompiledHeader>Create</PrecompiledHeader> | ||
54 | </ClCompile> | ||
55 | </ItemGroup> | ||
56 | |||
57 | <ItemGroup> | ||
58 | <ClInclude Include="netcoresearch.h" /> | ||
59 | <ClInclude Include="precomp.h" /> | ||
60 | </ItemGroup> | ||
61 | |||
62 | <ItemGroup> | ||
63 | <PackageReference Include="WixToolset.Dutil" /> | ||
64 | <PackageReference Include="Microsoft.SourceLink.GitHub" PrivateAssets="All" /> | ||
65 | <PackageReference Include="GitInfo" PrivateAssets="All" /> | ||
66 | </ItemGroup> | ||
67 | |||
68 | <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> | ||
69 | |||
70 | <Target Name="CopyHostfxr" AfterTargets="Build"> | ||
71 | <Copy SourceFiles="$(HostfxrPath)hostfxr.dll" DestinationFolder="$(OutputPath)" /> | ||
72 | </Target> | ||
73 | </Project> | ||
diff --git a/src/ext/NetFx/netcoresearch/packages.config b/src/ext/NetFx/netcoresearch/packages.config new file mode 100644 index 00000000..ad26db1c --- /dev/null +++ b/src/ext/NetFx/netcoresearch/packages.config | |||
@@ -0,0 +1,9 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | ||
2 | <packages> | ||
3 | <package id="runtime.win-arm64.Microsoft.NETCore.DotNetAppHost" version="6.0.4" targetFramework="native" /> | ||
4 | <package id="runtime.win-x64.Microsoft.NETCore.DotNetAppHost" version="6.0.4" targetFramework="native" /> | ||
5 | <package id="runtime.win-x86.Microsoft.NETCore.DotNetAppHost" version="6.0.4" targetFramework="native" /> | ||
6 | <package id="runtime.win-arm64.Microsoft.NETCore.DotNetHostResolver" version="6.0.4" targetFramework="native" /> | ||
7 | <package id="runtime.win-x64.Microsoft.NETCore.DotNetHostResolver" version="6.0.4" targetFramework="native" /> | ||
8 | <package id="runtime.win-x86.Microsoft.NETCore.DotNetHostResolver" version="6.0.4" targetFramework="native" /> | ||
9 | </packages> \ No newline at end of file | ||
diff --git a/src/ext/NetFx/netcoresearch/precomp.cpp b/src/ext/NetFx/netcoresearch/precomp.cpp new file mode 100644 index 00000000..37664a1c --- /dev/null +++ b/src/ext/NetFx/netcoresearch/precomp.cpp | |||
@@ -0,0 +1,3 @@ | |||
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 | #include "precomp.h" | ||
diff --git a/src/ext/NetFx/netcoresearch/precomp.h b/src/ext/NetFx/netcoresearch/precomp.h new file mode 100644 index 00000000..24023ec2 --- /dev/null +++ b/src/ext/NetFx/netcoresearch/precomp.h | |||
@@ -0,0 +1,18 @@ | |||
1 | #pragma once | ||
2 | // 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. | ||
3 | |||
4 | #include <windows.h> | ||
5 | #include <msiquery.h> | ||
6 | #include <corerror.h> | ||
7 | |||
8 | #include <dutil.h> | ||
9 | #include <conutil.h> | ||
10 | #include <memutil.h> | ||
11 | #include <pathutil.h> | ||
12 | #include <strutil.h> | ||
13 | #include <verutil.h> | ||
14 | #include <xmlutil.h> | ||
15 | |||
16 | #include <hostfxr.h> | ||
17 | |||
18 | #include "netcoresearch.h" | ||
diff --git a/src/ext/NetFx/netfx.cmd b/src/ext/NetFx/netfx.cmd index 182630b3..65cd1dcb 100644 --- a/src/ext/NetFx/netfx.cmd +++ b/src/ext/NetFx/netfx.cmd | |||
@@ -2,14 +2,19 @@ | |||
2 | @pushd %~dp0 | 2 | @pushd %~dp0 |
3 | 3 | ||
4 | @set _C=Debug | 4 | @set _C=Debug |
5 | @set _L=%~dp0..\..\..\build\logs | ||
5 | :parse_args | 6 | :parse_args |
6 | @if /i "%1"=="release" set _C=Release | 7 | @if /i "%1"=="release" set _C=Release |
7 | @if not "%1"=="" shift & goto parse_args | 8 | @if not "%1"=="" shift & goto parse_args |
8 | 9 | ||
9 | @echo NetFx.wixext build %_C% | 10 | @echo NetFx.wixext build %_C% |
10 | 11 | ||
12 | :: Restore | ||
13 | nuget restore netcoresearch\packages.config || exit /b | ||
14 | msbuild -t:Restore -p:Configuration=%_C% || exit /b | ||
15 | |||
11 | :: Build | 16 | :: Build |
12 | msbuild -Restore -p:Configuration=%_C% || exit /b | 17 | msbuild -p:Configuration=%_C% -bl:%_L%\netfx_build.binlog || exit /b |
13 | 18 | ||
14 | :: Test | 19 | :: Test |
15 | dotnet test -c %_C% --no-build test\WixToolsetTest.Netfx || exit /b | 20 | dotnet test -c %_C% --no-build test\WixToolsetTest.Netfx || exit /b |
diff --git a/src/ext/NetFx/test/WixToolsetTest.Netfx/NetfxExtensionFixture.cs b/src/ext/NetFx/test/WixToolsetTest.Netfx/NetfxExtensionFixture.cs index 4b8b826e..8db3db46 100644 --- a/src/ext/NetFx/test/WixToolsetTest.Netfx/NetfxExtensionFixture.cs +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/NetfxExtensionFixture.cs | |||
@@ -25,6 +25,8 @@ namespace WixToolsetTest.Netfx | |||
25 | { | 25 | { |
26 | "build", | 26 | "build", |
27 | Path.Combine(bundleSourceFolder, "BundleLatest.wxs"), | 27 | Path.Combine(bundleSourceFolder, "BundleLatest.wxs"), |
28 | Path.Combine(bundleSourceFolder, "NetCore3.1.12_x86.wxs"), | ||
29 | Path.Combine(bundleSourceFolder, "NetCore3.1.12_x64.wxs"), | ||
28 | "-ext", TestData.Get(@"WixToolset.Bal.wixext.dll"), | 30 | "-ext", TestData.Get(@"WixToolset.Bal.wixext.dll"), |
29 | "-ext", TestData.Get(@"WixToolset.Netfx.wixext.dll"), | 31 | "-ext", TestData.Get(@"WixToolset.Netfx.wixext.dll"), |
30 | "-intermediateFolder", intermediateFolder, | 32 | "-intermediateFolder", intermediateFolder, |
@@ -50,6 +52,7 @@ namespace WixToolsetTest.Netfx | |||
50 | { | 52 | { |
51 | "build", | 53 | "build", |
52 | Path.Combine(bundleSourceFolder, "BundleLatest_x64.wxs"), | 54 | Path.Combine(bundleSourceFolder, "BundleLatest_x64.wxs"), |
55 | Path.Combine(bundleSourceFolder, "NetCore3.1.12_x64.wxs"), | ||
53 | "-ext", TestData.Get(@"WixToolset.Bal.wixext.dll"), | 56 | "-ext", TestData.Get(@"WixToolset.Bal.wixext.dll"), |
54 | "-ext", TestData.Get(@"WixToolset.Netfx.wixext.dll"), | 57 | "-ext", TestData.Get(@"WixToolset.Netfx.wixext.dll"), |
55 | "-intermediateFolder", intermediateFolder, | 58 | "-intermediateFolder", intermediateFolder, |
diff --git a/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest.wxs b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest.wxs index 8e3d2c30..b7b55747 100644 --- a/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest.wxs +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest.wxs | |||
@@ -1,12 +1,15 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal"> |
2 | <Bundle Name="WixStdBa" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="75D5D534-E177-4689-AAE9-CAC1C39002C2"> | 2 | <Bundle Name="WixStdBa" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="75D5D534-E177-4689-AAE9-CAC1C39002C2"> |
3 | <BootstrapperApplication> | 3 | <BootstrapperApplication> |
4 | <bal:WixStandardBootstrapperApplication LicenseUrl="http://wixtoolset.org/about/license/" Theme="hyperlinkLicense" /> | 4 | <bal:WixStandardBootstrapperApplication LicenseUrl="http://wixtoolset.org/about/license/" Theme="hyperlinkLicense" /> |
5 | </BootstrapperApplication> | 5 | </BootstrapperApplication> |
6 | <Chain> | 6 | <Chain> |
7 | <PackageGroupRef Id="AspNetCoreRuntime31Redist_x86" /> | 7 | <PackageGroupRef Id="AspNetCoreRuntime3112Redist_x86" /> |
8 | <PackageGroupRef Id="DesktopNetCoreRuntime31Redist_x86" /> | 8 | <PackageGroupRef Id="DesktopNetCoreRuntime3112Redist_x86" /> |
9 | <PackageGroupRef Id="DotNetCoreRuntime31Redist_x86" /> | 9 | <PackageGroupRef Id="DotNetCoreRuntime3112Redist_x86" /> |
10 | <PackageGroupRef Id="AspNetCoreRuntime3112Redist_x64" /> | ||
11 | <PackageGroupRef Id="DesktopNetCoreRuntime3112Redist_x64" /> | ||
12 | <PackageGroupRef Id="DotNetCoreRuntime3112Redist_x64" /> | ||
10 | </Chain> | 13 | </Chain> |
11 | </Bundle> | 14 | </Bundle> |
12 | </Wix> | 15 | </Wix> |
diff --git a/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest_x64.wxs b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest_x64.wxs index fc42ac99..3588686a 100644 --- a/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest_x64.wxs +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/BundleLatest_x64.wxs | |||
@@ -1,12 +1,12 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal"> | 1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal"> |
2 | <Bundle Name="WixStdBa" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="75D5D534-E177-4689-AAE9-CAC1C39002C2"> | 2 | <Bundle Name="WixStdBa" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="75D5D534-E177-4689-AAE9-CAC1C39002C2"> |
3 | <BootstrapperApplication> | 3 | <BootstrapperApplication> |
4 | <bal:WixStandardBootstrapperApplication LicenseUrl="http://wixtoolset.org/about/license/" Theme="hyperlinkLicense" /> | 4 | <bal:WixStandardBootstrapperApplication LicenseUrl="http://wixtoolset.org/about/license/" Theme="hyperlinkLicense" /> |
5 | </BootstrapperApplication> | 5 | </BootstrapperApplication> |
6 | <Chain> | 6 | <Chain> |
7 | <PackageGroupRef Id="AspNetCoreRuntime31Redist_x64" /> | 7 | <PackageGroupRef Id="AspNetCoreRuntime3112Redist_x64" /> |
8 | <PackageGroupRef Id="DesktopNetCoreRuntime31Redist_x64" /> | 8 | <PackageGroupRef Id="DesktopNetCoreRuntime3112Redist_x64" /> |
9 | <PackageGroupRef Id="DotNetCoreRuntime31Redist_x64" /> | 9 | <PackageGroupRef Id="DotNetCoreRuntime3112Redist_x64" /> |
10 | </Chain> | 10 | </Chain> |
11 | </Bundle> | 11 | </Bundle> |
12 | </Wix> | 12 | </Wix> |
diff --git a/src/ext/NetFx/wixlib/NetCore3.1.12_x64.wxs b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3.1.12_x64.wxs index 3a1f5910..20b266a5 100644 --- a/src/ext/NetFx/wixlib/NetCore3.1.12_x64.wxs +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3.1.12_x64.wxs | |||
@@ -1,6 +1,6 @@ | |||
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 | ||
3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> | 3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:netfx="http://wixtoolset.org/schemas/v4/wxs/netfx"> |
4 | 4 | ||
5 | <?define NetCorePlatform = x64?> | 5 | <?define NetCorePlatform = x64?> |
6 | <?define NetCoreIdVersion = 3112?> | 6 | <?define NetCoreIdVersion = 3112?> |
@@ -12,9 +12,9 @@ | |||
12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/2fdc3009-cf5c-4cf6-8f3b-a61e83200cbb/2c71ee04b48103a7464f4e28a8bf339b/dotnet-runtime-3.1.12-win-x64.exe?> | 12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/2fdc3009-cf5c-4cf6-8f3b-a61e83200cbb/2c71ee04b48103a7464f4e28a8bf339b/dotnet-runtime-3.1.12-win-x64.exe?> |
13 | 13 | ||
14 | <Fragment> | 14 | <Fragment> |
15 | <util:DirectorySearchRef Id="$(var.AspNetCoreId)" /> | 15 | <netfx:DotNetCoreSearch Id="$(var.AspNetCoreId)" RuntimeType="aspnet" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.AspNetCoreId)" /> |
16 | 16 | ||
17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId)" Overridable="yes" /> | 17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
@@ -27,9 +27,9 @@ | |||
27 | </Fragment> | 27 | </Fragment> |
28 | 28 | ||
29 | <Fragment> | 29 | <Fragment> |
30 | <util:DirectorySearchRef Id="$(var.DesktopNetCoreId)" /> | 30 | <netfx:DotNetCoreSearch Id="$(var.DesktopNetCoreId)" RuntimeType="desktop" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.DesktopNetCoreId)" /> |
31 | 31 | ||
32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId)" Overridable="yes" /> | 32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
@@ -42,9 +42,9 @@ | |||
42 | </Fragment> | 42 | </Fragment> |
43 | 43 | ||
44 | <Fragment> | 44 | <Fragment> |
45 | <util:DirectorySearchRef Id="$(var.DotNetCoreId)" /> | 45 | <netfx:DotNetCoreSearch Id="$(var.DotNetCoreId)" RuntimeType="core" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.DotNetCoreId)" /> |
46 | 46 | ||
47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId)" Overridable="yes" /> | 47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
diff --git a/src/ext/NetFx/wixlib/NetCore3.1.12_x86.wxs b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3.1.12_x86.wxs index e3a70daf..4bd97492 100644 --- a/src/ext/NetFx/wixlib/NetCore3.1.12_x86.wxs +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3.1.12_x86.wxs | |||
@@ -1,6 +1,6 @@ | |||
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 | ||
3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> | 3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:netfx="http://wixtoolset.org/schemas/v4/wxs/netfx"> |
4 | 4 | ||
5 | <?define NetCorePlatform = x86?> | 5 | <?define NetCorePlatform = x86?> |
6 | <?define NetCoreIdVersion = 3112?> | 6 | <?define NetCoreIdVersion = 3112?> |
@@ -12,9 +12,9 @@ | |||
12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/cbdd1603-7fa9-4957-8869-94e24963ba6c/ca0b7d1be494882d5a7433accfa3c94c/dotnet-runtime-3.1.12-win-x86.exe?> | 12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/cbdd1603-7fa9-4957-8869-94e24963ba6c/ca0b7d1be494882d5a7433accfa3c94c/dotnet-runtime-3.1.12-win-x86.exe?> |
13 | 13 | ||
14 | <Fragment> | 14 | <Fragment> |
15 | <util:DirectorySearchRef Id="$(var.AspNetCoreId)" /> | 15 | <netfx:DotNetCoreSearch Id="$(var.AspNetCoreId)" RuntimeType="aspnet" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.AspNetCoreId)" /> |
16 | 16 | ||
17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId)" Overridable="yes" /> | 17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
@@ -27,9 +27,9 @@ | |||
27 | </Fragment> | 27 | </Fragment> |
28 | 28 | ||
29 | <Fragment> | 29 | <Fragment> |
30 | <util:DirectorySearchRef Id="$(var.DesktopNetCoreId)" /> | 30 | <netfx:DotNetCoreSearch Id="$(var.DesktopNetCoreId)" RuntimeType="desktop" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.DesktopNetCoreId)" /> |
31 | 31 | ||
32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId)" Overridable="yes" /> | 32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
@@ -42,9 +42,9 @@ | |||
42 | </Fragment> | 42 | </Fragment> |
43 | 43 | ||
44 | <Fragment> | 44 | <Fragment> |
45 | <util:DirectorySearchRef Id="$(var.DotNetCoreId)" /> | 45 | <netfx:DotNetCoreSearch Id="$(var.DotNetCoreId)" RuntimeType="core" Platform="$(var.NetCorePlatform)" MajorVersion="3" Variable="$(var.DotNetCoreId)" /> |
46 | 46 | ||
47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId)" Overridable="yes" /> | 47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId) >= v$(var.NetCoreVersion)" Overridable="yes" /> |
48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | 48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> |
49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | 49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> |
50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | 50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> |
diff --git a/src/ext/NetFx/wixlib/NetCore3_Platform.wxi b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3_Platform.wxi index 88e672be..f0b97d33 100644 --- a/src/ext/NetFx/wixlib/NetCore3_Platform.wxi +++ b/src/ext/NetFx/test/WixToolsetTest.Netfx/TestData/UsingDotNetCorePackages/NetCore3_Platform.wxi | |||
@@ -1,45 +1,29 @@ | |||
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 | ||
3 | 3 | ||
4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> | 4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> |
5 | 5 | ||
6 | <?define AspNetCoreId = ASPNETCORERUNTIME$(var.NetCoreIdVersion)_$(var.NetCorePlatform)?> | 6 | <?define AspNetCoreId = ASPNETCORERUNTIME3_$(var.NetCorePlatform)?> |
7 | <?define AspNetCoreRedistId = AspNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | 7 | <?define AspNetCoreRedistId = AspNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> |
8 | <?define AspNetCoreRedistLog = AspNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | 8 | <?define AspNetCoreRedistLog = AspNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> |
9 | <?define AspNetCoreRedistInstallArguments = /install /quiet /log "[$(var.AspNetCoreRedistLog)]"?> | 9 | <?define AspNetCoreRedistInstallArguments = /install /quiet /log "[$(var.AspNetCoreRedistLog)]"?> |
10 | <?define AspNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.AspNetCoreRedistLog)]"?> | 10 | <?define AspNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.AspNetCoreRedistLog)]"?> |
11 | 11 | ||
12 | <?define DesktopNetCoreId = DESKTOPNETCORERUNTIME$(var.NetCoreIdVersion)_$(var.NetCorePlatform)?> | 12 | <?define DesktopNetCoreId = DESKTOPNETCORERUNTIME3_$(var.NetCorePlatform)?> |
13 | <?define DesktopNetCoreRedistId = DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | 13 | <?define DesktopNetCoreRedistId = DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> |
14 | <?define DesktopNetCoreRedistLog = DesktopNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | 14 | <?define DesktopNetCoreRedistLog = DesktopNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> |
15 | <?define DesktopNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> | 15 | <?define DesktopNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> |
16 | <?define DesktopNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> | 16 | <?define DesktopNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> |
17 | 17 | ||
18 | <?define DotNetCoreId = DOTNETCORERUNTIME$(var.NetCoreIdVersion)_$(var.NetCorePlatform)?> | 18 | <?define DotNetCoreId = DOTNETCORERUNTIME3_$(var.NetCorePlatform)?> |
19 | <?define DotNetCoreRedistId = DotNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | 19 | <?define DotNetCoreRedistId = DotNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> |
20 | <?define DotNetCoreRedistLog = DotNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | 20 | <?define DotNetCoreRedistLog = DotNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> |
21 | <?define DotNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DotNetCoreRedistLog)]"?> | 21 | <?define DotNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DotNetCoreRedistLog)]"?> |
22 | <?define DotNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DotNetCoreRedistLog)]"?> | 22 | <?define DotNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DotNetCoreRedistLog)]"?> |
23 | 23 | ||
24 | <?define DotNetHomeId = DOTNETHOME_$(var.NetCorePlatform)?> | ||
25 | <?define NetCoreEulaLink = https://go.microsoft.com/fwlink/?LinkId=329770?> | 24 | <?define NetCoreEulaLink = https://go.microsoft.com/fwlink/?LinkId=329770?> |
26 | 25 | ||
27 | <Fragment> | 26 | <Fragment> |
28 | <util:RegistrySearchRef Id="$(var.DotNetHomeId)" /> | ||
29 | <util:DirectorySearch Id="$(var.AspNetCoreId)" Variable="$(var.AspNetCoreId)" Path="[$(var.DotNetHomeId)]\shared\Microsoft.AspNetCore.App\$(var.NetCoreVersion)" Result="exists" After="$(var.DotNetHomeId)" /> | ||
30 | </Fragment> | ||
31 | |||
32 | <Fragment> | ||
33 | <util:RegistrySearchRef Id="$(var.DotNetHomeId)" /> | ||
34 | <util:DirectorySearch Id="$(var.DesktopNetCoreId)" Variable="$(var.DesktopNetCoreId)" Path="[$(var.DotNetHomeId)]\shared\Microsoft.WindowsDesktop.App\$(var.NetCoreVersion)" Result="exists" After="$(var.DotNetHomeId)" /> | ||
35 | </Fragment> | ||
36 | |||
37 | <Fragment> | ||
38 | <util:RegistrySearchRef Id="$(var.DotNetHomeId)" /> | ||
39 | <util:DirectorySearch Id="$(var.DotNetCoreId)" Variable="$(var.DotNetCoreId)" Path="[$(var.DotNetHomeId)]\shared\Microsoft.NETCore.App\$(var.NetCoreVersion)" Result="exists" After="$(var.DotNetHomeId)" /> | ||
40 | </Fragment> | ||
41 | |||
42 | <Fragment> | ||
43 | <PackageGroup Id="$(var.AspNetCoreRedistId)AsPrereq"> | 27 | <PackageGroup Id="$(var.AspNetCoreRedistId)AsPrereq"> |
44 | <PackageGroupRef Id="$(var.AspNetCoreRedistId)" /> | 28 | <PackageGroupRef Id="$(var.AspNetCoreRedistId)" /> |
45 | </PackageGroup> | 29 | </PackageGroup> |
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 | ||
3 | namespace 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 | |||
3 | namespace WixToolset.Netfx.Symbols | 24 | namespace 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 | |||
3 | namespace 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 | |||
22 | namespace 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 | ||
3 | namespace WixToolset.Netfx.Symbols | 3 | namespace 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 | } |
diff --git a/src/ext/NetFx/wixlib/NetCore3.1_x64.wxs b/src/ext/NetFx/wixlib/NetCore3.1_x64.wxs deleted file mode 100644 index 60d7c27f..00000000 --- a/src/ext/NetFx/wixlib/NetCore3.1_x64.wxs +++ /dev/null | |||
@@ -1,22 +0,0 @@ | |||
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 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
4 | |||
5 | <Fragment> | ||
6 | <PackageGroup Id="AspNetCoreRuntime31Redist_x64"> | ||
7 | <PackageGroupRef Id="AspNetCoreRuntime3112Redist_x64" /> | ||
8 | </PackageGroup> | ||
9 | </Fragment> | ||
10 | |||
11 | <Fragment> | ||
12 | <PackageGroup Id="DesktopNetCoreRuntime31Redist_x64"> | ||
13 | <PackageGroupRef Id="DesktopNetCoreRuntime3112Redist_x64" /> | ||
14 | </PackageGroup> | ||
15 | </Fragment> | ||
16 | |||
17 | <Fragment> | ||
18 | <PackageGroup Id="DotNetCoreRuntime31Redist_x64"> | ||
19 | <PackageGroupRef Id="DotNetCoreRuntime3112Redist_x64" /> | ||
20 | </PackageGroup> | ||
21 | </Fragment> | ||
22 | </Wix> | ||
diff --git a/src/ext/NetFx/wixlib/NetCore3.1_x86.wxs b/src/ext/NetFx/wixlib/NetCore3.1_x86.wxs deleted file mode 100644 index cfff07b3..00000000 --- a/src/ext/NetFx/wixlib/NetCore3.1_x86.wxs +++ /dev/null | |||
@@ -1,22 +0,0 @@ | |||
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 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
4 | |||
5 | <Fragment> | ||
6 | <PackageGroup Id="AspNetCoreRuntime31Redist_x86"> | ||
7 | <PackageGroupRef Id="AspNetCoreRuntime3112Redist_x86" /> | ||
8 | </PackageGroup> | ||
9 | </Fragment> | ||
10 | |||
11 | <Fragment> | ||
12 | <PackageGroup Id="DesktopNetCoreRuntime31Redist_x86"> | ||
13 | <PackageGroupRef Id="DesktopNetCoreRuntime3112Redist_x86" /> | ||
14 | </PackageGroup> | ||
15 | </Fragment> | ||
16 | |||
17 | <Fragment> | ||
18 | <PackageGroup Id="DotNetCoreRuntime31Redist_x86"> | ||
19 | <PackageGroupRef Id="DotNetCoreRuntime3112Redist_x86" /> | ||
20 | </PackageGroup> | ||
21 | </Fragment> | ||
22 | </Wix> | ||
diff --git a/src/ext/NetFx/wixlib/NetCoreShared.wxs b/src/ext/NetFx/wixlib/NetCoreShared.wxs index 2045a5b9..51667117 100644 --- a/src/ext/NetFx/wixlib/NetCoreShared.wxs +++ b/src/ext/NetFx/wixlib/NetCoreShared.wxs | |||
@@ -1,8 +1,8 @@ | |||
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 | ||
3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> | 3 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> |
4 | 4 | ||
5 | <?foreach PLATFORM in x86;x64?> | 5 | <?foreach PLATFORM in x86;x64;arm64?> |
6 | <Fragment> | 6 | <Fragment> |
7 | <util:RegistrySearch Id="DOTNETHOME_$(var.PLATFORM)" Variable="DOTNETHOME_$(var.PLATFORM)" Root="HKLM" Key="SOFTWARE\dotnet\Setup\InstalledVersions\$(var.PLATFORM)" Value="InstallLocation" Result="value" Bitness="always32" /> | 7 | <util:RegistrySearch Id="DOTNETHOME_$(var.PLATFORM)" Variable="DOTNETHOME_$(var.PLATFORM)" Root="HKLM" Key="SOFTWARE\dotnet\Setup\InstalledVersions\$(var.PLATFORM)" Value="InstallLocation" Result="value" Bitness="always32" /> |
8 | </Fragment> | 8 | </Fragment> |
diff --git a/src/ext/NetFx/wixlib/NetfxBundleExtension_Platform.wxi b/src/ext/NetFx/wixlib/NetfxBundleExtension_Platform.wxi new file mode 100644 index 00000000..e3300534 --- /dev/null +++ b/src/ext/NetFx/wixlib/NetfxBundleExtension_Platform.wxi | |||
@@ -0,0 +1,15 @@ | |||
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 | |||
4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?include ..\..\caDecor.wxi ?> | ||
6 | |||
7 | <Fragment> | ||
8 | <BundleExtension Id="$(var.Prefix)NetfxBundleExtension$(var.Suffix)" SourceFile="!(bindpath.$(var.platform))netfxbe.dll" Name="$(var.Prefix)NetfxBundleExtension$(var.Suffix)\netfxbe.dll"> | ||
9 | <?foreach PLATFORM in x86;x64;arm64?> | ||
10 | <Payload SourceFile="!(bindpath.$(var.PLATFORM))netcoresearch.exe" Name="$(var.Prefix)NetfxBundleExtension$(var.Suffix)\$(var.PLATFORM)\netcoresearch.exe" /> | ||
11 | <Payload SourceFile="!(bindpath.$(var.PLATFORM))hostfxr.dll" Name="$(var.Prefix)NetfxBundleExtension$(var.Suffix)\$(var.PLATFORM)\hostfxr.dll" /> | ||
12 | <?endforeach?> | ||
13 | </BundleExtension> | ||
14 | </Fragment> | ||
15 | </Include> | ||
diff --git a/src/ext/NetFx/wixlib/NetfxBundleExtension_arm64.wxs b/src/ext/NetFx/wixlib/NetfxBundleExtension_arm64.wxs new file mode 100644 index 00000000..13757dd8 --- /dev/null +++ b/src/ext/NetFx/wixlib/NetfxBundleExtension_arm64.wxs | |||
@@ -0,0 +1,7 @@ | |||
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 | |||
4 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?define platform=arm64 ?> | ||
6 | <?include NetfxBundleExtension_Platform.wxi ?> | ||
7 | </Wix> | ||
diff --git a/src/ext/NetFx/wixlib/NetfxBundleExtension_x64.wxs b/src/ext/NetFx/wixlib/NetfxBundleExtension_x64.wxs new file mode 100644 index 00000000..f6c27a8e --- /dev/null +++ b/src/ext/NetFx/wixlib/NetfxBundleExtension_x64.wxs | |||
@@ -0,0 +1,7 @@ | |||
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 | |||
4 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?define platform=x64 ?> | ||
6 | <?include NetfxBundleExtension_Platform.wxi ?> | ||
7 | </Wix> | ||
diff --git a/src/ext/NetFx/wixlib/NetfxBundleExtension_x86.wxs b/src/ext/NetFx/wixlib/NetfxBundleExtension_x86.wxs new file mode 100644 index 00000000..76a8358f --- /dev/null +++ b/src/ext/NetFx/wixlib/NetfxBundleExtension_x86.wxs | |||
@@ -0,0 +1,7 @@ | |||
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 | |||
4 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
5 | <?define platform=x86 ?> | ||
6 | <?include NetfxBundleExtension_Platform.wxi ?> | ||
7 | </Wix> | ||
diff --git a/src/ext/NetFx/wixlib/netfx.wixproj b/src/ext/NetFx/wixlib/netfx.wixproj index ad7d028c..bc6a1172 100644 --- a/src/ext/NetFx/wixlib/netfx.wixproj +++ b/src/ext/NetFx/wixlib/netfx.wixproj | |||
@@ -14,9 +14,15 @@ | |||
14 | </ItemGroup> | 14 | </ItemGroup> |
15 | 15 | ||
16 | <ItemGroup> | 16 | <ItemGroup> |
17 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=ARM64" ReferenceOutputAssembly="false" /> | 17 | <ProjectReference Include="..\be\netfxbe.vcxproj" Properties="Platform=ARM64" /> |
18 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=x86" ReferenceOutputAssembly="false" /> | 18 | <ProjectReference Include="..\be\netfxbe.vcxproj" Properties="Platform=x64" /> |
19 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=x64" ReferenceOutputAssembly="false" /> | 19 | <ProjectReference Include="..\be\netfxbe.vcxproj" Properties="Platform=x86" /> |
20 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=ARM64" /> | ||
21 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=x86" /> | ||
22 | <ProjectReference Include="..\ca\netfxca.vcxproj" Properties="Platform=x64" /> | ||
23 | <ProjectReference Include="..\netcoresearch\netcoresearch.vcxproj" Properties="Platform=ARM64" /> | ||
24 | <ProjectReference Include="..\netcoresearch\netcoresearch.vcxproj" Properties="Platform=x86" /> | ||
25 | <ProjectReference Include="..\netcoresearch\netcoresearch.vcxproj" Properties="Platform=x64" /> | ||
20 | </ItemGroup> | 26 | </ItemGroup> |
21 | 27 | ||
22 | <ItemGroup> | 28 | <ItemGroup> |
diff --git a/src/ext/Util/be/UtilBundleExtension.cpp b/src/ext/Util/be/UtilBundleExtension.cpp index 110599fa..23f5d94f 100644 --- a/src/ext/Util/be/UtilBundleExtension.cpp +++ b/src/ext/Util/be/UtilBundleExtension.cpp | |||
@@ -28,16 +28,16 @@ public: //CBextBaseBundleExtension | |||
28 | IXMLDOMNode* pixnBundleExtension = NULL; | 28 | IXMLDOMNode* pixnBundleExtension = NULL; |
29 | 29 | ||
30 | hr = __super::Initialize(pCreateArgs); | 30 | hr = __super::Initialize(pCreateArgs); |
31 | ExitOnFailure(hr, "CBextBaseBundleExtension initialization failed."); | 31 | BextExitOnFailure(hr, "CBextBaseBundleExtension initialization failed."); |
32 | 32 | ||
33 | hr = XmlLoadDocumentFromFile(m_sczBundleExtensionDataPath, &pixdManifest); | 33 | hr = XmlLoadDocumentFromFile(m_sczBundleExtensionDataPath, &pixdManifest); |
34 | ExitOnFailure(hr, "Failed to load bundle extension manifest from path: %ls", m_sczBundleExtensionDataPath); | 34 | BextExitOnFailure(hr, "Failed to load bundle extension manifest from path: %ls", m_sczBundleExtensionDataPath); |
35 | 35 | ||
36 | hr = BextGetBundleExtensionDataNode(pixdManifest, UTIL_BUNDLE_EXTENSION_ID, &pixnBundleExtension); | 36 | hr = BextGetBundleExtensionDataNode(pixdManifest, UTIL_BUNDLE_EXTENSION_ID, &pixnBundleExtension); |
37 | ExitOnFailure(hr, "Failed to get BundleExtension '%ls'", UTIL_BUNDLE_EXTENSION_ID); | 37 | BextExitOnFailure(hr, "Failed to get BundleExtension '%ls'", UTIL_BUNDLE_EXTENSION_ID); |
38 | 38 | ||
39 | hr = UtilSearchParseFromXml(&m_searches, pixnBundleExtension); | 39 | hr = UtilSearchParseFromXml(&m_searches, pixnBundleExtension); |
40 | ExitOnFailure(hr, "Failed to parse searches from bundle extension manifest."); | 40 | BextExitOnFailure(hr, "Failed to parse searches from bundle extension manifest."); |
41 | 41 | ||
42 | LExit: | 42 | LExit: |
43 | ReleaseObject(pixnBundleExtension); | 43 | ReleaseObject(pixnBundleExtension); |
@@ -73,10 +73,10 @@ HRESULT UtilBundleExtensionCreate( | |||
73 | CWixUtilBundleExtension* pExtension = NULL; | 73 | CWixUtilBundleExtension* pExtension = NULL; |
74 | 74 | ||
75 | pExtension = new CWixUtilBundleExtension(pEngine); | 75 | pExtension = new CWixUtilBundleExtension(pEngine); |
76 | ExitOnNull(pExtension, hr, E_OUTOFMEMORY, "Failed to create new CWixUtilBundleExtension."); | 76 | BextExitOnNull(pExtension, hr, E_OUTOFMEMORY, "Failed to create new CWixUtilBundleExtension."); |
77 | 77 | ||
78 | hr = pExtension->Initialize(pArgs); | 78 | hr = pExtension->Initialize(pArgs); |
79 | ExitOnFailure(hr, "CWixUtilBundleExtension initialization failed."); | 79 | BextExitOnFailure(hr, "CWixUtilBundleExtension initialization failed."); |
80 | 80 | ||
81 | *ppBundleExtension = pExtension; | 81 | *ppBundleExtension = pExtension; |
82 | pExtension = NULL; | 82 | pExtension = NULL; |
diff --git a/src/ext/Util/be/detectsha2support.cpp b/src/ext/Util/be/detectsha2support.cpp index 90e349cd..4abfc63c 100644 --- a/src/ext/Util/be/detectsha2support.cpp +++ b/src/ext/Util/be/detectsha2support.cpp | |||
@@ -13,7 +13,7 @@ HRESULT DetectSHA2CodeSigning( | |||
13 | DWORD er = ERROR_SUCCESS; | 13 | DWORD er = ERROR_SUCCESS; |
14 | 14 | ||
15 | hr = LoadSystemLibrary(L"wintrust.dll", &hModule); | 15 | hr = LoadSystemLibrary(L"wintrust.dll", &hModule); |
16 | ExitOnFailure(hr, "Failed to load wintrust.dll"); | 16 | BextExitOnFailure(hr, "Failed to load wintrust.dll"); |
17 | 17 | ||
18 | pfn = ::GetProcAddress(hModule, "CryptCATAdminAcquireContext2"); | 18 | pfn = ::GetProcAddress(hModule, "CryptCATAdminAcquireContext2"); |
19 | if (pfn) | 19 | if (pfn) |
@@ -30,7 +30,7 @@ HRESULT DetectSHA2CodeSigning( | |||
30 | } | 30 | } |
31 | 31 | ||
32 | hr = HRESULT_FROM_WIN32(er); | 32 | hr = HRESULT_FROM_WIN32(er); |
33 | ExitOnFailure(hr, "Failed to probe for CryptCATAdminAcquireContext2 in wintrust.dll"); | 33 | BextExitOnFailure(hr, "Failed to probe for CryptCATAdminAcquireContext2 in wintrust.dll"); |
34 | 34 | ||
35 | LExit: | 35 | LExit: |
36 | ::FreeLibrary(hModule); | 36 | ::FreeLibrary(hModule); |
@@ -48,10 +48,10 @@ HRESULT UtilPerformDetectSHA2CodeSigning( | |||
48 | BOOL fSupported = FALSE; | 48 | BOOL fSupported = FALSE; |
49 | 49 | ||
50 | hr = DetectSHA2CodeSigning(&fSupported); | 50 | hr = DetectSHA2CodeSigning(&fSupported); |
51 | ExitOnFailure(hr, "DetectSHA2CodeSigning failed."); | 51 | BextExitOnFailure(hr, "DetectSHA2CodeSigning failed."); |
52 | 52 | ||
53 | hr = pEngine->SetVariableNumeric(wzVariable, fSupported ? 1 : 0); | 53 | hr = pEngine->SetVariableNumeric(wzVariable, fSupported ? 1 : 0); |
54 | ExitOnFailure(hr, "Failed to set variable '%ls'", wzVariable); | 54 | BextExitOnFailure(hr, "Failed to set variable '%ls'", wzVariable); |
55 | 55 | ||
56 | LExit: | 56 | LExit: |
57 | return hr; | 57 | return hr; |
diff --git a/src/ext/Util/be/precomp.h b/src/ext/Util/be/precomp.h index bb36b3f3..5ce5744f 100644 --- a/src/ext/Util/be/precomp.h +++ b/src/ext/Util/be/precomp.h | |||
@@ -31,7 +31,7 @@ | |||
31 | #include <bextutil.h> | 31 | #include <bextutil.h> |
32 | #include <BextBundleExtensionEngine.h> | 32 | #include <BextBundleExtensionEngine.h> |
33 | 33 | ||
34 | #include "beDecor.h" | 34 | #include "..\..\beDecor.h" |
35 | #include "utilsearch.h" | 35 | #include "utilsearch.h" |
36 | #include "detectsha2support.h" | 36 | #include "detectsha2support.h" |
37 | #include "UtilBundleExtension.h" | 37 | #include "UtilBundleExtension.h" |
diff --git a/src/ext/Util/be/utilbe.vcxproj b/src/ext/Util/be/utilbe.vcxproj index 4e4f80d9..fa39dcf3 100644 --- a/src/ext/Util/be/utilbe.vcxproj +++ b/src/ext/Util/be/utilbe.vcxproj | |||
@@ -56,7 +56,6 @@ | |||
56 | </ItemGroup> | 56 | </ItemGroup> |
57 | 57 | ||
58 | <ItemGroup> | 58 | <ItemGroup> |
59 | <ClInclude Include="beDecor.h" /> | ||
60 | <ClInclude Include="detectsha2support.h" /> | 59 | <ClInclude Include="detectsha2support.h" /> |
61 | <ClInclude Include="precomp.h" /> | 60 | <ClInclude Include="precomp.h" /> |
62 | <ClInclude Include="UtilBundleExtension.h" /> | 61 | <ClInclude Include="UtilBundleExtension.h" /> |
diff --git a/src/ext/Util/be/utilsearch.cpp b/src/ext/Util/be/utilsearch.cpp index 7cd2ea09..20a514d8 100644 --- a/src/ext/Util/be/utilsearch.cpp +++ b/src/ext/Util/be/utilsearch.cpp | |||
@@ -17,11 +17,11 @@ STDMETHODIMP UtilSearchParseFromXml( | |||
17 | 17 | ||
18 | // Select Util search nodes. | 18 | // Select Util search nodes. |
19 | hr = XmlSelectNodes(pixnBundleExtension, L"WixWindowsFeatureSearch", &pixnNodes); | 19 | hr = XmlSelectNodes(pixnBundleExtension, L"WixWindowsFeatureSearch", &pixnNodes); |
20 | ExitOnFailure(hr, "Failed to select Util search nodes."); | 20 | BextExitOnFailure(hr, "Failed to select Util search nodes."); |
21 | 21 | ||
22 | // Get Util search node count. | 22 | // Get Util search node count. |
23 | hr = pixnNodes->get_length((long*)&cNodes); | 23 | hr = pixnNodes->get_length((long*)&cNodes); |
24 | ExitOnFailure(hr, "Failed to get Util search node count."); | 24 | BextExitOnFailure(hr, "Failed to get Util search node count."); |
25 | 25 | ||
26 | if (!cNodes) | 26 | if (!cNodes) |
27 | { | 27 | { |
@@ -30,7 +30,7 @@ STDMETHODIMP UtilSearchParseFromXml( | |||
30 | 30 | ||
31 | // Allocate memory for searches. | 31 | // Allocate memory for searches. |
32 | pSearches->rgSearches = (UTIL_SEARCH*)MemAlloc(sizeof(UTIL_SEARCH) * cNodes, TRUE); | 32 | pSearches->rgSearches = (UTIL_SEARCH*)MemAlloc(sizeof(UTIL_SEARCH) * cNodes, TRUE); |
33 | ExitOnNull(pSearches->rgSearches, hr, E_OUTOFMEMORY, "Failed to allocate memory for search structs."); | 33 | BextExitOnNull(pSearches->rgSearches, hr, E_OUTOFMEMORY, "Failed to allocate memory for search structs."); |
34 | 34 | ||
35 | pSearches->cSearches = cNodes; | 35 | pSearches->cSearches = cNodes; |
36 | 36 | ||
@@ -40,11 +40,11 @@ STDMETHODIMP UtilSearchParseFromXml( | |||
40 | UTIL_SEARCH* pSearch = &pSearches->rgSearches[i]; | 40 | UTIL_SEARCH* pSearch = &pSearches->rgSearches[i]; |
41 | 41 | ||
42 | hr = XmlNextElement(pixnNodes, &pixnNode, &bstrNodeName); | 42 | hr = XmlNextElement(pixnNodes, &pixnNode, &bstrNodeName); |
43 | ExitOnFailure(hr, "Failed to get next node."); | 43 | BextExitOnFailure(hr, "Failed to get next node."); |
44 | 44 | ||
45 | // @Id | 45 | // @Id |
46 | hr = XmlGetAttributeEx(pixnNode, L"Id", &pSearch->sczId); | 46 | hr = XmlGetAttributeEx(pixnNode, L"Id", &pSearch->sczId); |
47 | ExitOnFailure(hr, "Failed to get @Id."); | 47 | BextExitOnFailure(hr, "Failed to get @Id."); |
48 | 48 | ||
49 | // Read type specific attributes. | 49 | // Read type specific attributes. |
50 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, bstrNodeName, -1, L"WixWindowsFeatureSearch", -1)) | 50 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, bstrNodeName, -1, L"WixWindowsFeatureSearch", -1)) |
@@ -53,7 +53,7 @@ STDMETHODIMP UtilSearchParseFromXml( | |||
53 | 53 | ||
54 | // @Type | 54 | // @Type |
55 | hr = XmlGetAttributeEx(pixnNode, L"Type", &scz); | 55 | hr = XmlGetAttributeEx(pixnNode, L"Type", &scz); |
56 | ExitOnFailure(hr, "Failed to get @Type."); | 56 | BextExitOnFailure(hr, "Failed to get @Type."); |
57 | 57 | ||
58 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, scz, -1, L"sha2CodeSigning", -1)) | 58 | if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, scz, -1, L"sha2CodeSigning", -1)) |
59 | { | 59 | { |
@@ -61,14 +61,12 @@ STDMETHODIMP UtilSearchParseFromXml( | |||
61 | } | 61 | } |
62 | else | 62 | else |
63 | { | 63 | { |
64 | hr = E_INVALIDARG; | 64 | BextExitWithRootFailure(hr, E_INVALIDARG, "Invalid value for @Type: %ls", scz); |
65 | ExitOnFailure(hr, "Invalid value for @Type: %ls", scz); | ||
66 | } | 65 | } |
67 | } | 66 | } |
68 | else | 67 | else |
69 | { | 68 | { |
70 | hr = E_UNEXPECTED; | 69 | BextExitWithRootFailure(hr, E_UNEXPECTED, "Unexpected element name: %ls", bstrNodeName); |
71 | ExitOnFailure(hr, "Unexpected element name: %ls", bstrNodeName); | ||
72 | } | 70 | } |
73 | 71 | ||
74 | // prepare next iteration | 72 | // prepare next iteration |
@@ -112,7 +110,7 @@ STDMETHODIMP UtilSearchExecute( | |||
112 | UTIL_SEARCH* pSearch = NULL; | 110 | UTIL_SEARCH* pSearch = NULL; |
113 | 111 | ||
114 | hr = UtilSearchFindById(pSearches, wzSearchId, &pSearch); | 112 | hr = UtilSearchFindById(pSearches, wzSearchId, &pSearch); |
115 | ExitOnFailure(hr, "Search id '%ls' is unknown to the util extension."); | 113 | BextExitOnFailure(hr, "Search id '%ls' is unknown to the util extension.", wzSearchId); |
116 | 114 | ||
117 | switch (pSearch->Type) | 115 | switch (pSearch->Type) |
118 | { | 116 | { |
diff --git a/src/ext/Util/wixext/Symbols/UtilSymbolDefinitions.cs b/src/ext/Util/wixext/Symbols/UtilSymbolDefinitions.cs index 72091c3b..3b357a96 100644 --- a/src/ext/Util/wixext/Symbols/UtilSymbolDefinitions.cs +++ b/src/ext/Util/wixext/Symbols/UtilSymbolDefinitions.cs | |||
@@ -33,8 +33,6 @@ namespace WixToolset.Util | |||
33 | 33 | ||
34 | public static partial class UtilSymbolDefinitions | 34 | public static partial class UtilSymbolDefinitions |
35 | { | 35 | { |
36 | public static readonly Version Version = new Version("4.0.0"); | ||
37 | |||
38 | public static IntermediateSymbolDefinition ByName(string name) | 36 | public static IntermediateSymbolDefinition ByName(string name) |
39 | { | 37 | { |
40 | if (!Enum.TryParse(name, out UtilSymbolDefinitionType type)) | 38 | if (!Enum.TryParse(name, out UtilSymbolDefinitionType type)) |
diff --git a/src/ext/Util/be/beDecor.h b/src/ext/beDecor.h index 2c6a8818..2c6a8818 100644 --- a/src/ext/Util/be/beDecor.h +++ b/src/ext/beDecor.h | |||
diff --git a/src/libs/dutil/WixToolset.DUtil/inc/procutil.h b/src/libs/dutil/WixToolset.DUtil/inc/procutil.h index 6a641a5b..e7e91705 100644 --- a/src/libs/dutil/WixToolset.DUtil/inc/procutil.h +++ b/src/libs/dutil/WixToolset.DUtil/inc/procutil.h | |||
@@ -62,6 +62,7 @@ HRESULT DAPI ProcExec( | |||
62 | __out HANDLE *phProcess | 62 | __out HANDLE *phProcess |
63 | ); | 63 | ); |
64 | HRESULT DAPI ProcExecute( | 64 | HRESULT DAPI ProcExecute( |
65 | __in_z_opt LPCWSTR wzApplicationName, | ||
65 | __in_z LPWSTR wzCommand, | 66 | __in_z LPWSTR wzCommand, |
66 | __out HANDLE *phProcess, | 67 | __out HANDLE *phProcess, |
67 | __out_opt HANDLE *phChildStdIn, | 68 | __out_opt HANDLE *phChildStdIn, |
@@ -73,7 +74,7 @@ HRESULT DAPI ProcWaitForCompletion( | |||
73 | __out_opt DWORD* pdwReturnCode | 74 | __out_opt DWORD* pdwReturnCode |
74 | ); | 75 | ); |
75 | HRESULT DAPI ProcWaitForIds( | 76 | HRESULT DAPI ProcWaitForIds( |
76 | __in_ecount(cProcessIds) const DWORD* pdwProcessIds, | 77 | __in_ecount(cProcessIds) const DWORD rgdwProcessIds[], |
77 | __in DWORD cProcessIds, | 78 | __in DWORD cProcessIds, |
78 | __in DWORD dwMilliseconds | 79 | __in DWORD dwMilliseconds |
79 | ); | 80 | ); |
diff --git a/src/libs/dutil/WixToolset.DUtil/procutil.cpp b/src/libs/dutil/WixToolset.DUtil/procutil.cpp index 376aec6d..f96a1999 100644 --- a/src/libs/dutil/WixToolset.DUtil/procutil.cpp +++ b/src/libs/dutil/WixToolset.DUtil/procutil.cpp | |||
@@ -375,6 +375,7 @@ LExit: | |||
375 | 375 | ||
376 | *******************************************************************/ | 376 | *******************************************************************/ |
377 | extern "C" HRESULT DAPI ProcExecute( | 377 | extern "C" HRESULT DAPI ProcExecute( |
378 | __in_z_opt LPCWSTR wzApplicationName, | ||
378 | __in_z LPWSTR wzCommand, | 379 | __in_z LPWSTR wzCommand, |
379 | __out HANDLE *phProcess, | 380 | __out HANDLE *phProcess, |
380 | __out_opt HANDLE *phChildStdIn, | 381 | __out_opt HANDLE *phChildStdIn, |
@@ -405,7 +406,7 @@ extern "C" HRESULT DAPI ProcExecute( | |||
405 | 406 | ||
406 | #pragma prefast(push) | 407 | #pragma prefast(push) |
407 | #pragma prefast(disable:25028) | 408 | #pragma prefast(disable:25028) |
408 | if (::CreateProcessW(NULL, | 409 | if (::CreateProcessW(wzApplicationName, |
409 | wzCommand, // command line | 410 | wzCommand, // command line |
410 | NULL, // security info | 411 | NULL, // security info |
411 | NULL, // thread info | 412 | NULL, // thread info |
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6.0.9_x86.wxs b/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6.0.9_x86.wxs new file mode 100644 index 00000000..6bfef872 --- /dev/null +++ b/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6.0.9_x86.wxs | |||
@@ -0,0 +1,58 @@ | |||
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 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:netfx="http://wixtoolset.org/schemas/v4/wxs/netfx"> | ||
4 | |||
5 | <?define NetCorePlatform = x86?> | ||
6 | <?define NetCoreIdVersion = 609?> | ||
7 | <?define NetCoreVersion = 6.0.9?> | ||
8 | <?include NetCore6_Platform.wxi?> | ||
9 | |||
10 | <?define AspNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/8f583028-b802-4661-b8dd-47139b0561ce/3c0cd3bdc6051759ccae40f78982c86e/aspnetcore-runtime-6.0.9-win-x86.exe?> | ||
11 | <?define DesktopNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/925f9407-2767-4341-857a-43cdfad71e17/0b84db913bdbb1dcf02db937a3cd3f63/windowsdesktop-runtime-6.0.9-win-x86.exe?> | ||
12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/6020f3fc-5cf8-4e25-bc7f-dcf8744137ac/4cb5ced4e015e426fddc554b130c3052/dotnet-runtime-6.0.9-win-x86.exe?> | ||
13 | |||
14 | <Fragment> | ||
15 | <netfx:DotNetCoreSearch Id="$(var.AspNetCoreId)" RuntimeType="aspnet" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.AspNetCoreId)" /> | ||
16 | |||
17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId)" Overridable="yes" /> | ||
18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
21 | |||
22 | <PackageGroup Id="$(var.AspNetCoreRedistId)"> | ||
23 | <ExePackage InstallArguments="$(var.AspNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.AspNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.AspNetCoreRedistLog)" Cache="remove"> | ||
24 | <ExePackagePayload Name="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)aspnetcore-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.AspNetCoreRedistLink)" ProductName="Microsoft ASP.NET Core 6.0.9 - Shared Framework (x86)" Description="Microsoft ASP.NET Core 6.0.9 - Shared Framework (x86)" Hash="493D9A5388A0E6BEF4FED091465B58A5CC6D9C148478E5A9822D76ECA61395CFFA93EBADAEC78C9F7E1DA5CCECC00881BAF10B757CA9C4EB9D475FB8EDE7FC53" Size="8255248" Version="6.0.9.22419" /> | ||
25 | </ExePackage> | ||
26 | </PackageGroup> | ||
27 | </Fragment> | ||
28 | |||
29 | <Fragment> | ||
30 | <netfx:DotNetCoreSearch Id="$(var.DesktopNetCoreId)" RuntimeType="desktop" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.DesktopNetCoreId)" /> | ||
31 | |||
32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId)" Overridable="yes" /> | ||
33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
36 | |||
37 | <PackageGroup Id="$(var.DesktopNetCoreRedistId)"> | ||
38 | <ExePackage InstallArguments="$(var.DesktopNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.DesktopNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.DesktopNetCoreRedistLog)" Cache="remove"> | ||
39 | <ExePackagePayload Name="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)windowsdesktop-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.DesktopNetCoreRedistLink)" ProductName="Microsoft Windows Desktop Runtime - 6.0.9 (x86)" Description="Microsoft Windows Desktop Runtime - 6.0.9 (x86)" Hash="6B45A936A15710E22A03C64AD4F37EE4A934D957D31E78F73533099109BBEECDB8EAB7EC0749C2ECBCF90B72C9D6C7462252885F7C502F68E636167CACBA3DE0" Size="52443656" Version="6.0.9.31620" /> | ||
40 | </ExePackage> | ||
41 | </PackageGroup> | ||
42 | </Fragment> | ||
43 | |||
44 | <Fragment> | ||
45 | <netfx:DotNetCoreSearch Id="$(var.DotNetCoreId)" RuntimeType="core" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.DotNetCoreId)" /> | ||
46 | |||
47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId)" Overridable="yes" /> | ||
48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
51 | |||
52 | <PackageGroup Id="$(var.DotNetCoreRedistId)"> | ||
53 | <ExePackage InstallArguments="$(var.DotNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.DotNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.DotNetCoreRedistLog)" Cache="remove"> | ||
54 | <ExePackagePayload Name="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)dotnet-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.DotNetCoreRedistLink)" ProductName="Microsoft .NET Runtime - 6.0.9 (x86)" Description="Microsoft .NET Runtime - 6.0.9 (x86)" Hash="4A5EE2E0297140FB4B6064540CBB9D520C1B3BEF474F8342DFC5AAED0FD85B7FE26C49F85D17686E85540D421DA57EB2AE4D2B402C5184A6EF2EADED33B097A9" Size="25803488" Version="6.0.9.31619" /> | ||
55 | </ExePackage> | ||
56 | </PackageGroup> | ||
57 | </Fragment> | ||
58 | </Wix> | ||
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6_Platform.wxi b/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6_Platform.wxi new file mode 100644 index 00000000..d508bcaf --- /dev/null +++ b/src/test/burn/TestData/TestBA/TestBAWixlib/NetCore6_Platform.wxi | |||
@@ -0,0 +1,49 @@ | |||
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 | |||
4 | <Include xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:bal="http://wixtoolset.org/schemas/v4/wxs/bal" xmlns:util="http://wixtoolset.org/schemas/v4/wxs/util"> | ||
5 | |||
6 | <?define AspNetCoreId = ASPNETCORERUNTIME6_$(var.NetCorePlatform)?> | ||
7 | <?define AspNetCoreRedistId = AspNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | ||
8 | <?define AspNetCoreRedistLog = AspNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | ||
9 | <?define AspNetCoreRedistInstallArguments = /install /quiet /log "[$(var.AspNetCoreRedistLog)]"?> | ||
10 | <?define AspNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.AspNetCoreRedistLog)]"?> | ||
11 | |||
12 | <?define DesktopNetCoreId = DESKTOPNETCORERUNTIME6_$(var.NetCorePlatform)?> | ||
13 | <?define DesktopNetCoreRedistId = DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | ||
14 | <?define DesktopNetCoreRedistLog = DesktopNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | ||
15 | <?define DesktopNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> | ||
16 | <?define DesktopNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DesktopNetCoreRedistLog)]"?> | ||
17 | |||
18 | <?define DotNetCoreId = DOTNETCORERUNTIME6_$(var.NetCorePlatform)?> | ||
19 | <?define DotNetCoreRedistId = DotNetCoreRuntime$(var.NetCoreIdVersion)Redist_$(var.NetCorePlatform)?> | ||
20 | <?define DotNetCoreRedistLog = DotNetCoreRuntime$(var.NetCoreIdVersion)RedistLog?> | ||
21 | <?define DotNetCoreRedistInstallArguments = /install /quiet /log "[$(var.DotNetCoreRedistLog)]"?> | ||
22 | <?define DotNetCoreRedistUninstallArguments = /uninstall /quiet /log "[$(var.DotNetCoreRedistLog)]"?> | ||
23 | |||
24 | <?define NetCoreEulaLink = https://go.microsoft.com/fwlink/?LinkId=329770?> | ||
25 | |||
26 | <Fragment> | ||
27 | <PackageGroup Id="$(var.AspNetCoreRedistId)AsPrereq"> | ||
28 | <PackageGroupRef Id="$(var.AspNetCoreRedistId)" /> | ||
29 | </PackageGroup> | ||
30 | |||
31 | <bal:ManagedBootstrapperApplicationPrereqInformation PackageId="$(var.AspNetCoreRedistId)" LicenseUrl="$(var.NetCoreEulaLink)" /> | ||
32 | </Fragment> | ||
33 | |||
34 | <Fragment> | ||
35 | <PackageGroup Id="$(var.DesktopNetCoreRedistId)AsPrereq"> | ||
36 | <PackageGroupRef Id="$(var.DesktopNetCoreRedistId)" /> | ||
37 | </PackageGroup> | ||
38 | |||
39 | <bal:ManagedBootstrapperApplicationPrereqInformation PackageId="$(var.DesktopNetCoreRedistId)" LicenseUrl="$(var.NetCoreEulaLink)" /> | ||
40 | </Fragment> | ||
41 | |||
42 | <Fragment> | ||
43 | <PackageGroup Id="$(var.DotNetCoreRedistId)AsPrereq"> | ||
44 | <PackageGroupRef Id="$(var.DotNetCoreRedistId)" /> | ||
45 | </PackageGroup> | ||
46 | |||
47 | <bal:ManagedBootstrapperApplicationPrereqInformation PackageId="$(var.DotNetCoreRedistId)" LicenseUrl="$(var.NetCoreEulaLink)" /> | ||
48 | </Fragment> | ||
49 | </Include> | ||
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib/TestBA.wxs b/src/test/burn/TestData/TestBA/TestBAWixlib/TestBA.wxs index ae162050..2db22e4b 100644 --- a/src/test/burn/TestData/TestBA/TestBAWixlib/TestBA.wxs +++ b/src/test/burn/TestData/TestBA/TestBAWixlib/TestBA.wxs | |||
@@ -11,7 +11,7 @@ | |||
11 | </BootstrapperApplication> | 11 | </BootstrapperApplication> |
12 | 12 | ||
13 | <PackageGroup Id="TestBAdnc"> | 13 | <PackageGroup Id="TestBAdnc"> |
14 | <PackageGroupRef Id="NetFx48WebAsPrereq" /> <!-- Yes, this is wrong but we don't have .NET 6 packages yet --> | 14 | <PackageGroupRef Id="DesktopNetCoreRuntime609Redist_x86AsPrereq" /> |
15 | </PackageGroup> | 15 | </PackageGroup> |
16 | </Fragment> | 16 | </Fragment> |
17 | <Fragment> | 17 | <Fragment> |
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib/testbawixlib.wixproj b/src/test/burn/TestData/TestBA/TestBAWixlib/testbawixlib.wixproj index 1dbc4f63..6ef417d0 100644 --- a/src/test/burn/TestData/TestBA/TestBAWixlib/testbawixlib.wixproj +++ b/src/test/burn/TestData/TestBA/TestBAWixlib/testbawixlib.wixproj | |||
@@ -17,5 +17,6 @@ | |||
17 | </ItemGroup> | 17 | </ItemGroup> |
18 | <ItemGroup> | 18 | <ItemGroup> |
19 | <PackageReference Include="WixToolset.Bal.wixext" /> | 19 | <PackageReference Include="WixToolset.Bal.wixext" /> |
20 | <PackageReference Include="WixToolset.Netfx.wixext" /> | ||
20 | </ItemGroup> | 21 | </ItemGroup> |
21 | </Project> \ No newline at end of file | 22 | </Project> \ No newline at end of file |
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/NetCore6.0.9_x64.wxs b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/NetCore6.0.9_x64.wxs new file mode 100644 index 00000000..f2345693 --- /dev/null +++ b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/NetCore6.0.9_x64.wxs | |||
@@ -0,0 +1,58 @@ | |||
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 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs" xmlns:netfx="http://wixtoolset.org/schemas/v4/wxs/netfx"> | ||
4 | |||
5 | <?define NetCorePlatform = x64?> | ||
6 | <?define NetCoreIdVersion = 609?> | ||
7 | <?define NetCoreVersion = 6.0.9?> | ||
8 | <?include ..\TestBAWixlib\NetCore6_Platform.wxi?> | ||
9 | |||
10 | <?define AspNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/98dbe241-8b77-4be0-b130-a5fb6af8d724/27b655adce6250da42be9440abe847a2/aspnetcore-runtime-6.0.9-win-x64.exe?> | ||
11 | <?define DesktopNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/fe8415d4-8a35-4af9-80a5-51306a96282d/05f9b2a1b4884238e69468e49b3a5453/windowsdesktop-runtime-6.0.9-win-x64.exe?> | ||
12 | <?define DotNetCoreRedistLink = https://download.visualstudio.microsoft.com/download/pr/9dc77a6b-0276-4ad5-9bfa-d84b546686ef/f01bbcf2dc0e7f5dbd0a7d337fd4cd43/dotnet-runtime-6.0.9-win-x64.exe?> | ||
13 | |||
14 | <Fragment> | ||
15 | <netfx:DotNetCoreSearch Id="$(var.AspNetCoreId)" RuntimeType="aspnet" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.AspNetCoreId)" /> | ||
16 | |||
17 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.AspNetCoreId)" Overridable="yes" /> | ||
18 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
19 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
20 | <WixVariable Id="AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
21 | |||
22 | <PackageGroup Id="$(var.AspNetCoreRedistId)"> | ||
23 | <ExePackage InstallArguments="$(var.AspNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.AspNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.AspNetCoreRedistLog)" Cache="remove"> | ||
24 | <ExePackagePayload Name="!(wix.AspNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)aspnetcore-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.AspNetCoreRedistLink)" ProductName="Microsoft ASP.NET Core 6.0.9 - Shared Framework (x64)" Description="Microsoft ASP.NET Core 6.0.9 - Shared Framework (x64)" Hash="E3FAE121878E5D98F49AEAA0A20B03ECE760FCF75429256B7AF13B78608EEAA2D2485578ED952A410CC590008023E62584233BAD0E34E9FA632D445BCE7FA1F5" Size="9010072" Version="6.0.9.22419" /> | ||
25 | </ExePackage> | ||
26 | </PackageGroup> | ||
27 | </Fragment> | ||
28 | |||
29 | <Fragment> | ||
30 | <netfx:DotNetCoreSearch Id="$(var.DesktopNetCoreId)" RuntimeType="desktop" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.DesktopNetCoreId)" /> | ||
31 | |||
32 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DesktopNetCoreId)" Overridable="yes" /> | ||
33 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
34 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
35 | <WixVariable Id="DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
36 | |||
37 | <PackageGroup Id="$(var.DesktopNetCoreRedistId)"> | ||
38 | <ExePackage InstallArguments="$(var.DesktopNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.DesktopNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.DesktopNetCoreRedistLog)" Cache="remove"> | ||
39 | <ExePackagePayload Name="!(wix.DesktopNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)windowsdesktop-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.DesktopNetCoreRedistLink)" ProductName="Microsoft Windows Desktop Runtime - 6.0.9 (x64)" Description="Microsoft Windows Desktop Runtime - 6.0.9 (x64)" Hash="28CC3D88E6FA54938177937118260E9129967246E30D2140FDB7A4A8E9E393EFEC689D6282EDB6982853FD3BA27701239A8D1EE81A2DD28C93B186F1A3CB1B55" Size="57328120" Version="6.0.9.31620" /> | ||
40 | </ExePackage> | ||
41 | </PackageGroup> | ||
42 | </Fragment> | ||
43 | |||
44 | <Fragment> | ||
45 | <netfx:DotNetCoreSearch Id="$(var.DotNetCoreId)" RuntimeType="core" Platform="$(var.NetCorePlatform)" MajorVersion="6" Variable="$(var.DotNetCoreId)" /> | ||
46 | |||
47 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition" Value="$(var.DotNetCoreId)" Overridable="yes" /> | ||
48 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition" Value="" Overridable="yes" /> | ||
49 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory" Value="redist\" Overridable="yes" /> | ||
50 | <WixVariable Id="DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)RepairArguments" Value="" Overridable="yes" /> | ||
51 | |||
52 | <PackageGroup Id="$(var.DotNetCoreRedistId)"> | ||
53 | <ExePackage InstallArguments="$(var.DotNetCoreRedistInstallArguments)" PerMachine="yes" DetectCondition="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)DetectCondition)" InstallCondition="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)InstallCondition)" Id="$(var.DotNetCoreRedistId)" Vital="yes" Permanent="yes" Protocol="burn" LogPathVariable="$(var.DotNetCoreRedistLog)" Cache="remove"> | ||
54 | <ExePackagePayload Name="!(wix.DotNetCoreRuntime$(var.NetCoreIdVersion)Redist$(var.NetCorePlatform)PackageDirectory)dotnet-runtime-$(var.NetCoreVersion)-win-$(var.NetCorePlatform).exe" DownloadUrl="$(var.DotNetCoreRedistLink)" ProductName="Microsoft .NET Runtime - 6.0.9 (x64)" Description="Microsoft .NET Runtime - 6.0.9 (x64)" Hash="5F4A73342B3563937F2EFB576AA101C29C0AD4908413BA87C415A733239B9AF196FF04778F2E8BF5845508B069812C13CA281EA5E912552AAB5227E7841E502D" Size="27912624" Version="6.0.9.31619" /> | ||
55 | </ExePackage> | ||
56 | </PackageGroup> | ||
57 | </Fragment> | ||
58 | </Wix> | ||
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/TestBA_x64.wxs b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/TestBA_x64.wxs index df058958..f6a6382b 100644 --- a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/TestBA_x64.wxs +++ b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/TestBA_x64.wxs | |||
@@ -11,7 +11,7 @@ | |||
11 | </BootstrapperApplication> | 11 | </BootstrapperApplication> |
12 | 12 | ||
13 | <PackageGroup Id="TestBAdnc_x64"> | 13 | <PackageGroup Id="TestBAdnc_x64"> |
14 | <PackageGroupRef Id="NetFx48WebAsPrereq" /> <!-- Yes, this is wrong but we don't have .NET 6 packages yet --> | 14 | <PackageGroupRef Id="DesktopNetCoreRuntime609Redist_x64AsPrereq" /> |
15 | </PackageGroup> | 15 | </PackageGroup> |
16 | </Fragment> | 16 | </Fragment> |
17 | <Fragment> | 17 | <Fragment> |
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/WixBA_x64.wxs b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/WixBA_x64.wxs index bc5d4080..6cfbc937 100644 --- a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/WixBA_x64.wxs +++ b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/WixBA_x64.wxs | |||
@@ -12,7 +12,7 @@ | |||
12 | </BootstrapperApplication> | 12 | </BootstrapperApplication> |
13 | 13 | ||
14 | <PackageGroup Id="WixBAdnc_x64"> | 14 | <PackageGroup Id="WixBAdnc_x64"> |
15 | <PackageGroupRef Id="NetFx48WebAsPrereq" /> <!-- Yes, this is wrong but we don't have .NET 6 packages yet --> | 15 | <PackageGroupRef Id="DesktopNetCoreRuntime609Redist_x64AsPrereq" /> |
16 | </PackageGroup> | 16 | </PackageGroup> |
17 | </Fragment> | 17 | </Fragment> |
18 | </Wix> | 18 | </Wix> |
diff --git a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/testbawixlib_x64.wixproj b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/testbawixlib_x64.wixproj index 3d714c4e..13f66a86 100644 --- a/src/test/burn/TestData/TestBA/TestBAWixlib_x64/testbawixlib_x64.wixproj +++ b/src/test/burn/TestData/TestBA/TestBAWixlib_x64/testbawixlib_x64.wixproj | |||
@@ -29,5 +29,6 @@ | |||
29 | </ItemGroup> | 29 | </ItemGroup> |
30 | <ItemGroup> | 30 | <ItemGroup> |
31 | <PackageReference Include="WixToolset.Bal.wixext" /> | 31 | <PackageReference Include="WixToolset.Bal.wixext" /> |
32 | <PackageReference Include="WixToolset.Netfx.wixext" /> | ||
32 | </ItemGroup> | 33 | </ItemGroup> |
33 | </Project> \ No newline at end of file | 34 | </Project> \ No newline at end of file |