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

* Rename within files * Rename in CI * Rename the folder and file names * Rename raw_rs to rawkit * Add example to README * Add initial documentation * Small API changes and extra documentation * Bump versions and stuff * Readme improvements * Merge proc-macro crates into one * Add README to rawkit-proc-macros * Remove keywords and categories * Add licenses to rawkit-proc-macros --------- Co-authored-by: Keavon Chambers <keavon@keavon.com>
81 lines
2.4 KiB
Nix
81 lines
2.4 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.
|
|
|
|
# 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.
|
|
|
|
# You can enter the Nix shell and run Graphite like normal with:
|
|
# > npm start
|
|
# Or you can run it like this without needing to first enter the Nix shell:
|
|
# > 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 = with pkgs; [
|
|
rustc-wasm
|
|
nodejs
|
|
cargo
|
|
cargo-watch
|
|
cargo-nextest
|
|
cargo-expand
|
|
wasm-pack
|
|
binaryen
|
|
wasm-bindgen-cli
|
|
vulkan-loader
|
|
libxkbcommon
|
|
llvm
|
|
gcc-unwrapped.lib
|
|
llvmPackages.libcxxStdenv
|
|
pkg-config
|
|
# used for profiling
|
|
gnuplot
|
|
samply
|
|
cargo-flamegraph
|
|
|
|
# For Tauri
|
|
openssl
|
|
glib
|
|
gtk3
|
|
libsoup
|
|
webkitgtk
|
|
|
|
# For Rawkit tests
|
|
libraw
|
|
|
|
# Use Mold as a linker
|
|
mold
|
|
];
|
|
|
|
# Hacky way to run Cargo through Mold
|
|
LD_LIBRARY_PATH = pkgs.lib.makeLibraryPath [pkgs.openssl pkgs.vulkan-loader pkgs.libxkbcommon pkgs.llvmPackages.libcxxStdenv pkgs.gcc-unwrapped.lib pkgs.llvm pkgs.libraw];
|
|
shellHook = ''
|
|
alias cargo='mold --run cargo'
|
|
'';
|
|
}
|