cc-safe-setup 29.6.6 → 29.6.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,35 @@
1
+ #!/bin/bash
2
+ # ================================================================
3
+ # json-syntax-check.sh — Validate JSON files after editing
4
+ # ================================================================
5
+ # PURPOSE:
6
+ # Claude Code sometimes writes invalid JSON to settings.json,
7
+ # package.json, or tsconfig.json. This hook validates JSON
8
+ # syntax immediately after an edit, before it causes errors.
9
+ #
10
+ # TRIGGER: PostToolUse
11
+ # MATCHER: "Edit|Write"
12
+ # ================================================================
13
+
14
+ INPUT=$(cat)
15
+ TOOL=$(echo "$INPUT" | jq -r '.tool_name // empty' 2>/dev/null)
16
+ FILE=$(echo "$INPUT" | jq -r '.tool_input.file_path // empty' 2>/dev/null)
17
+
18
+ [ -z "$FILE" ] && exit 0
19
+
20
+ # Only check JSON files
21
+ echo "$FILE" | grep -qiE '\.json$|\.jsonc$' || exit 0
22
+
23
+ # Skip if file doesn't exist (Write to new file hasn't completed yet)
24
+ [ -f "$FILE" ] || exit 0
25
+
26
+ # Validate JSON
27
+ if ! jq empty "$FILE" 2>/dev/null; then
28
+ echo "⚠ Invalid JSON syntax in: $FILE" >&2
29
+ # Show the specific error
30
+ ERROR=$(jq empty "$FILE" 2>&1)
31
+ echo " Error: $ERROR" >&2
32
+ echo " Fix this before continuing — broken JSON will cause runtime errors." >&2
33
+ fi
34
+
35
+ exit 0
@@ -0,0 +1,43 @@
1
+ #!/bin/bash
2
+ # ================================================================
3
+ # markdown-link-check.sh — Verify local file links in markdown
4
+ # ================================================================
5
+ # PURPOSE:
6
+ # After Claude edits a markdown file, check that all local file
7
+ # references (relative paths) actually exist. Catches broken
8
+ # links to images, other docs, or code files.
9
+ #
10
+ # TRIGGER: PostToolUse
11
+ # MATCHER: "Edit|Write"
12
+ # ================================================================
13
+
14
+ INPUT=$(cat)
15
+ FILE=$(echo "$INPUT" | jq -r '.tool_input.file_path // empty' 2>/dev/null)
16
+
17
+ [ -z "$FILE" ] && exit 0
18
+ echo "$FILE" | grep -qiE '\.md$|\.mdx$' || exit 0
19
+ [ -f "$FILE" ] || exit 0
20
+
21
+ DIR=$(dirname "$FILE")
22
+ BROKEN=0
23
+
24
+ # Extract markdown links: [text](path) — skip URLs and anchors
25
+ while IFS= read -r link; do
26
+ # Skip URLs, anchors, and mailto
27
+ echo "$link" | grep -qE '^(https?://|#|mailto:)' && continue
28
+ # Remove anchor part
29
+ CLEAN=$(echo "$link" | sed 's/#.*//')
30
+ [ -z "$CLEAN" ] && continue
31
+ # Resolve relative path
32
+ TARGET="$DIR/$CLEAN"
33
+ if [ ! -e "$TARGET" ]; then
34
+ echo "⚠ Broken link in $FILE: $link" >&2
35
+ BROKEN=$((BROKEN + 1))
36
+ fi
37
+ done < <(grep -oE '\]\([^)]+\)' "$FILE" 2>/dev/null | sed 's/\](\(.*\))/\1/')
38
+
39
+ if [ "$BROKEN" -gt 0 ]; then
40
+ echo " $BROKEN broken link(s) found." >&2
41
+ fi
42
+
43
+ exit 0
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "cc-safe-setup",
3
- "version": "29.6.6",
4
- "description": "One command to make Claude Code safe. 416 example hooks + 8 built-in. 52 CLI commands. 5633 tests. Works with Auto Mode.",
3
+ "version": "29.6.8",
4
+ "description": "One command to make Claude Code safe. 418 example hooks + 8 built-in. 52 CLI commands. 5646 tests. Works with Auto Mode.",
5
5
  "main": "index.mjs",
6
6
  "bin": {
7
7
  "cc-safe-setup": "index.mjs"