mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-04-11 03:43:30 +08:00
fix: preserve directory structure in installation to prevent file overwrites (#169)
Fix installation instructions that caused file overwrites. Adds install.sh script and preserves directory structure. Fixes #164.
This commit is contained in:
51
install.sh
Executable file
51
install.sh
Executable file
@@ -0,0 +1,51 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# install.sh — Install claude rules while preserving directory structure.
|
||||||
|
#
|
||||||
|
# Usage:
|
||||||
|
# ./install.sh <language> [<language> ...]
|
||||||
|
#
|
||||||
|
# Examples:
|
||||||
|
# ./install.sh typescript
|
||||||
|
# ./install.sh typescript python golang
|
||||||
|
#
|
||||||
|
# This script copies rules into ~/.claude/rules/ keeping the common/ and
|
||||||
|
# language-specific subdirectories intact so that:
|
||||||
|
# 1. Files with the same name in common/ and <language>/ don't overwrite
|
||||||
|
# each other.
|
||||||
|
# 2. Relative references (e.g. ../common/coding-style.md) remain valid.
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
RULES_DIR="$(cd "$(dirname "$0")/rules" && pwd)"
|
||||||
|
DEST_DIR="${CLAUDE_RULES_DIR:-$HOME/.claude/rules}"
|
||||||
|
|
||||||
|
if [[ $# -eq 0 ]]; then
|
||||||
|
echo "Usage: $0 <language> [<language> ...]"
|
||||||
|
echo ""
|
||||||
|
echo "Available languages:"
|
||||||
|
for dir in "$RULES_DIR"/*/; do
|
||||||
|
name="$(basename "$dir")"
|
||||||
|
[[ "$name" == "common" ]] && continue
|
||||||
|
echo " - $name"
|
||||||
|
done
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Always install common rules
|
||||||
|
echo "Installing common rules -> $DEST_DIR/common/"
|
||||||
|
mkdir -p "$DEST_DIR/common"
|
||||||
|
cp -r "$RULES_DIR/common/." "$DEST_DIR/common/"
|
||||||
|
|
||||||
|
# Install each requested language
|
||||||
|
for lang in "$@"; do
|
||||||
|
lang_dir="$RULES_DIR/$lang"
|
||||||
|
if [[ ! -d "$lang_dir" ]]; then
|
||||||
|
echo "Warning: rules/$lang/ does not exist, skipping." >&2
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
echo "Installing $lang rules -> $DEST_DIR/$lang/"
|
||||||
|
mkdir -p "$DEST_DIR/$lang"
|
||||||
|
cp -r "$lang_dir/." "$DEST_DIR/$lang/"
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Done. Rules installed to $DEST_DIR/"
|
||||||
@@ -25,17 +25,36 @@ rules/
|
|||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
|
### Option 1: Install Script (Recommended)
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Install common + one or more language-specific rule sets
|
||||||
|
./install.sh typescript
|
||||||
|
./install.sh python
|
||||||
|
./install.sh golang
|
||||||
|
|
||||||
|
# Install multiple languages at once
|
||||||
|
./install.sh typescript python
|
||||||
|
```
|
||||||
|
|
||||||
|
### Option 2: Manual Installation
|
||||||
|
|
||||||
|
> **Important:** Copy entire directories — do NOT flatten with `/*`.
|
||||||
|
> Common and language-specific directories contain files with the same names.
|
||||||
|
> Flattening them into one directory causes language-specific files to overwrite
|
||||||
|
> common rules, and breaks the relative `../common/` references used by
|
||||||
|
> language-specific files.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
# Install common rules (required for all projects)
|
# Install common rules (required for all projects)
|
||||||
cp -r rules/common/* ~/.claude/rules/
|
cp -r rules/common ~/.claude/rules/common
|
||||||
|
|
||||||
# Install language-specific rules based on your project's tech stack
|
# Install language-specific rules based on your project's tech stack
|
||||||
cp -r rules/typescript/* ~/.claude/rules/
|
cp -r rules/typescript ~/.claude/rules/typescript
|
||||||
cp -r rules/python/* ~/.claude/rules/
|
cp -r rules/python ~/.claude/rules/python
|
||||||
cp -r rules/golang/* ~/.claude/rules/
|
cp -r rules/golang ~/.claude/rules/golang
|
||||||
|
|
||||||
# Attention ! ! ! Configure according to your actual project requirements; the configuration here is for reference only.
|
# Attention ! ! ! Configure according to your actual project requirements; the configuration here is for reference only.
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## Rules vs Skills
|
## Rules vs Skills
|
||||||
|
|||||||
Reference in New Issue
Block a user