xcbuild: cleanup
This commit is contained in:
parent
0edb441a0e
commit
b5d529d52f
@ -294,8 +294,7 @@ runCommand "Platforms" {} ''
|
|||||||
install -D ${writeText "PackageTypes.xcspec" (toPlist {} PackageTypes)} $platform/Developer/Library/Xcode/Specifications/PackageTypes.xcspec
|
install -D ${writeText "PackageTypes.xcspec" (toPlist {} PackageTypes)} $platform/Developer/Library/Xcode/Specifications/PackageTypes.xcspec
|
||||||
install -D ${writeText "ProductTypes.xcspec" (toPlist {} ProductTypes)} $platform/Developer/Library/Xcode/Specifications/ProductTypes.xcspec
|
install -D ${writeText "ProductTypes.xcspec" (toPlist {} ProductTypes)} $platform/Developer/Library/Xcode/Specifications/ProductTypes.xcspec
|
||||||
|
|
||||||
# per-platform bins go here
|
ln -s $platform $platform/usr
|
||||||
mkdir -p $platform/usr/bin
|
|
||||||
|
|
||||||
mkdir -p $platform/Developer
|
mkdir -p $platform/Developer
|
||||||
ln -s ${sdks} $platform/Developer/SDKs
|
ln -s ${sdks} $platform/Developer/SDKs
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{ runCommand, lib, toolchainName, sdkName, writeText, version, xcodePlatform }:
|
{ stdenv, runCommand, lib, toolchainName, sdkName
|
||||||
|
, writeText, version, xcodePlatform, libcxx, symlinkJoin }:
|
||||||
|
|
||||||
let
|
let
|
||||||
inherit (lib.generators) toPlist;
|
inherit (lib.generators) toPlist;
|
||||||
@ -18,11 +19,11 @@ let
|
|||||||
};
|
};
|
||||||
in
|
in
|
||||||
|
|
||||||
runCommand "SDKs" {
|
runCommand "SDKs" {} ''
|
||||||
inherit version;
|
|
||||||
} ''
|
|
||||||
sdk=$out/${sdkName}.sdk
|
sdk=$out/${sdkName}.sdk
|
||||||
install -D ${writeText "SDKSettings.plist" (toPlist {} SDKSettings)} $sdk/SDKSettings.plist
|
install -D ${writeText "SDKSettings.plist" (toPlist {} SDKSettings)} $sdk/SDKSettings.plist
|
||||||
install -D ${writeText "SystemVersion.plist" (toPlist {} SystemVersion)} $sdk/System/Library/CoreServices/SystemVersion.plist
|
install -D ${writeText "SystemVersion.plist" (toPlist {} SystemVersion)} $sdk/System/Library/CoreServices/SystemVersion.plist
|
||||||
|
ln -s $sdk $sdk/usr
|
||||||
|
|
||||||
ln -s $sdk $out/${xcodePlatform}.sdk
|
ln -s $sdk $out/${xcodePlatform}.sdk
|
||||||
''
|
''
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ runCommand, toolchainName, fetchurl, makeWrapper, stdenv
|
{ runCommand, toolchainName, fetchurl, stdenv
|
||||||
, buildPackages, lib, writeText }:
|
, buildPackages, lib, writeText }:
|
||||||
|
|
||||||
let
|
let
|
||||||
@ -20,52 +20,52 @@ let
|
|||||||
};
|
};
|
||||||
in
|
in
|
||||||
|
|
||||||
runCommand "Toolchains" {
|
runCommand "Toolchains" {} (''
|
||||||
nativeBuildInputs = [ makeWrapper ];
|
|
||||||
} (''
|
|
||||||
toolchain=$out/XcodeDefault.xctoolchain
|
toolchain=$out/XcodeDefault.xctoolchain
|
||||||
mkdir -p $toolchain
|
mkdir -p $toolchain
|
||||||
|
|
||||||
install -D ${writeText "ToolchainInfo.plist" (toPlist {} ToolchainInfo)} $toolchain/ToolchainInfo.plist
|
install -D ${writeText "ToolchainInfo.plist" (toPlist {} ToolchainInfo)} $toolchain/ToolchainInfo.plist
|
||||||
|
|
||||||
mkdir -p $toolchain/usr/include
|
ln -s $toolchain $toolchain/usr
|
||||||
mkdir -p $toolchain/usr/lib
|
|
||||||
mkdir -p $toolchain/usr/libexec
|
mkdir -p $toolchain/include
|
||||||
mkdir -p $toolchain/usr/share
|
mkdir -p $toolchain/lib
|
||||||
mkdir -p $toolchain/usr/bin
|
mkdir -p $toolchain/libexec
|
||||||
|
mkdir -p $toolchain/share
|
||||||
|
mkdir -p $toolchain/bin
|
||||||
|
|
||||||
for bin in ${getBin stdenv.cc}/bin/*; do
|
for bin in ${getBin stdenv.cc}/bin/*; do
|
||||||
ln -s $bin $toolchain/usr/bin
|
ln -s $bin $toolchain/bin
|
||||||
done
|
done
|
||||||
|
|
||||||
for bin in ${getBin stdenv.cc.bintools.bintools}/bin/*; do
|
for bin in ${getBin stdenv.cc.bintools.bintools}/bin/*; do
|
||||||
if ! [ -e "$toolchain/usr/bin/$(basename $bin)" ]; then
|
if ! [ -e "$toolchain/bin/$(basename $bin)" ]; then
|
||||||
ln -s $bin $toolchain/usr/bin
|
ln -s $bin $toolchain/bin
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
ln -s ${buildPackages.yacc}/bin/yacc $toolchain/usr/bin/yacc
|
ln -s ${buildPackages.yacc}/bin/yacc $toolchain/bin/yacc
|
||||||
ln -s ${buildPackages.yacc}/bin/bison $toolchain/usr/bin/bison
|
ln -s ${buildPackages.yacc}/bin/bison $toolchain/bin/bison
|
||||||
ln -s ${buildPackages.flex}/bin/flex $toolchain/usr/bin/flex
|
ln -s ${buildPackages.flex}/bin/flex $toolchain/bin/flex
|
||||||
ln -s ${buildPackages.flex}/bin/flex++ $toolchain/usr/bin/flex++
|
ln -s ${buildPackages.flex}/bin/flex++ $toolchain/bin/flex++
|
||||||
ln -s $toolchain/bin/flex $toolchain/usr/bin/lex
|
ln -s $toolchain/bin/flex $toolchain/bin/lex
|
||||||
|
|
||||||
ln -s ${buildPackages.m4}/bin/m4 $toolchain/usr/bin/m4
|
ln -s ${buildPackages.m4}/bin/m4 $toolchain/bin/m4
|
||||||
ln -s $toolchain/usr/bin/m4 $toolchain/usr/bin/gm4
|
ln -s $toolchain/bin/m4 $toolchain/bin/gm4
|
||||||
|
|
||||||
ln -s ${buildPackages.unifdef}/bin/unifdef $toolchain/usr/bin/unifdef
|
ln -s ${buildPackages.unifdef}/bin/unifdef $toolchain/bin/unifdef
|
||||||
ln -s ${buildPackages.unifdef}/bin/unifdefall $toolchain/usr/bin/unifdefall
|
ln -s ${buildPackages.unifdef}/bin/unifdefall $toolchain/bin/unifdefall
|
||||||
|
|
||||||
ln -s ${buildPackages.gperf}/bin/gperf $toolchain/usr/bin/gperf
|
ln -s ${buildPackages.gperf}/bin/gperf $toolchain/bin/gperf
|
||||||
ln -s ${buildPackages.indent}/bin/indent $toolchain/usr/bin/indent
|
ln -s ${buildPackages.indent}/bin/indent $toolchain/bin/indent
|
||||||
ln -s ${buildPackages.ctags}/bin/ctags $toolchain/usr/bin/ctags
|
ln -s ${buildPackages.ctags}/bin/ctags $toolchain/bin/ctags
|
||||||
'' + optionalString stdenv.isDarwin ''
|
'' + optionalString stdenv.isDarwin ''
|
||||||
for bin in ${getBin buildPackages.darwin.cctools}/bin/*; do
|
for bin in ${getBin buildPackages.darwin.cctools}/bin/*; do
|
||||||
if ! [ -e "$toolchain/usr/bin/$(basename $bin)" ]; then
|
if ! [ -e "$toolchain/bin/$(basename $bin)" ]; then
|
||||||
ln -s $bin $toolchain/usr/bin
|
ln -s $bin $toolchain/bin
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
ln -s ${buildPackages.darwin.bootstrap_cmds}/bin/mig $toolchain/usr/bin
|
ln -s ${buildPackages.darwin.bootstrap_cmds}/bin/mig $toolchain/bin
|
||||||
ln -s ${mkdep-darwin-src} $toolchain/usr/bin/mkdep
|
ln -s ${mkdep-darwin-src} $toolchain/bin/mkdep
|
||||||
'')
|
'')
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
{ lib, buildPackages, makeWrapper, writeText, runCommand
|
{ stdenv, lib, buildPackages, makeWrapper, writeText, runCommand
|
||||||
|
, bash
|
||||||
, CoreServices, ImageIO, CoreGraphics
|
, CoreServices, ImageIO, CoreGraphics
|
||||||
, targetPlatform
|
, targetPlatform
|
||||||
, xcodePlatform ? targetPlatform.xcodePlatform or "MacOSX"
|
, xcodePlatform ? targetPlatform.xcodePlatform or "MacOSX"
|
||||||
@ -36,7 +37,7 @@ let
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
xcode-select = writeText "xcode-select" ''
|
xcode-select = writeText "xcode-select" ''
|
||||||
#!/usr/bin/env sh
|
#!${bash}/bin/sh
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-h | --help) ;; # noop
|
-h | --help) ;; # noop
|
||||||
@ -51,7 +52,7 @@ done
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
xcrun = writeText "xcrun" ''
|
xcrun = writeText "xcrun" ''
|
||||||
#!/usr/bin/env sh
|
#!${bash}/bin/sh
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
--sdk | -sdk) shift ;;
|
--sdk | -sdk) shift ;;
|
||||||
@ -86,16 +87,20 @@ runCommand "xcodebuild-${xcbuild.version}" {
|
|||||||
inherit (xcbuild) meta;
|
inherit (xcbuild) meta;
|
||||||
|
|
||||||
# ensure that the toolchain goes in PATH
|
# ensure that the toolchain goes in PATH
|
||||||
propagatedBuildInputs = [ "${toolchains}/XcodeDefault.xctoolchain/usr" ];
|
propagatedBuildInputs = [ "${toolchains}/XcodeDefault.xctoolchain" ];
|
||||||
|
|
||||||
passthru = { inherit xcbuild; };
|
passthru = {
|
||||||
|
inherit xcbuild;
|
||||||
|
toolchain = "${toolchains}/XcodeDefault.xctoolchain";
|
||||||
|
sdk = "${sdks}/${sdkName}";
|
||||||
|
platform = "${platforms}/${xcodePlatform}.platform";
|
||||||
|
};
|
||||||
|
|
||||||
preferLocalBuild = true;
|
preferLocalBuild = true;
|
||||||
} ''
|
} ''
|
||||||
mkdir -p $out/bin
|
mkdir -p $out/bin
|
||||||
|
|
||||||
mkdir -p $out/usr
|
ln -s $out $out/usr
|
||||||
ln -s $out/bin $out/usr/bin
|
|
||||||
|
|
||||||
mkdir -p $out/Library/Xcode
|
mkdir -p $out/Library/Xcode
|
||||||
ln -s ${xcbuild}/Library/Xcode/Specifications $out/Library/Xcode/Specifications
|
ln -s ${xcbuild}/Library/Xcode/Specifications $out/Library/Xcode/Specifications
|
||||||
@ -108,7 +113,8 @@ runCommand "xcodebuild-${xcbuild.version}" {
|
|||||||
--add-flags "DERIVED_DATA_DIR=." \
|
--add-flags "DERIVED_DATA_DIR=." \
|
||||||
--set DEVELOPER_DIR "$out" \
|
--set DEVELOPER_DIR "$out" \
|
||||||
--set SDKROOT ${sdkName} \
|
--set SDKROOT ${sdkName} \
|
||||||
--run '[ "$1" = "-version" ] && (echo Xcode ${xcodeVer}; echo Build version ${sdkBuildVersion}) && exit 0'
|
--run '[ "$1" = "-version" ] && (echo Xcode ${xcodeVer}; echo Build version ${sdkBuildVersion}) && exit 0' \
|
||||||
|
--run '[ "$1" = "-license" ] && exit 0'
|
||||||
|
|
||||||
substitute ${xcode-select} $out/bin/xcode-select \
|
substitute ${xcode-select} $out/bin/xcode-select \
|
||||||
--subst-var-by DEVELOPER_DIR $out
|
--subst-var-by DEVELOPER_DIR $out
|
||||||
|
Loading…
x
Reference in New Issue
Block a user