server/priv/docs/zh_Hans/cli/directories.md
Tuist 遵循 XDG 基本目录规范,在系统中的多个目录中组织文件。这为管理配置、缓存和状态文件提供了一种简洁、标准的方式。
Tuist 既支持标准 XDG 变量,也支持 Tuist 特有的前缀变量。Tuist 专用变量(前缀为TUIST_ )优先,允许您将 Tuist
与其他应用程序分开配置。
环境变量:
TUIST_XDG_CONFIG_HOME (优先)。xdg_config_home默认值: ~/.config/tuist
用于:
credentials/{host}.json)例如
# Set Tuist-specific config directory
export TUIST_XDG_CONFIG_HOME=/custom/config
tuist auth login
# Or use standard XDG variable
export XDG_CONFIG_HOME=/custom/config
tuist auth login
环境变量:
TUIST_XDG_CACHE_HOME (优先)。XDG_CACHE_HOME默认值: ~/.cache/tuist
用于:
例如
# Set Tuist-specific cache directory
export TUIST_XDG_CACHE_HOME=/tmp/tuist-cache
tuist cache
# Or use standard XDG variable
export XDG_CACHE_HOME=/tmp/cache
tuist cache
环境变量:
TUIST_XDG_STATE_HOME (优先使用)XDG_STATE_HOME默认值: ~/.local/state/tuist
用于:
logs/{uuid}.log){handle}.sock)例如
# Set Tuist-specific state directory
export TUIST_XDG_STATE_HOME=/var/log/tuist
tuist generate
# Or use standard XDG variable
export XDG_STATE_HOME=/var/log
tuist generate
在确定使用哪个目录时,Tuist 会按以下顺序检查环境变量:
TUIST_XDG_CONFIG_HOME)XDG_CONFIG_HOME)~/.config/tuist)这样您就可以
您可能需要在每个项目中隔离 Tuist 的缓存和状态:
# In your project's .envrc (using direnv)
export TUIST_XDG_CACHE_HOME="$PWD/.tuist/cache"
export TUIST_XDG_STATE_HOME="$PWD/.tuist/state"
export TUIST_XDG_CONFIG_HOME="$PWD/.tuist/config"
在 CI 环境中,您可能需要使用临时目录:
# GitHub Actions example
env:
TUIST_XDG_CACHE_HOME: /tmp/tuist-cache
TUIST_XDG_STATE_HOME: /tmp/tuist-state
jobs:
build:
runs-on: macos-latest
steps:
- uses: actions/checkout@v4
- run: tuist generate
- name: Upload logs
if: failure()
uses: actions/upload-artifact@v4
with:
name: tuist-logs
path: /tmp/tuist-state/logs/*.log
在调试问题时,你可能需要一块干净的石板:
# Create temporary directories for debugging
export TUIST_XDG_CACHE_HOME=$(mktemp -d)
export TUIST_XDG_STATE_HOME=$(mktemp -d)
export TUIST_XDG_CONFIG_HOME=$(mktemp -d)
# Run Tuist commands
tuist generate
# Clean up when done
rm -rf $TUIST_XDG_CACHE_HOME $TUIST_XDG_STATE_HOME $TUIST_XDG_CONFIG_HOME