This is an archive of the discontinued LLVM Phabricator instance.

Host: generalise `GetXcodeSDKPath`
ClosedPublic

Authored by compnerd on Apr 27 2023, 6:24 PM.

Details

Summary

This generalises the GetXcodeSDKPath hook to a GetSDKRoot path which
will be re-used for the Windows support to compute a language specific
SDK path on the platform. Because there may be other options that we
wish to use to compute the SDK path, sink the XcodeSDK parameter into
a structure which can pass a disaggregated set of options. Furthermore,
optionalise the parameter as Xcode is not available for all platforms.

Diff Detail

Event Timeline

compnerd created this revision.Apr 27 2023, 6:24 PM
Herald added a project: Restricted Project. · View Herald TranscriptApr 27 2023, 6:24 PM
compnerd requested review of this revision.Apr 27 2023, 6:24 PM
JDevlieghere accepted this revision.Apr 27 2023, 7:49 PM

LGTM. Thanks Saleem!

This revision is now accepted and ready to land.Apr 27 2023, 7:49 PM
This revision was automatically updated to reflect the committed changes.
mgorny added a subscriber: mgorny.Apr 29 2023, 10:49 AM

This change broke building with GCC:

samu: job failed: /usr/lib/ccache/bin/x86_64-pc-linux-gnu-g++ -DHAVE_ROUND -D_DEBUG -D_GLIBCXX_ASSERTIONS -D_LIBCPP_ENABLE_ASSERTIONS -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb_build/source/Host -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/source/Host -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb_build/include -I/usr/lib/llvm/17/include -I/usr/include/python3.11 -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/tools/clang/include -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb_build/../clang/include -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/source -I/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb_build/source -isystem /usr/include/libxml2  -march=znver2 --param=l1-cache-size=32 --param=l1-cache-line-size=64 -O2 -pipe -frecord-gcc-switches -fPIC -fno-semantic-interposition -fvisibility-inlines-hidden -Werror=date-time -Wall -Wextra -Wno-unused-parameter -Wwrite-strings -Wcast-qual -Wno-missing-field-initializers -Wimplicit-fallthrough -Wno-class-memaccess -Wno-redundant-move -Wno-pessimizing-move -Wno-noexcept-type -Wdelete-non-virtual-dtor -Wsuggest-override -Wno-comment -Wno-misleading-indentation -Wctad-maybe-unsupported -fdiagnostics-color -ffunction-sections -fdata-sections -Wno-deprecated-declarations -Wno-unknown-pragmas -Wno-strict-aliasing -Wno-stringop-truncation -std=c++17 -UNDEBUG -MD -MT source/Host/CMakeFiles/lldbHost.dir/posix/PipePosix.cpp.o -MF source/Host/CMakeFiles/lldbHost.dir/posix/PipePosix.cpp.o.d -o source/Host/CMakeFiles/lldbHost.dir/posix/PipePosix.cpp.o -c /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/source/Host/posix/PipePosix.cpp
In file included from /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/posix/HostInfoPosix.h:12,
                 from /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/linux/HostInfoLinux.h:12,
                 from /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/HostInfo.h:43,
                 from /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/source/Host/posix/PipePosix.cpp:10:
/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/HostInfoBase.h:130:29: error: declaration of ‘std::optional<lldb_private::XcodeSDK> lldb_private::HostInfoBase::SDKOptions::XcodeSDK’ changes meaning of ‘XcodeSDK’ [-Wchanges-meaning]
  130 |     std::optional<XcodeSDK> XcodeSDK;
      |                             ^~~~~~~~
/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/HostInfoBase.h:130:19: note: used here to mean ‘class lldb_private::XcodeSDK’
  130 |     std::optional<XcodeSDK> XcodeSDK;
      |                   ^~~~~~~~
In file included from /var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Host/HostInfoBase.h:16:
/var/tmp/portage/dev-util/lldb-17.0.0_pre20230429/work/lldb/include/lldb/Utility/XcodeSDK.h:24:7: note: declared here
   24 | class XcodeSDK {
      |       ^~~~~~~~
samu: subcommands failed
cmtice added a subscriber: cmtice.Apr 29 2023, 1:32 PM

I'm seeing the same build failures reported by mgorny. Would you consider reverting this patch until you can fix it?