update flutter flakes
This commit is contained in:
@@ -1,109 +1,43 @@
|
|||||||
{
|
{
|
||||||
|
description = "Flutter 3.13.x";
|
||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "nixpkgs/nixpkgs-unstable";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||||
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
flake-parts = {
|
|
||||||
url = "github:hercules-ci/flake-parts";
|
|
||||||
inputs.nixpkgs-lib.follows = "nixpkgs";
|
|
||||||
};
|
};
|
||||||
|
outputs = { self, nixpkgs, flake-utils }:
|
||||||
android-nixpkgs.url = "github:tadfisher/android-nixpkgs";
|
flake-utils.lib.eachDefaultSystem (system:
|
||||||
|
let
|
||||||
cursor.url = "github:omarcresp/cursor-flake/main";
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
outputs = {
|
|
||||||
self,
|
|
||||||
nixpkgs,
|
|
||||||
flake-parts,
|
|
||||||
cursor,
|
|
||||||
...
|
|
||||||
} @ inputs:
|
|
||||||
flake-parts.lib.mkFlake {inherit inputs;} {
|
|
||||||
systems = ["x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin"];
|
|
||||||
perSystem = {
|
|
||||||
pkgs,
|
|
||||||
system,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
devShells.default = let
|
|
||||||
pkgs = import nixpkgs {
|
pkgs = import nixpkgs {
|
||||||
inherit system;
|
inherit system;
|
||||||
config = {
|
config = {
|
||||||
allowUnfree = true;
|
|
||||||
android_sdk.accept_license = true;
|
android_sdk.accept_license = true;
|
||||||
|
allowUnfree = true;
|
||||||
};
|
};
|
||||||
overlays = [];
|
|
||||||
};
|
};
|
||||||
android-nixpkgs = pkgs.callPackage inputs.android-nixpkgs {};
|
androidComposition = pkgs.androidenv.composeAndroidPackages {
|
||||||
androidSdk = android-nixpkgs.sdk (sdkPkgs:
|
buildToolsVersions = [ "28.0.3" "34.0.0" ];
|
||||||
with sdkPkgs; [
|
platformVersions = [ "34" "35" "33" ];
|
||||||
cmdline-tools-latest
|
includeNDK = true;
|
||||||
build-tools-34-0-0
|
ndkVersions = ["26.3.11579264"];
|
||||||
build-tools-30-0-3
|
abiVersions = [ "armeabi-v7a" "arm64-v8a" ];
|
||||||
platform-tools
|
cmakeVersions = [ "3.22.1" ];
|
||||||
platforms-android-35
|
|
||||||
platforms-android-34
|
|
||||||
platforms-android-33
|
|
||||||
platforms-android-31
|
|
||||||
platforms-android-30
|
|
||||||
ndk-26-3-11579264
|
|
||||||
cmake-3-22-1
|
|
||||||
]);
|
|
||||||
PWD = builtins.getEnv "PWD";
|
|
||||||
patchedFlutter = pkgs.flutter.override (prev: rec {
|
|
||||||
flutter = prev.flutter.overrideAttrs (prevAttrs: {
|
|
||||||
patches = prevAttrs.patches ++ [
|
|
||||||
# This patch is needed to avoid the Kotlin Gradle plugin writing to the store.
|
|
||||||
(pkgs.writeText "kotlin-fix.patch" ''
|
|
||||||
--- a/packages/flutter_tools/gradle/build.gradle.kts
|
|
||||||
+++ b/packages/flutter_tools/gradle/build.gradle.kts
|
|
||||||
@@ -4,6 +4,8 @@
|
|
||||||
|
|
||||||
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
|
|
||||||
|
|
||||||
+gradle.startParameter.projectCacheDir = layout.buildDirectory.dir("cache").get().asFile
|
|
||||||
+
|
|
||||||
plugins {
|
|
||||||
`java-gradle-plugin`
|
|
||||||
groovy
|
|
||||||
'')
|
|
||||||
];
|
|
||||||
passthru = prevAttrs.passthru // {
|
|
||||||
sdk = flutter;
|
|
||||||
};
|
};
|
||||||
# postInstall = (prevAttrs.postInstall or "") + ''
|
androidSdk = androidComposition.androidsdk;
|
||||||
# mkdir -p $out/bin/cache
|
|
||||||
# touch $out/bin/cache/engine.realm
|
|
||||||
# '';
|
|
||||||
});
|
|
||||||
});
|
|
||||||
in
|
in
|
||||||
pkgs.mkShell {
|
{
|
||||||
|
devShell =
|
||||||
|
with pkgs; mkShell rec {
|
||||||
ANDROID_SDK_ROOT = "${androidSdk}/libexec/android-sdk";
|
ANDROID_SDK_ROOT = "${androidSdk}/libexec/android-sdk";
|
||||||
ANDROID_NDK_ROOT = "${androidSdk}/libexec/android-sdk/ndk-bundle";
|
GRADLE_OPTS = "-Dorg.gradle.project.android.aapt2FromMavenOverride=${androidSdk}/libexec/android-sdk/build-tools/34.0.0/aapt2";
|
||||||
ANDROID_AVD_HOME = "${PWD}/.android/avd";
|
buildInputs = [
|
||||||
ANDROID_HOME = "${androidSdk}/libexec/android-sdk";
|
flutter
|
||||||
FLUTTER_SDK = "${patchedFlutter}";
|
androidSdk # The customized SDK that we've made above
|
||||||
GRADLE_OPTS = "-Dorg.gradle.project.android.aapt2FromMavenOverride=${androidSdk}/share/android-sdk/build-tools/34.0.0/aapt2";
|
|
||||||
buildInputs = with pkgs; [
|
|
||||||
patchedFlutter
|
|
||||||
jdk17
|
jdk17
|
||||||
androidSdk
|
|
||||||
clang
|
|
||||||
dart
|
|
||||||
cmake
|
|
||||||
android-tools
|
|
||||||
cursor.packages.${pkgs.system}.default
|
|
||||||
];
|
];
|
||||||
shellHook = ''
|
shellHook = ''
|
||||||
zsh
|
zsh
|
||||||
exit
|
exit
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
# formatter = pkgs.alejandra;
|
});
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
109
shells/flutter/flake.nix.bk
Normal file
109
shells/flutter/flake.nix.bk
Normal file
@@ -0,0 +1,109 @@
|
|||||||
|
{
|
||||||
|
inputs = {
|
||||||
|
nixpkgs.url = "nixpkgs/nixpkgs-unstable";
|
||||||
|
|
||||||
|
flake-parts = {
|
||||||
|
url = "github:hercules-ci/flake-parts";
|
||||||
|
inputs.nixpkgs-lib.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
|
android-nixpkgs.url = "github:tadfisher/android-nixpkgs";
|
||||||
|
|
||||||
|
cursor.url = "github:omarcresp/cursor-flake/main";
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
outputs = {
|
||||||
|
self,
|
||||||
|
nixpkgs,
|
||||||
|
flake-parts,
|
||||||
|
cursor,
|
||||||
|
...
|
||||||
|
} @ inputs:
|
||||||
|
flake-parts.lib.mkFlake {inherit inputs;} {
|
||||||
|
systems = ["x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin"];
|
||||||
|
perSystem = {
|
||||||
|
pkgs,
|
||||||
|
system,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
devShells.default = let
|
||||||
|
pkgs = import nixpkgs {
|
||||||
|
inherit system;
|
||||||
|
config = {
|
||||||
|
allowUnfree = true;
|
||||||
|
android_sdk.accept_license = true;
|
||||||
|
};
|
||||||
|
overlays = [];
|
||||||
|
};
|
||||||
|
android-nixpkgs = pkgs.callPackage inputs.android-nixpkgs {};
|
||||||
|
androidSdk = android-nixpkgs.sdk (sdkPkgs:
|
||||||
|
with sdkPkgs; [
|
||||||
|
cmdline-tools-latest
|
||||||
|
build-tools-34-0-0
|
||||||
|
build-tools-30-0-3
|
||||||
|
platform-tools
|
||||||
|
platforms-android-35
|
||||||
|
platforms-android-34
|
||||||
|
platforms-android-33
|
||||||
|
platforms-android-31
|
||||||
|
platforms-android-30
|
||||||
|
ndk-26-3-11579264
|
||||||
|
cmake-3-22-1
|
||||||
|
]);
|
||||||
|
PWD = builtins.getEnv "PWD";
|
||||||
|
patchedFlutter = pkgs.flutter.override (prev: rec {
|
||||||
|
flutter = prev.flutter.overrideAttrs (prevAttrs: {
|
||||||
|
patches = prevAttrs.patches ++ [
|
||||||
|
# This patch is needed to avoid the Kotlin Gradle plugin writing to the store.
|
||||||
|
(pkgs.writeText "kotlin-fix.patch" ''
|
||||||
|
--- a/packages/flutter_tools/gradle/build.gradle.kts
|
||||||
|
+++ b/packages/flutter_tools/gradle/build.gradle.kts
|
||||||
|
@@ -4,6 +4,8 @@
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
|
||||||
|
|
||||||
|
+gradle.startParameter.projectCacheDir = layout.buildDirectory.dir("cache").get().asFile
|
||||||
|
+
|
||||||
|
plugins {
|
||||||
|
`java-gradle-plugin`
|
||||||
|
groovy
|
||||||
|
'')
|
||||||
|
];
|
||||||
|
passthru = prevAttrs.passthru // {
|
||||||
|
sdk = flutter;
|
||||||
|
};
|
||||||
|
# postInstall = (prevAttrs.postInstall or "") + ''
|
||||||
|
# mkdir -p $out/bin/cache
|
||||||
|
# touch $out/bin/cache/engine.realm
|
||||||
|
# '';
|
||||||
|
});
|
||||||
|
});
|
||||||
|
in
|
||||||
|
pkgs.mkShell {
|
||||||
|
ANDROID_SDK_ROOT = "${androidSdk}/libexec/android-sdk";
|
||||||
|
ANDROID_NDK_ROOT = "${androidSdk}/libexec/android-sdk/ndk-bundle";
|
||||||
|
ANDROID_AVD_HOME = "${PWD}/.android/avd";
|
||||||
|
ANDROID_HOME = "${androidSdk}/libexec/android-sdk";
|
||||||
|
FLUTTER_SDK = "${patchedFlutter}";
|
||||||
|
GRADLE_OPTS = "-Dorg.gradle.project.android.aapt2FromMavenOverride=${androidSdk}/share/android-sdk/build-tools/34.0.0/aapt2";
|
||||||
|
buildInputs = with pkgs; [
|
||||||
|
patchedFlutter
|
||||||
|
jdk17
|
||||||
|
androidSdk
|
||||||
|
clang
|
||||||
|
dart
|
||||||
|
cmake
|
||||||
|
android-tools
|
||||||
|
cursor.packages.${pkgs.system}.default
|
||||||
|
];
|
||||||
|
shellHook = ''
|
||||||
|
zsh
|
||||||
|
exit
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
# formatter = pkgs.alejandra;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user