diff options
| author | Staffan Gustafsson <staffangu@outlook.com> | 2022-11-30 17:15:12 +0100 |
|---|---|---|
| committer | Sean Hall <r.sean.hall@gmail.com> | 2023-01-18 18:10:56 -0600 |
| commit | 853887b4e84df1965794802b7683f3a9aca3e930 (patch) | |
| tree | c2db272b63381c94186712c0029ed0e000ec3391 /src/ext/NetFx/be | |
| parent | 9f368d76848e31d21ec3c193fa8c92849b1362a1 (diff) | |
| download | wix-853887b4e84df1965794802b7683f3a9aca3e930.tar.gz wix-853887b4e84df1965794802b7683f3a9aca3e930.tar.bz2 wix-853887b4e84df1965794802b7683f3a9aca3e930.zip | |
Adding support for DotNetCoreSdkSearch and DotNetCoreSdkCompatibilityCheck
Diffstat (limited to 'src/ext/NetFx/be')
| -rw-r--r-- | src/ext/NetFx/be/detectnetcore.cpp | 2 | ||||
| -rw-r--r-- | src/ext/NetFx/be/detectnetcoresdk.cpp | 122 | ||||
| -rw-r--r-- | src/ext/NetFx/be/detectnetcoresdk.h | 9 | ||||
| -rw-r--r-- | src/ext/NetFx/be/netfxbe.vcxproj | 2 | ||||
| -rw-r--r-- | src/ext/NetFx/be/netfxsearch.cpp | 25 | ||||
| -rw-r--r-- | src/ext/NetFx/be/netfxsearch.h | 6 | ||||
| -rw-r--r-- | src/ext/NetFx/be/precomp.h | 1 |
7 files changed, 162 insertions, 5 deletions
diff --git a/src/ext/NetFx/be/detectnetcore.cpp b/src/ext/NetFx/be/detectnetcore.cpp index 42156692..aeb04203 100644 --- a/src/ext/NetFx/be/detectnetcore.cpp +++ b/src/ext/NetFx/be/detectnetcore.cpp | |||
| @@ -60,7 +60,7 @@ HRESULT DetectNetCore( | |||
| 60 | hr = StrAllocFormatted(&sczExePath, L"%ls%ls\\netcoresearch.exe", wzBaseDirectory, wzPlatformName); | 60 | hr = StrAllocFormatted(&sczExePath, L"%ls%ls\\netcoresearch.exe", wzBaseDirectory, wzPlatformName); |
| 61 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe path."); | 61 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe path."); |
| 62 | 62 | ||
| 63 | hr = StrAllocFormatted(&sczCommandLine, L"\"%ls\" %ls %ls", sczExePath, wzMajorVersion, wzRuntimeType); | 63 | hr = StrAllocFormatted(&sczCommandLine, L"\"%ls\" runtime %ls %ls", sczExePath, wzMajorVersion, wzRuntimeType); |
| 64 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe command line."); | 64 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe command line."); |
| 65 | 65 | ||
| 66 | hr = ProcExecute(sczExePath, sczCommandLine, &hProcess, NULL, &hStdOutErr); | 66 | hr = ProcExecute(sczExePath, sczCommandLine, &hProcess, NULL, &hStdOutErr); |
diff --git a/src/ext/NetFx/be/detectnetcoresdk.cpp b/src/ext/NetFx/be/detectnetcoresdk.cpp new file mode 100644 index 00000000..08b18334 --- /dev/null +++ b/src/ext/NetFx/be/detectnetcoresdk.cpp | |||
| @@ -0,0 +1,122 @@ | |||
| 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 DetectNetCoreSdk( | ||
| 6 | __in NETFX_NET_CORE_PLATFORM platform, | ||
| 7 | __in LPCWSTR wzVersion, | ||
| 8 | __in LPCWSTR wzBaseDirectory, | ||
| 9 | __inout LPWSTR* psczLatestVersion | ||
| 10 | ) | ||
| 11 | { | ||
| 12 | HRESULT hr = S_OK; | ||
| 13 | LPCWSTR wzPlatformName = NULL; | ||
| 14 | LPWSTR sczExePath = NULL; | ||
| 15 | LPWSTR sczCommandLine = NULL; | ||
| 16 | HANDLE hProcess = NULL; | ||
| 17 | HANDLE hStdOutErr = INVALID_HANDLE_VALUE; | ||
| 18 | BYTE* rgbOutput = NULL; | ||
| 19 | DWORD cbOutput = 0; | ||
| 20 | DWORD cbTotalRead = 0; | ||
| 21 | DWORD cbRead = 0; | ||
| 22 | DWORD dwExitCode = 0; | ||
| 23 | |||
| 24 | ReleaseNullStr(*psczLatestVersion); | ||
| 25 | |||
| 26 | switch (platform) | ||
| 27 | { | ||
| 28 | case NETFX_NET_CORE_PLATFORM_ARM64: | ||
| 29 | wzPlatformName = L"arm64"; | ||
| 30 | break; | ||
| 31 | case NETFX_NET_CORE_PLATFORM_X64: | ||
| 32 | wzPlatformName = L"x64"; | ||
| 33 | break; | ||
| 34 | case NETFX_NET_CORE_PLATFORM_X86: | ||
| 35 | wzPlatformName = L"x86"; | ||
| 36 | break; | ||
| 37 | default: | ||
| 38 | BextExitWithRootFailure(hr, E_INVALIDARG, "Unknown platform: %u", platform); | ||
| 39 | break; | ||
| 40 | } | ||
| 41 | |||
| 42 | hr = StrAllocFormatted(&sczExePath, L"%ls%ls\\netcoresearch.exe", wzBaseDirectory, wzPlatformName); | ||
| 43 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe path."); | ||
| 44 | |||
| 45 | hr = StrAllocFormatted(&sczCommandLine, L"\"%ls\" sdk %ls", sczExePath, wzVersion); | ||
| 46 | BextExitOnFailure(hr, "Failed to build netcoresearch.exe command line."); | ||
| 47 | |||
| 48 | hr = ProcExecute(sczExePath, sczCommandLine, &hProcess, NULL, &hStdOutErr); | ||
| 49 | if (HRESULT_FROM_WIN32(ERROR_EXE_MACHINE_TYPE_MISMATCH) == hr) | ||
| 50 | { | ||
| 51 | ExitFunction1(hr = S_FALSE); | ||
| 52 | } | ||
| 53 | BextExitOnFailure(hr, "Failed to run: %ls", sczCommandLine); | ||
| 54 | |||
| 55 | cbOutput = 64; | ||
| 56 | |||
| 57 | rgbOutput = static_cast<BYTE*>(MemAlloc(cbOutput, TRUE)); | ||
| 58 | BextExitOnNull(rgbOutput, hr, E_OUTOFMEMORY, "Failed to alloc output string."); | ||
| 59 | |||
| 60 | while (::ReadFile(hStdOutErr, rgbOutput + cbTotalRead, cbOutput - cbTotalRead, &cbRead, NULL)) | ||
| 61 | { | ||
| 62 | cbTotalRead += cbRead; | ||
| 63 | |||
| 64 | if (cbTotalRead == cbOutput) | ||
| 65 | { | ||
| 66 | cbOutput *= 2; | ||
| 67 | |||
| 68 | const LPVOID pvNew = MemReAlloc(rgbOutput, cbOutput, TRUE); | ||
| 69 | BextExitOnNull(pvNew, hr, E_OUTOFMEMORY, "Failed to realloc output string."); | ||
| 70 | |||
| 71 | rgbOutput = static_cast<BYTE*>(pvNew); | ||
| 72 | } | ||
| 73 | } | ||
| 74 | |||
| 75 | if (ERROR_BROKEN_PIPE != ::GetLastError()) | ||
| 76 | { | ||
| 77 | BextExitWithLastError(hr, "Failed to read netcoresearch.exe output."); | ||
| 78 | } | ||
| 79 | |||
| 80 | hr = ProcWaitForCompletion(hProcess, INFINITE, &dwExitCode); | ||
| 81 | BextExitOnFailure(hr, "Failed to wait for netcoresearch.exe to exit."); | ||
| 82 | |||
| 83 | if (0 != dwExitCode) | ||
| 84 | { | ||
| 85 | BextExitWithRootFailure(hr, E_UNEXPECTED, "netcoresearch.exe failed with exit code: 0x%x\r\nOutput:\r\n%hs", dwExitCode, rgbOutput); | ||
| 86 | } | ||
| 87 | |||
| 88 | if (*rgbOutput) | ||
| 89 | { | ||
| 90 | hr = StrAllocStringAnsi(psczLatestVersion, reinterpret_cast<LPSTR>(rgbOutput), 0, CP_UTF8); | ||
| 91 | BextExitOnFailure(hr, "Failed to widen output string: %hs", rgbOutput); | ||
| 92 | } | ||
| 93 | |||
| 94 | LExit: | ||
| 95 | ReleaseFileHandle(hStdOutErr); | ||
| 96 | ReleaseHandle(hProcess); | ||
| 97 | ReleaseMem(rgbOutput); | ||
| 98 | ReleaseStr(sczCommandLine); | ||
| 99 | ReleaseStr(sczExePath); | ||
| 100 | |||
| 101 | return hr; | ||
| 102 | } | ||
| 103 | |||
| 104 | HRESULT NetfxPerformDetectNetCoreSdk( | ||
| 105 | __in LPCWSTR wzVariable, | ||
| 106 | __in NETFX_SEARCH* pSearch, | ||
| 107 | __in IBundleExtensionEngine* pEngine, | ||
| 108 | __in LPCWSTR wzBaseDirectory | ||
| 109 | ) | ||
| 110 | { | ||
| 111 | HRESULT hr = S_OK; | ||
| 112 | LPWSTR sczLatestVersion = nullptr; | ||
| 113 | const auto& searchParams = pSearch->NetCoreSdkSearch; | ||
| 114 | hr = DetectNetCoreSdk(searchParams.platform, searchParams.sczVersion, wzBaseDirectory, &sczLatestVersion); | ||
| 115 | BextExitOnFailure(hr, "DetectNetCoreSdk failed."); | ||
| 116 | |||
| 117 | hr = pEngine->SetVariableVersion(wzVariable, sczLatestVersion); | ||
| 118 | BextExitOnFailure(hr, "Failed to set variable '%ls' to '%ls'", wzVariable, sczLatestVersion); | ||
| 119 | |||
| 120 | LExit: | ||
| 121 | return hr; | ||
| 122 | } | ||
diff --git a/src/ext/NetFx/be/detectnetcoresdk.h b/src/ext/NetFx/be/detectnetcoresdk.h new file mode 100644 index 00000000..025deaa2 --- /dev/null +++ b/src/ext/NetFx/be/detectnetcoresdk.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 NetfxPerformDetectNetCoreSdk( | ||
| 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.vcxproj b/src/ext/NetFx/be/netfxbe.vcxproj index d1084dd1..0408da72 100644 --- a/src/ext/NetFx/be/netfxbe.vcxproj +++ b/src/ext/NetFx/be/netfxbe.vcxproj | |||
| @@ -47,6 +47,7 @@ | |||
| 47 | 47 | ||
| 48 | <ItemGroup> | 48 | <ItemGroup> |
| 49 | <ClCompile Include="detectnetcore.cpp" /> | 49 | <ClCompile Include="detectnetcore.cpp" /> |
| 50 | <ClCompile Include="detectnetcoresdk.cpp" /> | ||
| 50 | <ClCompile Include="netfxbe.cpp" /> | 51 | <ClCompile Include="netfxbe.cpp" /> |
| 51 | <ClCompile Include="NetfxBundleExtension.cpp" /> | 52 | <ClCompile Include="NetfxBundleExtension.cpp" /> |
| 52 | <ClCompile Include="netfxsearch.cpp" /> | 53 | <ClCompile Include="netfxsearch.cpp" /> |
| @@ -57,6 +58,7 @@ | |||
| 57 | 58 | ||
| 58 | <ItemGroup> | 59 | <ItemGroup> |
| 59 | <ClInclude Include="detectnetcore.h" /> | 60 | <ClInclude Include="detectnetcore.h" /> |
| 61 | <ClInclude Include="detectnetcoresdk.h" /> | ||
| 60 | <ClInclude Include="NetfxBundleExtension.h" /> | 62 | <ClInclude Include="NetfxBundleExtension.h" /> |
| 61 | <ClInclude Include="netfxsearch.h" /> | 63 | <ClInclude Include="netfxsearch.h" /> |
| 62 | <ClInclude Include="precomp.h" /> | 64 | <ClInclude Include="precomp.h" /> |
diff --git a/src/ext/NetFx/be/netfxsearch.cpp b/src/ext/NetFx/be/netfxsearch.cpp index 3c12161d..671e7546 100644 --- a/src/ext/NetFx/be/netfxsearch.cpp +++ b/src/ext/NetFx/be/netfxsearch.cpp | |||
| @@ -15,7 +15,7 @@ STDMETHODIMP NetfxSearchParseFromXml( | |||
| 15 | BSTR bstrNodeName = NULL; | 15 | BSTR bstrNodeName = NULL; |
| 16 | 16 | ||
| 17 | // Select Netfx search nodes. | 17 | // Select Netfx search nodes. |
| 18 | hr = XmlSelectNodes(pixnBundleExtension, L"NetFxNetCoreSearch", &pixnNodes); | 18 | hr = XmlSelectNodes(pixnBundleExtension, L"NetFxNetCoreSearch|NetFxNetCoreSdkSearch", &pixnNodes); |
| 19 | BextExitOnFailure(hr, "Failed to select Netfx search nodes."); | 19 | BextExitOnFailure(hr, "Failed to select Netfx search nodes."); |
| 20 | 20 | ||
| 21 | // Get Netfx search node count. | 21 | // Get Netfx search node count. |
| @@ -50,18 +50,32 @@ STDMETHODIMP NetfxSearchParseFromXml( | |||
| 50 | { | 50 | { |
| 51 | pSearch->Type = NETFX_SEARCH_TYPE_NET_CORE_SEARCH; | 51 | pSearch->Type = NETFX_SEARCH_TYPE_NET_CORE_SEARCH; |
| 52 | 52 | ||
| 53 | auto& netCoreSearch = pSearch->NetCoreSearch; | ||
| 53 | // @RuntimeType | 54 | // @RuntimeType |
| 54 | hr = XmlGetAttributeUInt32(pixnNode, L"RuntimeType", reinterpret_cast<DWORD*>(&pSearch->NetCoreSearch.runtimeType)); | 55 | hr = XmlGetAttributeUInt32(pixnNode, L"RuntimeType", reinterpret_cast<DWORD*>(&netCoreSearch.runtimeType)); |
| 55 | BextExitOnFailure(hr, "Failed to get @RuntimeType."); | 56 | BextExitOnFailure(hr, "Failed to get @RuntimeType."); |
| 56 | 57 | ||
| 57 | // @Platform | 58 | // @Platform |
| 58 | hr = XmlGetAttributeUInt32(pixnNode, L"Platform", reinterpret_cast<DWORD*>(&pSearch->NetCoreSearch.platform)); | 59 | hr = XmlGetAttributeUInt32(pixnNode, L"Platform", reinterpret_cast<DWORD*>(&netCoreSearch.platform)); |
| 59 | BextExitOnFailure(hr, "Failed to get @Platform."); | 60 | BextExitOnFailure(hr, "Failed to get @Platform."); |
| 60 | 61 | ||
| 61 | // @MajorVersion | 62 | // @MajorVersion |
| 62 | hr = XmlGetAttributeEx(pixnNode, L"MajorVersion", &pSearch->NetCoreSearch.sczMajorVersion); | 63 | hr = XmlGetAttributeEx(pixnNode, L"MajorVersion", &netCoreSearch.sczMajorVersion); |
| 63 | BextExitOnFailure(hr, "Failed to get @MajorVersion."); | 64 | BextExitOnFailure(hr, "Failed to get @MajorVersion."); |
| 64 | } | 65 | } |
| 66 | else if (CSTR_EQUAL == ::CompareStringW(LOCALE_INVARIANT, 0, bstrNodeName, -1, L"NetFxNetCoreSdkSearch", -1)) | ||
| 67 | { | ||
| 68 | pSearch->Type = NETFX_SEARCH_TYPE_NET_CORE_SDK_SEARCH; | ||
| 69 | |||
| 70 | auto& netCoreSdkSearch = pSearch->NetCoreSdkSearch; | ||
| 71 | // @Platform | ||
| 72 | hr = XmlGetAttributeUInt32(pixnNode, L"Platform", reinterpret_cast<DWORD*>(&netCoreSdkSearch.platform)); | ||
| 73 | BextExitOnFailure(hr, "Failed to get @Platform."); | ||
| 74 | |||
| 75 | // @Version | ||
| 76 | hr = XmlGetAttributeEx(pixnNode, L"Version", &netCoreSdkSearch.sczVersion); | ||
| 77 | BextExitOnFailure(hr, "Failed to get @Version."); | ||
| 78 | } | ||
| 65 | else | 79 | else |
| 66 | { | 80 | { |
| 67 | BextExitWithRootFailure(hr, E_UNEXPECTED, "Unexpected element name: %ls", bstrNodeName); | 81 | BextExitWithRootFailure(hr, E_UNEXPECTED, "Unexpected element name: %ls", bstrNodeName); |
| @@ -115,6 +129,9 @@ STDMETHODIMP NetfxSearchExecute( | |||
| 115 | case NETFX_SEARCH_TYPE_NET_CORE_SEARCH: | 129 | case NETFX_SEARCH_TYPE_NET_CORE_SEARCH: |
| 116 | hr = NetfxPerformDetectNetCore(wzVariable, pSearch, pEngine, wzBaseDirectory); | 130 | hr = NetfxPerformDetectNetCore(wzVariable, pSearch, pEngine, wzBaseDirectory); |
| 117 | break; | 131 | break; |
| 132 | case NETFX_SEARCH_TYPE_NET_CORE_SDK_SEARCH: | ||
| 133 | hr = NetfxPerformDetectNetCoreSdk(wzVariable, pSearch, pEngine, wzBaseDirectory); | ||
| 134 | break; | ||
| 118 | default: | 135 | default: |
| 119 | hr = E_UNEXPECTED; | 136 | hr = E_UNEXPECTED; |
| 120 | } | 137 | } |
diff --git a/src/ext/NetFx/be/netfxsearch.h b/src/ext/NetFx/be/netfxsearch.h index ae250690..f4e4db01 100644 --- a/src/ext/NetFx/be/netfxsearch.h +++ b/src/ext/NetFx/be/netfxsearch.h | |||
| @@ -8,6 +8,7 @@ enum NETFX_SEARCH_TYPE | |||
| 8 | { | 8 | { |
| 9 | NETFX_SEARCH_TYPE_NONE, | 9 | NETFX_SEARCH_TYPE_NONE, |
| 10 | NETFX_SEARCH_TYPE_NET_CORE_SEARCH, | 10 | NETFX_SEARCH_TYPE_NET_CORE_SEARCH, |
| 11 | NETFX_SEARCH_TYPE_NET_CORE_SDK_SEARCH, | ||
| 11 | }; | 12 | }; |
| 12 | 13 | ||
| 13 | enum NETFX_NET_CORE_RUNTIME_TYPE | 14 | enum NETFX_NET_CORE_RUNTIME_TYPE |
| @@ -40,6 +41,11 @@ typedef struct _NETFX_SEARCH | |||
| 40 | NETFX_NET_CORE_PLATFORM platform; | 41 | NETFX_NET_CORE_PLATFORM platform; |
| 41 | LPWSTR sczMajorVersion; | 42 | LPWSTR sczMajorVersion; |
| 42 | } NetCoreSearch; | 43 | } NetCoreSearch; |
| 44 | struct | ||
| 45 | { | ||
| 46 | NETFX_NET_CORE_PLATFORM platform; | ||
| 47 | LPWSTR sczVersion; | ||
| 48 | } NetCoreSdkSearch; | ||
| 43 | }; | 49 | }; |
| 44 | } NETFX_SEARCH; | 50 | } NETFX_SEARCH; |
| 45 | 51 | ||
diff --git a/src/ext/NetFx/be/precomp.h b/src/ext/NetFx/be/precomp.h index 33aea9bc..4a774200 100644 --- a/src/ext/NetFx/be/precomp.h +++ b/src/ext/NetFx/be/precomp.h | |||
| @@ -30,4 +30,5 @@ | |||
| 30 | #include "..\..\beDecor.h" | 30 | #include "..\..\beDecor.h" |
| 31 | #include "netfxsearch.h" | 31 | #include "netfxsearch.h" |
| 32 | #include "detectnetcore.h" | 32 | #include "detectnetcore.h" |
| 33 | #include "detectnetcoresdk.h" | ||
| 33 | #include "NetfxBundleExtension.h" | 34 | #include "NetfxBundleExtension.h" |
