From c46a9a57b6b538d26b5c8d2e79f6ba0f407f601e Mon Sep 17 00:00:00 2001 From: Ryan Yin Date: Fri, 26 Jul 2024 10:46:34 +0800 Subject: [PATCH] feat: update dev-env (#173) --- docs/development/dev-environments.md | 45 ++++++++++++++++++------- docs/zh/development/dev-environments.md | 32 ++++++++++++------ 2 files changed, 55 insertions(+), 22 deletions(-) diff --git a/docs/development/dev-environments.md b/docs/development/dev-environments.md index a2b96a5..e2e229b 100644 --- a/docs/development/dev-environments.md +++ b/docs/development/dev-environments.md @@ -1,17 +1,38 @@ # Dev Environments -On NixOS, in the global environment (home-manager), you can install only some general -development tools and SDKs, such as `git`, `vim`, `emacs`, `tmux`, `zsh`, etc. For the -dependencies of the project itself, it is best to have a separate `flake.nix` for each -project to manage their respective development environments. - -For simplicity, you might also consider creating some general `flake.nix` templates for -common languages in advance, which can be copied and modified as needed. - -Various plugins for editors like `neovim` will also have their own dependencies. These -dependencies can be considered to be added to the IDE's own environment through parameters -like `programs.neovim.extraPackages` in home-manager, ensuring that the IDE itself can run -properly without polluting the global environment. +On NixOS, we have a variety of methods to set up development environments, with the most +ideal approach being a complete definition of each project's development environment +through its own `flake.nix`. However, this can be somewhat cumbersome in practice, as it +requires crafting a `flake.nix` and then running `nix develop` for each instance. For +temporary projects or when one simply wants to glance at the code, this approach is +somewhat overkill. + +A compromise is to divide the development environment into three tiers: + +1. **Global Environment**: This typically refers to the user environment managed by + home-manager. + - Universal development tools: `git`, `vim`, `emacs`, `tmux`, and the like. + - Common language SDKs and package managers: `rust`, `openjdk`, `python`, `go`, among + others. +2. **IDE Environment**: + - Taking neovim as an example, home-manager creates a wrapper for neovim that + encapsulates its dependencies within its own environment, preventing contamination of + the global environment. + - Dependencies for neovim plugins can be added to the neovim environment via the + `programs.neovim.extraPackages` parameter, ensuring the IDE operates smoothly. + - However, if you use multiple IDEs (such as emacs and neovim), they often rely on many + of the same programs (like lsp, tree-sitter, debugger, formatter, etc.). For ease of + management, these shared dependencies can be placed in the global environment. Be + cautious of potential dependency conflicts with other programs in the global + environment, particularly with python packages, which are prone to conflicts. +3. **Project Environment**: Each project can define its own development environment + (`devShells`) via `flake.nix`. + - To simplify, you can create generic `flake.nix` templates for commonly used languages + in advance, which can be copied and modified as needed. + - The project environment takes the highest precedence (added to the front of the + PATH), and its dependencies will override those with the same name in the global + environment. Thus, you can control the version of project dependencies via the + project's `flake.nix`, unaffected by the global environment. ## Templates for Development Environments diff --git a/docs/zh/development/dev-environments.md b/docs/zh/development/dev-environments.md index 730b01f..ef2bf43 100644 --- a/docs/zh/development/dev-environments.md +++ b/docs/zh/development/dev-environments.md @@ -1,15 +1,27 @@ # Dev Environments -在 NixOS 上,全局环境中(home-manager)可以只安装一些通用的开发工具与 SDK,比如 -`git`、`vim`、`emacs`、`tmux`、`zsh` 等等。对于项目本身的依赖,最好是每个项目都有一个独立 -的 `flake.nix` 用于管理各自的开发环境。 - -为了简便,你也可以考虑提前为常用语言创建一些通用的 `flake.nix` 模板,在需要的时候复制模板 -改一改就能用了。 - -`neovim` 等编辑器的各种插件本身也会有各种依赖,这些依赖可以考虑通过 home-manager 的 -`programs.neovim.extraPackages` 等参数来将其加入到 IDE 本身的环境中,这样就能保证 IDE 本身 -能正常运行,又不会污染全局环境。 +在 NixOS 上,我们有许多种安装开发环境的途径,最理想的方式当然是每个项目的开发环境都完全通 +过它自己的 `flake.nix` 定义,但实际使用上这样做有些繁琐,每次都得弄个 `flake.nix` 出来再 +`nix develop` 一下,对于一些临时项目或者只是想简单看看代码的情况,这样做显然有些大材小用。 + +一个折衷的方案是将开发环境分为三个层次: + +1. **全局环境**:通常这是指由 home-manager 管理的用户环境。 + - 通用的开发工具:`git`、`vim`、`emacs`、`tmux` 等等。 + - 常见语言的 SDK 与包管理器:`rust`、`openjdk`、`python`、`go` 等等。 +1. **IDE 环境**: + - 以 neovim 为例,home-manager 为 neovim 做了一个 wrapper 用于将 neovim 自身的依赖封装 + 到它本身的环境中,避免污染全局环境。 + - 可通过 `programs.neovim.extraPackages` 参数将 neovim 的插件依赖加入到 neovim 的环境 + 中,保证 IDE 本身能正常运行。 + - 但如果你有多个 IDE(如 emacs 跟 neovim),它们常常会依赖许多相同的程序(譬如 lsp, + tree-sitter, debugger, formatter 等),为了方便管理,可以将这些共享的依赖放到全局。但 + 要注意可能会跟全局环境中的其他程序产生依赖冲突(尤其是 python 包,比较容易冲突)。 +1. **项目环境**:每个项目都可以通过 `flake.nix` 定义自己的开发环境(`devShells`)。 + - 为了简便,可以提前为常用语言创建一些通用的 `flake.nix` 模板,在需要的时候复制模板改一 + 改就能用。 + - 项目环境的优先级是最高的(会被加到 PATH 最前面),其中的依赖会覆盖掉全局环境中同名的 + 依赖程序。所以你可以通过项目的 `flake.nix` 来控制项目的依赖版本,不受全局环境的影响。 ## 开发环境的配置模板