1
1
mirror of https://github.com/the-nix-way/dev-templates synced 2025-07-24 16:19:46 +02:00
Dev environments for numerous languages based on Nix flakes
Go to file
2025-06-08 09:18:30 -07:00
.github
bun
c-cpp
clojure
cue
dhall
elixir
elm
empty
gleam
go
hashi
haskell
haxe
java
jupyter
kotlin
latex
lean4
nickel
nim
nix
node
ocaml
odin
opa
php
platformio
protobuf
pulumi
purescript
python
r
ruby
rust
rust-toolchain
scala
shell
swi-prolog
swift
vlang
zig
.editorconfig
.envrc
.gitignore
flake.lock
flake.nix Use FlakeHub ref for dvt 2025-06-08 09:18:30 -07:00
README.md

Nix flake templates for easy dev environments

built with nix

To initialize (where ${ENV} is listed in the table below):

nix flake init --template "https://flakehub.com/f/the-nix-way/dev-templates/*#${ENV}"

Here's an example (for the rust template):

# Initialize in the current project
nix flake init --template "https://flakehub.com/f/the-nix-way/dev-templates/*#rust"

# Create a new project
nix flake new --template "https://flakehub.com/f/the-nix-way/dev-templates/*#rust" ${NEW_PROJECT_DIRECTORY}

How to use the templates

Once your preferred template has been initialized, you can use the provided shell in two ways:

  1. If you have nix-direnv installed, you can initialize the environment by running direnv allow.
  2. If you don't have nix-direnv installed, you can run nix develop to open up the Nix-defined shell.

Available templates

Language/framework/tool Template
Bun bun
C/C++ c-cpp
Clojure clojure
Cue cue
Dhall dhall
Elixir elixir
Elm elm
Empty (change at will) empty
Gleam gleam
Go go
Hashicorp tools hashi
Haskell haskell
Haxe haxe
Java java
Jupyter jupyter
Kotlin kotlin
LaTeX latex
Nickel nickel
Nim nim
Nix nix
Node.js node
OCaml ocaml
Odin odin
Open Policy Agent opa
PHP php
PlatformIO platformio
Protobuf protobuf
Pulumi pulumi
Purescript purescript
Python python
R r
Ruby ruby
Rust rust
Rust from toolchain file rust-toolchain
Scala scala
Shell shell
SWI-prolog swi-prolog
Swift swift
Vlang vlang
Zig zig

Template contents

The sections below list what each template includes. In all cases, you're free to add and remove packages as you see fit; the templates are just boilerplate.

bun

c-cpp

clojure

cue

dhall

elixir

elm

Empty

A dev template that's fully customizable.

gleam

go

hashi

haskell

haxe

java

jupyter

kotlin

latex

lean4

nickel

nim

nix

node

ocaml

odin

opa

php

platformio

protobuf

pulumi

purescript

python

r

ruby

  • Ruby, plus the standard Ruby tools (bundle, gem, etc.)

rust

  • Rust, including cargo, Clippy, and the other standard tools. The Rust version is determined as follows, in order:

    • From the rust-toolchain.toml file if present
    • From the rust-toolchain file if present
    • Version 1.78.0 if neither is present
  • rust-analyzer

  • cargo-edit

  • cargo-deny

scala

shell

swi-prolog

swift

vlang

zig