diff options
author | Kira Bruneau <kira.bruneau@pm.me> | 2023-04-28 23:02:14 -0400 |
---|---|---|
committer | Kira Bruneau <kira.bruneau@pm.me> | 2023-04-29 12:16:23 -0400 |
commit | e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe (patch) | |
tree | 84936d473feb7f25b69d3d239eefb5dd72f269b7 | |
parent | 4acc6ace1e447d7018197b0f1caee62cd7e2ef90 (diff) | |
download | nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar.gz nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar.bz2 nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar.lz nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar.xz nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.tar.zst nixpkgs-e12199b8a017c0b03a5f6d23418bbf9f3ef4bbbe.zip |
dart-sass-embedded: build from source
-rw-r--r-- | pkgs/misc/dart-sass-embedded/default.nix | 89 | ||||
-rw-r--r-- | pkgs/servers/web-apps/discourse/default.nix | 2 |
2 files changed, 58 insertions, 33 deletions
diff --git a/pkgs/misc/dart-sass-embedded/default.nix b/pkgs/misc/dart-sass-embedded/default.nix index 18ba6f9472c..c190dfaa507 100644 --- a/pkgs/misc/dart-sass-embedded/default.nix +++ b/pkgs/misc/dart-sass-embedded/default.nix @@ -1,49 +1,74 @@ { lib , stdenvNoCC -, fetchurl -, autoPatchelfHook +, fetchFromGitHub +, dart +, buf +, callPackage +, runtimeShell }: -stdenvNoCC.mkDerivation rec { +let + embedded-protocol = fetchFromGitHub { + owner = "sass"; + repo = "embedded-protocol"; + rev = "refs/tags/1.2.0"; + hash = "sha256-OHOWotI+cXjDhEYUNXa36FpMEW7hSIu8gVX3gVRvw2Y="; + }; + + libExt = stdenvNoCC.hostPlatform.extensions.sharedLibrary; +in +stdenvNoCC.mkDerivation (finalAttrs: { pname = "dart-sass-embedded"; version = "1.62.1"; - dontConfigure = true; - dontBuild = true; - - nativeBuildInputs = lib.optional stdenvNoCC.hostPlatform.isLinux autoPatchelfHook; - - src = let base = "https://github.com/sass/dart-sass-embedded/releases/download/${version}/sass_embedded-${version}"; in - fetchurl { - "x86_64-linux" = { - url = "${base}-linux-x64.tar.gz"; - hash = "sha256-NXTadacyKlOQNGSLj/hP8syhYuuSTXK2Y9cYzTk28HU="; - }; - "aarch64-linux" = { - url = "${base}-linux-arm64.tar.gz"; - hash = "sha256-DX29U1AjmqVhKFgzP+71vsdoMjQ13IS93PZ1JLOA7bA="; - }; - "x86_64-darwin" = { - url = "${base}-macos-x64.tar.gz"; - hash = "sha256-0oyb9YBKoPNaWFLbIUZOJc5yK11uDYyAKKW4urkmRJQ="; - }; - "aarch64-darwin" = { - url = "${base}-macos-arm64.tar.gz"; - hash = "sha256-dkBcdVbxolK8xXYaOHot0s9FxGmfhMNAEoZqo+2LRfk="; - }; - }."${stdenvNoCC.hostPlatform.system}" or (throw "Unsupported system ${stdenvNoCC.hostPlatform.system}"); + src = fetchFromGitHub { + owner = "sass"; + repo = "dart-sass-embedded"; + rev = "refs/tags/${finalAttrs.version}"; + hash = "sha256-GpSus5/QItbzCrOImMvrO6DTAQeODABRNiSYHJlLlIA="; + }; + + nativeBuildInputs = [ + buf + dart + (callPackage ../../build-support/dart/fetch-dart-deps { } { + buildDrvArgs = finalAttrs; + vendorHash = "sha256-aEBE+z8M5ivMR9zL7kleBJ8c9T+4PGXoec56iwHVT+c="; + }) + ]; + + strictDeps = true; + + configurePhase = '' + runHook preConfigure + dart pub get --offline + mkdir build + ln -s ${embedded-protocol} build/embedded-protocol + runHook postConfigure + ''; + + buildPhase = '' + runHook preBuild + UPDATE_SASS_PROTOCOL=false HOME="$TMPDIR" dart run grinder protobuf + dart run grinder pkg-compile-native + runHook postBuild + ''; installPhase = '' - mkdir -p $out/bin - cp -r * $out - ln -s $out/dart-sass-embedded $out/bin/dart-sass-embedded + runHook preInstall + mkdir -p "$out/lib" "$out/bin" + cp build/dart-sass-embedded.native "$out/lib/dart-sass-embedded${libExt}" + echo '#!${runtimeShell}' > "$out/bin/dart-sass-embedded" + echo "exec ${dart}/bin/dartaotruntime $out/lib/dart-sass-embedded${libExt} \"\$@\"" >> "$out/bin/dart-sass-embedded" + chmod +x "$out/bin/dart-sass-embedded" + runHook postInstall ''; meta = with lib; { description = "A wrapper for Dart Sass that implements the compiler side of the Embedded Sass protocol"; homepage = "https://github.com/sass/dart-sass-embedded"; - changelog = "https://github.com/sass/dart-sass-embedded/blob/${version}/CHANGELOG.md"; + changelog = "https://github.com/sass/dart-sass-embedded/blob/${finalAttrs.version}/CHANGELOG.md"; license = licenses.mit; maintainers = with maintainers; [ shyim ]; }; -} +}) diff --git a/pkgs/servers/web-apps/discourse/default.nix b/pkgs/servers/web-apps/discourse/default.nix index 05a961e5927..b07425860bf 100644 --- a/pkgs/servers/web-apps/discourse/default.nix +++ b/pkgs/servers/web-apps/discourse/default.nix @@ -198,7 +198,7 @@ let ./rubyEnv/sass-embedded-static.patch ]; postPatch = '' - export SASS_EMBEDDED=${dart-sass-embedded} + export SASS_EMBEDDED=${dart-sass-embedded}/bin ''; }; }; |