2024-09-26 11:04:55 +00:00
{
clangStdenv ,
lib ,
fetchurl ,
2024-10-11 05:15:48 +00:00
fetchpatch ,
2024-09-26 11:04:55 +00:00
dotnetCorePackages ,
jq ,
curl ,
git ,
cmake ,
pkg-config ,
llvm ,
zlib ,
icu ,
lttng-ust_2_12 ,
krb5 ,
glibcLocales ,
ensureNewerSourcesForZipFilesHook ,
darwin ,
xcbuild ,
swiftPackages ,
openssl ,
getconf ,
python3 ,
xmlstarlet ,
nodejs ,
callPackage ,
unzip ,
yq ,
2024-10-11 05:15:48 +00:00
baseName ? " d o t n e t " ,
2024-09-26 11:04:55 +00:00
bootstrapSdk ,
releaseManifestFile ,
tarballHash ,
2024-04-21 15:54:59 +00:00
} :
let
2024-09-26 11:04:55 +00:00
stdenv = if clangStdenv . hostPlatform . isDarwin then swiftPackages . stdenv else clangStdenv ;
2024-04-21 15:54:59 +00:00
inherit ( stdenv )
isLinux
isDarwin
buildPlatform
2024-09-26 11:04:55 +00:00
targetPlatform
;
2024-04-21 15:54:59 +00:00
inherit ( swiftPackages ) apple_sdk swift ;
releaseManifest = lib . importJSON releaseManifestFile ;
inherit ( releaseManifest ) release sourceRepository tag ;
buildRid = dotnetCorePackages . systemToDotnetRid buildPlatform . system ;
targetRid = dotnetCorePackages . systemToDotnetRid targetPlatform . system ;
targetArch = lib . elemAt ( lib . splitString " - " targetRid ) 1 ;
2024-09-26 11:04:55 +00:00
sigtool = callPackage ./sigtool.nix { } ;
2024-04-21 15:54:59 +00:00
_icu = if isDarwin then darwin . ICU else icu ;
2024-10-11 05:15:48 +00:00
# error NU1903: Package 'System.Text.Json' 8.0.4 has a known high severity vulnerability,
disableNU1903 = fetchpatch {
url = " h t t p s : / / g i t h u b . c o m / d o t n e t / s d k / p u l l / 4 4 0 2 8 . p a t c h " ;
hash = " s h a 2 5 6 - r 6 A O h X h w T 8 a r 3 a S 0 r 5 C A 9 s P i B s p 3 p n n P I V O + 5 l 5 C U G M = " ;
} ;
2024-09-26 11:04:55 +00:00
in
stdenv . mkDerivation rec {
2024-10-11 05:15:48 +00:00
pname = " ${ baseName } - v m r " ;
2024-04-21 15:54:59 +00:00
version = release ;
# TODO: fix this in the binary sdk packages
2024-09-26 11:04:55 +00:00
preHook = lib . optionalString stdenv . hostPlatform . isDarwin ''
2024-04-21 15:54:59 +00:00
addToSearchPath DYLD_LIBRARY_PATH " ${ _icu } / l i b "
export DYLD_LIBRARY_PATH
'' ;
src = fetchurl {
url = " ${ sourceRepository } / a r c h i v e / r e f s / t a g s / ${ tag } . t a r . g z " ;
hash = tarballHash ;
} ;
2024-09-26 11:04:55 +00:00
nativeBuildInputs =
[
ensureNewerSourcesForZipFilesHook
jq
curl . bin
git
cmake
pkg-config
python3
xmlstarlet
unzip
yq
]
++ lib . optionals ( lib . versionAtLeast version " 9 " ) [
nodejs
]
++ lib . optionals isDarwin [
getconf
] ;
buildInputs =
[
# this gets copied into the tree, but we still want the hooks to run
bootstrapSdk
# the propagated build inputs in llvm.dev break swift compilation
llvm . out
zlib
_icu
openssl
]
++ lib . optionals isLinux [
krb5
lttng-ust_2_12
]
++ lib . optionals isDarwin (
with apple_sdk . frameworks ;
[
xcbuild
swift
( krb5 . overrideAttrs ( old : {
# the propagated build inputs break swift compilation
buildInputs = old . buildInputs ++ old . propagatedBuildInputs ;
propagatedBuildInputs = [ ] ;
} ) )
sigtool
Foundation
CoreFoundation
CryptoKit
System
]
++ lib . optional ( lib . versionAtLeast version " 9 " ) GSS
) ;
2024-04-21 15:54:59 +00:00
# This is required to fix the error:
# > CSSM_ModuleLoad(): One or more parameters passed to a function were not valid.
# The error occurs during
# AppleCryptoNative_X509ImportCollection -> ReadX509 -> SecItemImport
# while importing trustedroots/codesignctl.pem. This happens during any dotnet
# restore operation.
# Enabling com.apple.system.opendirectoryd.membership causes swiftc to use
# /var/folders for its default cache path, so the swiftc -module-cache-path
# patch below is required.
sandboxProfile = ''
( allow file-read * ( subpath " / p r i v a t e / v a r / d b / m d s / s y s t e m " ) )
( allow mach-lookup ( global-name " c o m . a p p l e . S e c u r i t y S e r v e r " )
( global-name " c o m . a p p l e . s y s t e m . o p e n d i r e c t o r y d . m e m b e r s h i p " ) )
'' ;
2024-10-11 05:15:48 +00:00
patches =
lib . optionals ( lib . versionAtLeast version " 9 " ) [
./UpdateNuGetConfigPackageSourcesMappings-don-t-add-em.patch
]
++ lib . optionals ( lib . versionOlder version " 9 " ) [
./fix-aspnetcore-portable-build.patch
] ;
2024-04-21 15:54:59 +00:00
2024-09-26 11:04:55 +00:00
postPatch =
''
# set the sdk version in global.json to match the bootstrap sdk
jq ' ( . tools . dotnet = $ dotnet ) ' global . json - - arg dotnet " $ ( ${ bootstrapSdk } / b i n / d o t n e t - - v e r s i o n ) " > global . json ~
mv global . json { ~ , }
patchShebangs $ ( find - name \ * . sh - type f - executable )
# I'm not sure why this is required, but these files seem to use the wrong
# property name.
# TODO: not needed in 9.0?
[ [ ! - f src/xliff-tasks/eng/Versions.props ] ] || \
sed - i ' s : \ bVersionBase \ b:VersionPrefix:g' \
src/xliff-tasks/eng/Versions.props
# at least in 9.0 preview 1, this package depends on a specific beta build
# of System.CommandLine
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n NoWarn - v ' $ ( NoWarn ) ; NU1603' \
src/nuget-client/src/NuGet.Core/NuGet.CommandLine.XPlat/NuGet.CommandLine.XPlat.csproj
# AD0001 crashes intermittently in source-build-reference-packages with
# CSC : error AD0001: Analyzer 'Microsoft.NetCore.CSharp.Analyzers.Runtime.CSharpDetectPreviewFeatureAnalyzer' threw an exception of type 'System.NullReferenceException' with message 'Object reference not set to an instance of an object.'.
# possibly related to https://github.com/dotnet/runtime/issues/90356
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n NoWarn - v ' $ ( NoWarn ) ; AD0001' \
src/source-build-reference-packages/src/referencePackages/Directory.Build.props
# https://github.com/microsoft/ApplicationInsights-dotnet/issues/2848
xmlstarlet ed \
- - inplace \
- u // _ : Project/_ : PropertyGroup/_ : BuildNumber - v 0 \
src/source-build-externals/src/application-insights/.props/_GlobalStaticVersion.props
# this fixes compile errors with clang 15 (e.g. darwin)
substituteInPlace \
src/runtime/src/native/libs/CMakeLists.txt \
- - replace-fail ' add_compile_options ( - Weverything ) ' ' add_compile_options ( - Wall ) '
# strip native symbols in runtime
# see: https://github.com/dotnet/source-build/issues/2543
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n KeepNativeSymbols - v false \
src/runtime/Directory.Build.props
''
+ lib . optionalString ( lib . versionAtLeast version " 9 " ) ''
# repro.csproj fails to restore due to missing freebsd packages
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n RuntimeIdentifiers - v $ { targetRid } \
src/runtime/src/coreclr/tools/aot/ILCompiler/repro/repro.csproj
# https://github.com/dotnet/runtime/pull/98559#issuecomment-1965338627
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n NoWarn - v ' $ ( NoWarn ) ; CS9216' \
src/runtime/Directory.Build.props
# patch packages installed from npm cache
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n Import \
- i \ $ prev - t attr - n Project - v " ${ ./patch-npm-packages.proj } " \
src/aspnetcore/eng/DotNetBuild.props
2024-10-11 05:15:48 +00:00
# patch is from sdk repo where vmr bits are in src/SourceBuild/content
patch - p4 < $ { disableNU1903 }
2024-09-26 11:04:55 +00:00
''
+ lib . optionalString ( lib . versionAtLeast version " 9 " ) ''
# https://github.com/dotnet/source-build/issues/3131#issuecomment-2030215805
substituteInPlace \
src/aspnetcore/eng/Dependencies.props \
- - replace-fail \
" ' \$ ( D o t N e t B u i l d S o u r c e O n l y ) ' = = ' t r u e ' " \
" ' \$ ( D o t N e t B u i l d S o u r c e O n l y ) ' = = ' t r u e ' a n d \$ ( P o r t a b l e B u i l d ) = = ' f a l s e ' "
# https://github.com/dotnet/source-build/issues/4325
xmlstarlet ed \
- - inplace \
- r ' // Target [ @ Name = " U n p a c k T a r b a l l s " ] /Move ' - v Copy \
eng/init-source-only.proj
# error: _FORTIFY_SOURCE requires compiling with optimization (-O) [-Werror,-W#warnings]
substituteInPlace \
src/runtime/src/coreclr/ilasm/CMakeLists.txt \
- - replace-fail ' set_source_files_properties ( prebuilt/asmparse.cpp PROPERTIES COMPILE_FLAGS " - O 0 " ) ' " "
# https://github.com/dotnet/source-build/issues/4444
xmlstarlet ed \
- - inplace \
- s ' // Project/Target/MSBuild [ @ Targets = " R e s t o r e " ] ' \
- t attr - n Properties - v " N U G E T _ P A C K A G E S = ' \$ ( C u r r e n t R e p o S o u r c e B u i l d P a c k a g e C a c h e ) ' " \
src/aspnetcore/eng/Tools.props
''
+ lib . optionalString isLinux (
''
substituteInPlace \
src/runtime/src/native/libs/System.Security.Cryptography.Native/opensslshim.c \
- - replace-fail ' " l i b s s l . s o " ' ' " ${ openssl . out } / l i b / l i b s s l . s o " '
substituteInPlace \
src/runtime/src/native/libs/System.Net.Security.Native/pal_gssapi.c \
- - replace-fail ' " l i b g s s a p i _ k r b 5 . s o . 2 " ' ' " ${ lib . getLib krb5 } / l i b / l i b g s s a p i _ k r b 5 . s o . 2 " '
substituteInPlace \
src/runtime/src/native/libs/System.Globalization.Native/pal_icushim.c \
- - replace-fail ' " l i b i c u i 1 8 n . s o " ' ' " ${ icu } / l i b / l i b i c u i 1 8 n . s o " ' \
- - replace-fail ' " l i b i c u u c . s o " ' ' " ${ icu } / l i b / l i b i c u u c . s o " '
''
+ lib . optionalString ( lib . versionAtLeast version " 9 " ) ''
substituteInPlace \
src/runtime/src/native/libs/System.Globalization.Native/pal_icushim.c \
- - replace-fail ' #define VERSIONED_LIB_NAME_LEN 64' '#define VERSIONED_LIB_NAME_LEN 256'
''
+ lib . optionalString ( lib . versionOlder version " 9 " ) ''
substituteInPlace \
src/runtime/src/native/libs/System.Globalization.Native/pal_icushim.c \
- - replace-warn ' libicuucName [ 64 ] ' ' libicuucName [ 256 ] ' \
- - replace-warn ' libicui18nName [ 64 ] ' ' libicui18nName [ 256 ] '
''
)
+ lib . optionalString isDarwin (
''
substituteInPlace \
src/runtime/src/native/libs/System.Globalization.Native/CMakeLists.txt \
- - replace-fail ' /usr/lib/libicucore.dylib ' ' $ { darwin . ICU } /lib/libicucore.dylib '
substituteInPlace \
src/runtime/src/installer/managed/Microsoft.NET.HostModel/HostModelUtils.cs \
src/sdk/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.Sdk.targets \
- - replace-fail ' /usr/bin/codesign ' ' $ { sigtool } /bin/codesign '
# fix: strip: error: unknown argument '-n'
substituteInPlace \
src/runtime/eng/native/functions.cmake \
- - replace-fail ' - no_code_signature_warning' " "
# [...]/installer.singlerid.targets(434,5): error MSB3073: The command "pkgbuild [...]" exited with code 127
xmlstarlet ed \
- - inplace \
- s // Project - t elem - n PropertyGroup \
- s \ $ prev - t elem - n SkipInstallerBuild - v true \
src/runtime/Directory.Build.props
# stop passing -sdk without a path
# stop using xcrun
# add -module-cache-path to fix swift errors, see sandboxProfile
# <unknown>:0: error: unable to open output file '/var/folders/[...]/C/clang/ModuleCache/[...]/SwiftShims-[...].pcm': 'Operation not permitted'
# <unknown>:0: error: could not build Objective-C module 'SwiftShims'
substituteInPlace \
src/runtime/src/native/libs/System.Security.Cryptography.Native.Apple/CMakeLists.txt \
- - replace-fail ' - sdk '' ${ CMAKE_OSX_SYSROOT } ' " " \
- - replace-fail ' xcrun swiftc' ' swiftc - module-cache-path " $ E N V { H O M E } / . c a c h e / m o d u l e - c a c h e " '
''
+ lib . optionalString ( lib . versionAtLeast version " 9 " ) ''
# fix: strip: error: unknown argument '-n'
substituteInPlace \
src/runtime/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.targets \
src/runtime/src/native/managed/native-library.targets \
- - replace-fail ' - no_code_signature_warning' " "
# ld: library not found for -ld_classic
substituteInPlace \
src/runtime/src/coreclr/nativeaot/BuildIntegration/Microsoft.NETCore.Native.Unix.targets \
src/runtime/src/coreclr/tools/aot/ILCompiler/ILCompiler.csproj \
- - replace-fail ' Include = " - l d _ c l a s s i c " ' " "
''
+ lib . optionalString ( lib . versionOlder version " 9 " ) ''
# [...]/build.proj(123,5): error : Did not find PDBs for the following SDK files:
# [...]/build.proj(123,5): error : sdk/8.0.102/System.Resources.Extensions.dll
# [...]/build.proj(123,5): error : sdk/8.0.102/System.CodeDom.dll
# [...]/build.proj(123,5): error : sdk/8.0.102/FSharp/System.Resources.Extensions.dll
# [...]/build.proj(123,5): error : sdk/8.0.102/FSharp/System.CodeDom.dll
substituteInPlace \
build . proj \
- - replace-fail ' FailOnMissingPDBs = " t r u e " ' ' FailOnMissingPDBs = " f a l s e " '
substituteInPlace \
src/runtime/src/mono/CMakeLists.txt \
- - replace-fail ' /usr/lib/libicucore.dylib ' ' $ { darwin . ICU } /lib/libicucore.dylib '
''
) ;
2024-04-21 15:54:59 +00:00
prepFlags = [
" - - n o - a r t i f a c t s "
" - - n o - p r e b u i l t s "
2024-09-26 11:04:55 +00:00
" - - w i t h - p a c k a g e s "
bootstrapSdk . artifacts
2024-04-21 15:54:59 +00:00
] ;
2024-09-26 11:04:55 +00:00
configurePhase =
let
prepScript = if ( lib . versionAtLeast version " 9 " ) then " . / p r e p - s o u r c e - b u i l d . s h " else " . / p r e p . s h " ;
in
''
runHook preConfigure
2024-04-21 15:54:59 +00:00
2024-09-26 11:04:55 +00:00
# The build process tries to overwrite some things in the sdk (e.g.
# SourceBuild.MSBuildSdkResolver.dll), so it needs to be mutable.
cp - Tr $ { bootstrapSdk } . dotnet
chmod - R + w . dotnet
2024-04-21 15:54:59 +00:00
2024-09-26 11:04:55 +00:00
$ { prepScript } $ prepFlags
2024-04-21 15:54:59 +00:00
2024-09-26 11:04:55 +00:00
runHook postConfigure
'' ;
2024-04-21 15:54:59 +00:00
postConfigure = lib . optionalString ( lib . versionAtLeast version " 9 " ) ''
# see patch-npm-packages.proj
typeset - f isScript patchShebangs > src/aspnetcore/patch-shebangs.sh
'' ;
2024-09-19 14:19:46 +00:00
dontConfigureNuget = true ; # NUGET_PACKAGES breaks the build
2024-04-21 15:54:59 +00:00
dontUseCmakeConfigure = true ;
# https://github.com/NixOS/nixpkgs/issues/38991
# bash: warning: setlocale: LC_ALL: cannot change locale (en_US.UTF-8)
2024-09-26 11:04:55 +00:00
LOCALE_ARCHIVE = lib . optionalString isLinux " ${ glibcLocales } / l i b / l o c a l e / l o c a l e - a r c h i v e " ;
buildFlags =
[
" - - w i t h - p a c k a g e s "
bootstrapSdk . artifacts
" - - c l e a n - w h i l e - b u i l d i n g "
" - - r e l e a s e - m a n i f e s t "
releaseManifestFile
]
++ lib . optionals ( lib . versionAtLeast version " 9 " ) [
" - - s o u r c e - b u i l d "
]
++ [
" - - "
" - p : P o r t a b l e B u i l d = t r u e "
]
++ lib . optional ( targetRid != buildRid ) " - p : T a r g e t R i d = ${ targetRid } " ;
2024-04-21 15:54:59 +00:00
buildPhase = ''
runHook preBuild
# on darwin, in a sandbox, this causes:
# CSSM_ModuleLoad(): One or more parameters passed to a function were not valid.
export DOTNET_GENERATE_ASPNET_CERTIFICATE = 0
# CLR_CC/CXX need to be set to stop the build system from using clang-11,
# which is unwrapped
# dotnet needs to be in PATH to fix:
# src/sdk/eng/restore-toolset.sh: line 114: /nix/store/[...]-dotnet-sdk-9.0.100-preview.2.24157.14//.version: Read-only file system
version = \
CLR_CC = $ ( command - v clang ) \
CLR_CXX = $ ( command - v clang ++ ) \
PATH = $ PWD/.dotnet : $ PATH \
./build.sh $ buildFlags
runHook postBuild
'' ;
2024-09-26 11:04:55 +00:00
installPhase =
let
assets = if ( lib . versionAtLeast version " 9 " ) then " a s s e t s " else targetArch ;
in
''
runHook preInstall
mkdir " $ o u t "
pushd " a r t i f a c t s / ${ assets } / R e l e a s e "
find . - name \ * . tar . gz | while read archive ; do
target = $ out / $ ( basename " $ a r c h i v e " . tar . gz )
# dotnet 9 currently has two copies of the sdk tarball
[ [ ! - e " $ t a r g e t " ] ] || continue
mkdir " $ t a r g e t "
tar - C " $ t a r g e t " - xzf " $ P W D / $ a r c h i v e "
done
popd
local - r unpacked = " $ P W D / . u n p a c k e d "
for nupkg in $ out/Private.SourceBuilt.Artifacts. * . ${ targetRid } / { , SourceBuildReferencePackages / } * . nupkg ; do
rm - rf " $ u n p a c k e d "
unzip - qd " $ u n p a c k e d " " $ n u p k g "
chmod - R + rw " $ u n p a c k e d "
rm " $ n u p k g "
mv " $ u n p a c k e d " " $ n u p k g "
# TODO: should we fix executable flags here? see dotnetInstallHook
done
runHook postInstall
'' ;
2024-04-21 15:54:59 +00:00
# dotnet cli is in the root, so we need to strip from there
# TODO: should we install in $out/share/dotnet?
stripDebugList = [ " . " ] ;
# stripping dlls results in:
# Failed to load System.Private.CoreLib.dll (error code 0x8007000B)
2024-09-19 14:19:46 +00:00
# stripped crossgen2 results in:
# Failure processing application bundle; possible file corruption.
# this needs to be a bash array
preFixup = ''
stripExclude = ( \ * . dll crossgen2 )
'' ;
2024-04-21 15:54:59 +00:00
passthru = {
inherit releaseManifest buildRid targetRid ;
icu = _icu ;
2024-09-19 14:19:46 +00:00
# ilcompiler is currently broken: https://github.com/dotnet/source-build/issues/1215
hasILCompiler = lib . versionAtLeast version " 9 " ;
2024-04-21 15:54:59 +00:00
} ;
meta = with lib ; {
description = " C o r e f u n c t i o n a l i t y n e e d e d t o c r e a t e . N E T C o r e p r o j e c t s , t h a t i s s h a r e d b e t w e e n V i s u a l S t u d i o a n d C L I " ;
homepage = " h t t p s : / / d o t n e t . g i t h u b . i o / " ;
license = licenses . mit ;
maintainers = with maintainers ; [ corngood ] ;
mainProgram = " d o t n e t " ;
platforms = [
" x 8 6 _ 6 4 - l i n u x "
" a a r c h 6 4 - l i n u x "
" x 8 6 _ 6 4 - d a r w i n "
" a a r c h 6 4 - d a r w i n "
] ;
} ;
}