mirror of
https://github.com/GraphiteEditor/Graphite.git
synced 2025-07-07 15:55:00 +00:00

* Update gpu nodes to compile again Restructure `gpu-executor` and `wgpu-executor` And libssl to nix shell Fix graphene-cli and add half percision color format Fix texture scaling Remove vulkan executor Fix compile errors Improve execution request deduplication * Fix warnings * Fix graph compile issues * Code review * Remove test file * Fix lint * Wip make node futures send * Make futures Send on non wasm targets * Fix warnings * Fix nested use of block_on --------- Co-authored-by: Keavon Chambers <keavon@keavon.com>
74 lines
2.2 KiB
Nix
74 lines
2.2 KiB
Nix
# This is a helper file for people using NixOs as their Operating System
|
|
# > If you don't know what this file does you can safely ignore it :D
|
|
|
|
# If you are using nix as your package manager, you can run 'nix-shell'
|
|
# in the root directory of the project and nix will open a bash shell
|
|
# with all the packages needed to build and run Graphite installed.
|
|
# A shell.nix file is used in the Nix ecosystem to define a development
|
|
# environment with specific dependencies. When you enter a Nix shell using
|
|
# this file, it ensures that all the specified tools and libraries are
|
|
# available regardless of the host system's configuration. This provides
|
|
# a reproducible development environment across different machines and developers.
|
|
|
|
# If you don't need the shell, you can build Graphite using this command:
|
|
# nix-shell --command "npm start"
|
|
|
|
let
|
|
# Get oxalica's Rust overlay for better Rust integration
|
|
rust-overlay-source = builtins.fetchGit {
|
|
url = "https://github.com/oxalica/rust-overlay";
|
|
};
|
|
|
|
# Import it so we can use it in Nix
|
|
rust-overlay = import rust-overlay-source;
|
|
|
|
# Import system packages overlaid with the Rust overlay
|
|
pkgs = import <nixpkgs> {
|
|
overlays = [ rust-overlay ];
|
|
};
|
|
|
|
# Define the rustc we need
|
|
rustc-wasm = pkgs.rust-bin.stable.latest.default.override {
|
|
targets = [ "wasm32-unknown-unknown" ];
|
|
# wasm-pack needs this
|
|
extensions = [ "rust-src" "rust-analyzer" "clippy"];
|
|
};
|
|
in
|
|
# Make a shell with the dependencies we need
|
|
pkgs.mkShell {
|
|
packages = [
|
|
rustc-wasm
|
|
pkgs.nodejs
|
|
pkgs.cargo
|
|
pkgs.cargo-watch
|
|
pkgs.cargo-nextest
|
|
pkgs.cargo-expand
|
|
pkgs.wasm-pack
|
|
pkgs.wasm-bindgen-cli
|
|
pkgs.vulkan-loader
|
|
pkgs.libxkbcommon
|
|
pkgs.llvm
|
|
pkgs.gcc-unwrapped.lib
|
|
pkgs.llvmPackages.libcxxStdenv
|
|
|
|
pkgs.openssl
|
|
pkgs.glib
|
|
pkgs.gtk3
|
|
pkgs.libsoup
|
|
pkgs.webkitgtk
|
|
|
|
pkgs.pkg-config
|
|
pkgs.openssl
|
|
|
|
# Use Mold as a Linke
|
|
pkgs.mold
|
|
];
|
|
|
|
|
|
# Hacky way to run cago through Mold
|
|
LD_LIBRARY_PATH = pkgs.lib.makeLibraryPath [pkgs.openssl pkgs.vulkan-loader pkgs.libxkbcommon pkgs.llvmPackages.libcxxStdenv pkgs.gcc-unwrapped.lib pkgs.llvm];
|
|
shellHook = ''
|
|
alias cargo='mold --run cargo'
|
|
'';
|
|
}
|
|
|