Merge pull request #108611 from thiagokokada/flutter-refactor-bump
flutter: reduce derivation size and refactor
This commit is contained in:
commit
544d4f3a91
|
@ -1,5 +1,4 @@
|
||||||
{ callPackage, dart }:
|
{ callPackage, dart }:
|
||||||
|
|
||||||
let
|
let
|
||||||
dart_stable = dart.override { version = "2.10.0"; };
|
dart_stable = dart.override { version = "2.10.0"; };
|
||||||
dart_beta = dart.override { version = "2.10.0"; };
|
dart_beta = dart.override { version = "2.10.0"; };
|
||||||
|
@ -8,7 +7,8 @@ let
|
||||||
getPatches = dir:
|
getPatches = dir:
|
||||||
let files = builtins.attrNames (builtins.readDir dir);
|
let files = builtins.attrNames (builtins.readDir dir);
|
||||||
in map (f: dir + ("/" + f)) files;
|
in map (f: dir + ("/" + f)) files;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
mkFlutter = mkFlutter;
|
mkFlutter = mkFlutter;
|
||||||
stable = mkFlutter rec {
|
stable = mkFlutter rec {
|
||||||
pname = "flutter";
|
pname = "flutter";
|
||||||
|
|
|
@ -1,10 +1,36 @@
|
||||||
{ channel, pname, version, sha256Hash, patches, dart
|
{ channel
|
||||||
, filename ? "flutter_linux_${version}-${channel}.tar.xz"}:
|
, pname
|
||||||
|
, version
|
||||||
{ bash, buildFHSUserEnv, cacert, coreutils, git, makeWrapper, runCommand, stdenv
|
, sha256Hash
|
||||||
, fetchurl, alsaLib, dbus, expat, libpulseaudio, libuuid, libX11, libxcb
|
, patches
|
||||||
, libXcomposite, libXcursor, libXdamage, libXfixes, libGL, nspr, nss, systemd }:
|
, dart
|
||||||
|
, filename ? "flutter_linux_${version}-${channel}.tar.xz"
|
||||||
|
}:
|
||||||
|
|
||||||
|
{ bash
|
||||||
|
, buildFHSUserEnv
|
||||||
|
, cacert
|
||||||
|
, coreutils
|
||||||
|
, git
|
||||||
|
, runCommand
|
||||||
|
, stdenv
|
||||||
|
, fetchurl
|
||||||
|
, alsaLib
|
||||||
|
, dbus
|
||||||
|
, expat
|
||||||
|
, libpulseaudio
|
||||||
|
, libuuid
|
||||||
|
, libX11
|
||||||
|
, libxcb
|
||||||
|
, libXcomposite
|
||||||
|
, libXcursor
|
||||||
|
, libXdamage
|
||||||
|
, libXfixes
|
||||||
|
, libGL
|
||||||
|
, nspr
|
||||||
|
, nss
|
||||||
|
, systemd
|
||||||
|
}:
|
||||||
let
|
let
|
||||||
drvName = "flutter-${channel}-${version}";
|
drvName = "flutter-${channel}-${version}";
|
||||||
flutter = stdenv.mkDerivation {
|
flutter = stdenv.mkDerivation {
|
||||||
|
@ -16,7 +42,7 @@ let
|
||||||
sha256 = sha256Hash;
|
sha256 = sha256Hash;
|
||||||
};
|
};
|
||||||
|
|
||||||
buildInputs = [ makeWrapper git ];
|
buildInputs = [ git ];
|
||||||
|
|
||||||
inherit patches;
|
inherit patches;
|
||||||
|
|
||||||
|
@ -31,28 +57,27 @@ let
|
||||||
SNAPSHOT_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.snapshot"
|
SNAPSHOT_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.snapshot"
|
||||||
STAMP_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.stamp"
|
STAMP_PATH="$FLUTTER_ROOT/bin/cache/flutter_tools.stamp"
|
||||||
SCRIPT_PATH="$FLUTTER_TOOLS_DIR/bin/flutter_tools.dart"
|
SCRIPT_PATH="$FLUTTER_TOOLS_DIR/bin/flutter_tools.dart"
|
||||||
DART_SDK_PATH="$FLUTTER_ROOT/bin/cache/dart-sdk"
|
DART_SDK_PATH="${dart}"
|
||||||
|
|
||||||
DART="$DART_SDK_PATH/bin/dart"
|
|
||||||
PUB="$DART_SDK_PATH/bin/pub"
|
|
||||||
|
|
||||||
HOME=../.. # required for pub upgrade --offline, ~/.pub-cache
|
HOME=../.. # required for pub upgrade --offline, ~/.pub-cache
|
||||||
# path is relative otherwise it's replaced by /build/flutter
|
# path is relative otherwise it's replaced by /build/flutter
|
||||||
|
|
||||||
(cd "$FLUTTER_TOOLS_DIR" && "$PUB" upgrade --offline)
|
(cd "$FLUTTER_TOOLS_DIR" && ${dart}/bin/pub upgrade --offline)
|
||||||
|
|
||||||
local revision="$(cd "$FLUTTER_ROOT"; git rev-parse HEAD)"
|
local revision="$(cd "$FLUTTER_ROOT"; git rev-parse HEAD)"
|
||||||
"$DART" --snapshot="$SNAPSHOT_PATH" --packages="$FLUTTER_TOOLS_DIR/.packages" "$SCRIPT_PATH"
|
${dart}/bin/dart --snapshot="$SNAPSHOT_PATH" --packages="$FLUTTER_TOOLS_DIR/.packages" "$SCRIPT_PATH"
|
||||||
echo "$revision" > "$STAMP_PATH"
|
echo "$revision" > "$STAMP_PATH"
|
||||||
echo -n "${version}" > version
|
echo -n "${version}" > version
|
||||||
|
|
||||||
rm -rf bin/cache/{artifacts,downloads}
|
rm -rf bin/cache/{artifacts,dart-sdk,downloads}
|
||||||
rm -f bin/cache/*.stamp
|
rm -f bin/cache/*.stamp
|
||||||
'';
|
'';
|
||||||
|
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
mkdir -p $out
|
mkdir -p $out
|
||||||
cp -r . $out
|
cp -r . $out
|
||||||
|
mkdir -p $out/bin/cache/
|
||||||
|
ln -sf ${dart} $out/bin/cache/dart-sdk
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -100,7 +125,9 @@ let
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
in runCommand drvName {
|
in
|
||||||
|
runCommand drvName
|
||||||
|
{
|
||||||
startScript = ''
|
startScript = ''
|
||||||
#!${bash}/bin/bash
|
#!${bash}/bin/bash
|
||||||
export PUB_CACHE=''${PUB_CACHE:-"$HOME/.pub-cache"}
|
export PUB_CACHE=''${PUB_CACHE:-"$HOME/.pub-cache"}
|
||||||
|
@ -126,8 +153,4 @@ in runCommand drvName {
|
||||||
|
|
||||||
echo -n "$startScript" > $out/bin/${pname}
|
echo -n "$startScript" > $out/bin/${pname}
|
||||||
chmod +x $out/bin/${pname}
|
chmod +x $out/bin/${pname}
|
||||||
|
|
||||||
mkdir -p $out/bin/cache/dart-sdk/
|
|
||||||
cp -r ${dart}/* $out/bin/cache/dart-sdk/
|
|
||||||
ln $out/bin/cache/dart-sdk/bin/dart $out/bin/dart
|
|
||||||
''
|
''
|
||||||
|
|
Loading…
Reference in New Issue