mirror of
https://github.com/Matir/skel.git
synced 2026-05-25 21:19:09 -07:00
Improve gemini context
This commit is contained in:
@@ -7,7 +7,7 @@ export GEMINI_CONTEXT_DIR="${XDG_CONFIG_HOME:-$HOME/.config}/gemini"
|
||||
mkdir -p "$GEMINI_CONTEXT_DIR"
|
||||
|
||||
# Template settings file
|
||||
GEMINI_TEMPLATE_SETTINGS="${HOME}/.skel/dotfiles/config/gemini/settings.json"
|
||||
GEMINI_TEMPLATE_SETTINGS="${GEMINI_CONTEXT_DIR}/settings.json"
|
||||
|
||||
# Create a new Gemini context
|
||||
gemini-context-create() {
|
||||
@@ -19,8 +19,13 @@ gemini-context-create() {
|
||||
local context_name="$1"
|
||||
local context_path="$GEMINI_CONTEXT_DIR/$context_name"
|
||||
|
||||
if [[ "$context_name" =~ [/] ]]; then
|
||||
echo "Error: Context name cannot contain slashes."
|
||||
if [[ "$context_name" =~ [^a-zA-Z0-9_-] ]]; then
|
||||
echo "Error: Context name should only contain alphanumeric characters, underscores, or dashes."
|
||||
return 1
|
||||
fi
|
||||
|
||||
if [[ "$context_name" == .* ]]; then
|
||||
echo "Error: Context name cannot start with a dot."
|
||||
return 1
|
||||
fi
|
||||
|
||||
@@ -42,25 +47,90 @@ gemini-context-create() {
|
||||
echo "Context '$context_name' created."
|
||||
}
|
||||
|
||||
# List available Gemini contexts
|
||||
# List available Gemini contexts (directories only, containing .gemini)
|
||||
_gemini_context_list_internal() {
|
||||
command ls "$GEMINI_CONTEXT_DIR" 2>/dev/null
|
||||
local contexts
|
||||
# Use Zsh globbing: find directories containing a .gemini subdir
|
||||
contexts=($GEMINI_CONTEXT_DIR/*/.gemini(N/:h:t))
|
||||
[[ ${#contexts} -gt 0 ]] && print -l "${contexts[@]}"
|
||||
}
|
||||
|
||||
gemini-context-list() {
|
||||
echo "Available Gemini contexts:"
|
||||
local contexts=$(_gemini_context_list_internal)
|
||||
if [ -z "$contexts" ]; then
|
||||
local contexts=($(_gemini_context_list_internal))
|
||||
if [ ${#contexts} -eq 0 ]; then
|
||||
echo " (No contexts found)"
|
||||
return
|
||||
fi
|
||||
for context in $contexts; do
|
||||
if [ -d "$GEMINI_CONTEXT_DIR/$context" ]; then
|
||||
echo " $context"
|
||||
for context in "${contexts[@]}"; do
|
||||
if [ "$GEMINI_CLI_HOME" = "$GEMINI_CONTEXT_DIR/$context" ]; then
|
||||
echo " * $context (active)"
|
||||
else
|
||||
echo " $context"
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
# Delete a Gemini context
|
||||
gemini-context-delete() {
|
||||
local context_name
|
||||
if [ -z "$1" ]; then
|
||||
if command -v fzf >/dev/null; then
|
||||
context_name=$(_gemini_context_list_internal | fzf --prompt="Select Gemini Context to DELETE: ")
|
||||
[[ -z "$context_name" ]] && return 1
|
||||
else
|
||||
echo "Usage: gemini-context-delete <name>"
|
||||
return 1
|
||||
fi
|
||||
else
|
||||
context_name="$1"
|
||||
fi
|
||||
|
||||
local context_path="$GEMINI_CONTEXT_DIR/$context_name"
|
||||
if [ ! -d "$context_path" ]; then
|
||||
echo "Error: Context '$context_name' not found."
|
||||
return 1
|
||||
fi
|
||||
|
||||
if read -q "confirm?Are you sure you want to delete context '$context_name'? [y/N] "; then
|
||||
echo
|
||||
rm -rf "$context_path"
|
||||
echo "Context '$context_name' deleted."
|
||||
if [ "$GEMINI_CLI_HOME" = "$context_path" ]; then
|
||||
gemini-context-unset
|
||||
fi
|
||||
else
|
||||
echo "\nDeletion cancelled."
|
||||
fi
|
||||
}
|
||||
|
||||
# Rename a Gemini context
|
||||
gemini-context-rename() {
|
||||
if [ -z "$1" ] || [ -z "$2" ]; then
|
||||
echo "Usage: gemini-context-rename <old_name> <new_name>"
|
||||
return 1
|
||||
fi
|
||||
|
||||
local old_path="$GEMINI_CONTEXT_DIR/$1"
|
||||
local new_path="$GEMINI_CONTEXT_DIR/$2"
|
||||
|
||||
if [ ! -d "$old_path" ]; then
|
||||
echo "Error: Source context '$1' not found."
|
||||
return 1
|
||||
fi
|
||||
|
||||
if [ -d "$new_path" ]; then
|
||||
echo "Error: Destination context '$2' already exists."
|
||||
return 1
|
||||
fi
|
||||
|
||||
mv "$old_path" "$new_path"
|
||||
echo "Context '$1' renamed to '$2'."
|
||||
if [ "$GEMINI_CLI_HOME" = "$old_path" ]; then
|
||||
gemini-context-use -q "$2"
|
||||
fi
|
||||
}
|
||||
|
||||
# Use a specific Gemini context
|
||||
gemini-context-use() {
|
||||
local context_name
|
||||
@@ -89,14 +159,13 @@ gemini-context-use() {
|
||||
|
||||
local context_path="$GEMINI_CONTEXT_DIR/$context_name"
|
||||
|
||||
if [ ! -d "$context_path" ]; then
|
||||
[[ "$quiet" -eq 0 ]] && echo "Error: Context '$context_name' not found at $context_path"
|
||||
[[ "$quiet" -eq 0 ]] && gemini-context-list
|
||||
if [ ! -d "$context_path/.gemini" ]; then
|
||||
[[ "$quiet" -eq 0 ]] && echo "Error: '$context_name' is not a valid Gemini context (missing .gemini directory)."
|
||||
return 1
|
||||
fi
|
||||
|
||||
export GEMINI_CLI_HOME="$context_path"
|
||||
[[ "$quiet" -eq 0 ]] && echo "Switched to Gemini context '$context_name' (GEMINI_CLI_HOME=$GEMINI_CLI_HOME)"
|
||||
[[ "$quiet" -eq 0 ]] && echo "Switched to Gemini context '$context_name'"
|
||||
}
|
||||
|
||||
# Edit a context's settings
|
||||
@@ -136,13 +205,12 @@ gemini-context-edit() {
|
||||
# Show the current Gemini context
|
||||
gemini-context-current() {
|
||||
if [ -n "$GEMINI_CLI_HOME" ]; then
|
||||
local current_context=$(basename "$GEMINI_CLI_HOME")
|
||||
local current_context=${GEMINI_CLI_HOME:t}
|
||||
if [ "$GEMINI_CONTEXT_DIR/$current_context" = "$GEMINI_CLI_HOME" ]; then
|
||||
echo "Current Gemini context: $current_context"
|
||||
else
|
||||
echo "Current Gemini context: Custom"
|
||||
echo "Current Gemini context: Custom ($GEMINI_CLI_HOME)"
|
||||
fi
|
||||
echo "GEMINI_CLI_HOME=$GEMINI_CLI_HOME"
|
||||
else
|
||||
echo "No Gemini context set, using default."
|
||||
fi
|
||||
@@ -157,12 +225,12 @@ gemini-context-unset() {
|
||||
# Alias for gemini-context-use
|
||||
alias gemctx='gemini-context-use'
|
||||
|
||||
# Zsh Completion for gemini-context-use and gemctx
|
||||
# Zsh Completion
|
||||
_gemini_contexts() {
|
||||
local contexts
|
||||
local -a contexts
|
||||
contexts=($(_gemini_context_list_internal))
|
||||
_describe 'gemini contexts' contexts
|
||||
}
|
||||
compdef _gemini_contexts gemini-context-use
|
||||
compdef _gemini_contexts gemctx
|
||||
compdef _gemini_contexts gemini-context-edit
|
||||
|
||||
compdef _gemini_contexts gemini-context-use gemctx gemini-context-edit gemini-context-delete gemini-context-rename
|
||||
|
||||
|
||||
Reference in New Issue
Block a user