From 3ed563d1575b9b912d20caf43764c5caf2c4b050 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Thu, 3 Jul 2025 23:16:26 +0900 Subject: claude-code: support zsh --- home-manager/config/bash/.bashrc | 45 +---------------------------------- home-manager/config/sh/claude-code.sh | 44 ++++++++++++++++++++++++++++++++++ home-manager/config/zsh/.zshrc | 1 + 3 files changed, 46 insertions(+), 44 deletions(-) create mode 100644 home-manager/config/sh/claude-code.sh create mode 100644 home-manager/config/zsh/.zshrc (limited to 'home-manager/config') diff --git a/home-manager/config/bash/.bashrc b/home-manager/config/bash/.bashrc index 39d2837..439e34c 100644 --- a/home-manager/config/bash/.bashrc +++ b/home-manager/config/bash/.bashrc @@ -1,44 +1 @@ -# Safe wrappers for Claude Code -if [[ -n "$CLAUDECODE" ]]; then - # Safe wrapper for find command - find() { - local has_dangerous=0 - - for arg in "$@"; do - case "$arg" in - -delete|-exec|-execdir|-fls|-fprint|-fprint0|-fprintf|-ok|-okdir) - has_dangerous=1 - break - ;; - esac - done - - if [[ $has_dangerous == 1 ]]; then - echo "Error: dangerous actions, -delete/-exec/-execdir/-fls/-fprint/-fprint0/-fprintf/-ok/-okdir, are not allowed in Claude Code environment" >&2 - return 1 - fi - - command find "$@" - } - - # Safe wrapper for fd command - fd() { - local has_dangerous=0 - - for arg in "$@"; do - case "$arg" in - -x|--exec|-X|--exec-batch) - has_dangerous=1 - break - ;; - esac - done - - if [[ $has_dangerous == 1 ]]; then - echo "Error: dangerous actions, -x/--exec/-X/--exec-batch, are not allowed in Claude Code environment" >&2 - return 1 - fi - - command fd "$@" - } -fi +source "${XDG_CONFIG_HOME:-$HOME/.config}"/sh/claude-code.sh diff --git a/home-manager/config/sh/claude-code.sh b/home-manager/config/sh/claude-code.sh new file mode 100644 index 0000000..0b467bb --- /dev/null +++ b/home-manager/config/sh/claude-code.sh @@ -0,0 +1,44 @@ +# Safe wrappers for Claude Code +if [ -n "$CLAUDECODE" ]; then + # Safe wrapper for find command + find() { + has_dangerous=0 + + for arg in "$@"; do + case "$arg" in + -delete|-exec|-execdir|-fls|-fprint|-fprint0|-fprintf|-ok|-okdir) + has_dangerous=1 + break + ;; + esac + done + + if [ $has_dangerous = 1 ]; then + echo "Error: dangerous actions, -delete/-exec/-execdir/-fls/-fprint/-fprint0/-fprintf/-ok/-okdir, are not allowed in Claude Code environment" >&2 + return 1 + fi + + command find "$@" + } + + # Safe wrapper for fd command + fd() { + has_dangerous=0 + + for arg in "$@"; do + case "$arg" in + -x|--exec|-X|--exec-batch) + has_dangerous=1 + break + ;; + esac + done + + if [ $has_dangerous = 1 ]; then + echo "Error: dangerous actions, -x/--exec/-X/--exec-batch, are not allowed in Claude Code environment" >&2 + return 1 + fi + + command fd "$@" + } +fi \ No newline at end of file diff --git a/home-manager/config/zsh/.zshrc b/home-manager/config/zsh/.zshrc new file mode 100644 index 0000000..439e34c --- /dev/null +++ b/home-manager/config/zsh/.zshrc @@ -0,0 +1 @@ +source "${XDG_CONFIG_HOME:-$HOME/.config}"/sh/claude-code.sh -- cgit v1.2.3-70-g09d2