Add gemini sub-commands to .zshrc
This commit is contained in:
parent
429c1fca38
commit
3a9b2d993f
2 changed files with 68 additions and 18 deletions
|
@ -12,6 +12,7 @@ This document outlines my general preferences for working with Gemini.
|
||||||
- **Handling Ambiguity**: If a request is unclear or could be interpreted in multiple ways, always stop and ask for clarification.
|
- **Handling Ambiguity**: If a request is unclear or could be interpreted in multiple ways, always stop and ask for clarification.
|
||||||
- **Logging**: Unless instructed otherwise, add descriptive logging statements for errors. For logical flows, add messages like "Starting {logic}" and "Successfully completed {logic}".
|
- **Logging**: Unless instructed otherwise, add descriptive logging statements for errors. For logical flows, add messages like "Starting {logic}" and "Successfully completed {logic}".
|
||||||
- **API Design**: While not a primary task, prefer `snake_case` for JSON field names. Above all, always remain consistent with the conventions of the current project.
|
- **API Design**: While not a primary task, prefer `snake_case` for JSON field names. Above all, always remain consistent with the conventions of the current project.
|
||||||
|
- **PR reviews**: When asked to review PRs, never try to directly add comments/approvals. Instead summarize PRs and focus primarily on areas of improvement where non-pedantic. Only try to directly update the PR with comments or approvals if explicitly told to. You have access to the `gh` command line tool so use that to pull PR diffs.
|
||||||
|
|
||||||
|
|
||||||
## Language-Specific Guidelines
|
## Language-Specific Guidelines
|
||||||
|
|
85
home/.zshrc
85
home/.zshrc
|
@ -25,32 +25,78 @@ export PASSWORD_STORE_CHARACTER_SET='a-zA-Z0-9+\-$!*_='
|
||||||
export XDEB_PKGROOT=${HOME}/.config/xdeb
|
export XDEB_PKGROOT=${HOME}/.config/xdeb
|
||||||
|
|
||||||
# Custom path additions
|
# Custom path additions
|
||||||
|
source ~/.profile
|
||||||
export PATH="$PATH:/usr/local/cuda-12.8/bin:$HOME/bin"
|
export PATH="$PATH:/usr/local/cuda-12.8/bin:$HOME/bin"
|
||||||
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/local/cuda-12.8/lib64"
|
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/usr/local/cuda-12.8/lib64"
|
||||||
|
|
||||||
#==============================================================================
|
|
||||||
# OS-Specific Configuration
|
|
||||||
#==============================================================================
|
|
||||||
|
|
||||||
if [ "$(uname)" = "Darwin" ]; then
|
|
||||||
export PATH="$PATH:/opt/homebrew/bin"
|
|
||||||
alias ls="gls --classify --group-directories-first --color"
|
|
||||||
alias gemini="(source ~/.gemini_project && gemini)"
|
|
||||||
export NVIM_JDTLS_JAVA_HOME="/Library/Java/JavaVirtualMachines/temurin-21.jdk/Contents/Home/"
|
|
||||||
# I only start tmux by default on Mac because of dwm+swallow patch
|
|
||||||
if [[ -z "$TMUX" ]] && [[ -n "$PS1" ]]; then
|
|
||||||
tmux attach -t dev || tmux new -s dev
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
alias ls="ls --classify --group-directories-first --color"
|
|
||||||
fi
|
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# Aliases
|
# Aliases
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
|
|
||||||
alias clip2png="xclip -selection clipboard -target image/png -out"
|
alias clip2png="xclip -selection clipboard -target image/png -out"
|
||||||
|
|
||||||
|
|
||||||
|
#==============================================================================
|
||||||
|
# Gemini Agents
|
||||||
|
#==============================================================================
|
||||||
|
|
||||||
|
function gemini-planner(){
|
||||||
|
if $(echo "$1" | grep "engjira.int.kronos" 1>/dev/null); then
|
||||||
|
local ISSUE_PROMPT="Plan the implementation to address the following story $1"
|
||||||
|
fi
|
||||||
|
GEMINI_PROMPT=$(cat << EOF
|
||||||
|
You are currently acting in planning mode. Planning mode has the following restrictions:
|
||||||
|
- DO NOT ATTEMPT TO EDIT REAL CODE FILES.
|
||||||
|
- Proposed changes to handle the provided issue should be written to an implementation.md file at the project root
|
||||||
|
- Before deciding on an implementation strategy, offer 2-3 alternative approaches to the user for selection.
|
||||||
|
|
||||||
|
## Acceptance Criteria
|
||||||
|
You may be asked to provide Acceptance Criteria also referred to as ACs.
|
||||||
|
Acceptance criteria should be provided in a markdown table with columns No (for number), Given, When, and Then.
|
||||||
|
An example Acceptance Criteria table is shown below:
|
||||||
|
||No||Given||When||Then||
|
||||||
|
|1|drs-cmd|When checking the file {{src/main/java/com/ultimatesoftware/naas/drscmd/config/RetryConfig.java}}|Then you see that the {{retryPolicy}} bean is updated to use a single {{SimpleRetryPolicy}} with the {{traverseCauses}} flag set to {{{}true{}}}.|
|
||||||
|
|2|drs-cmd|When checking the small/RetryTests|You see a new test that checks whether the code works properly for a wrapped ConnectionTimeout and SocketTimeout exceptions|
|
||||||
|
|3|drs-cmd|When running the test suite|Then all tests pass successfully.|
|
||||||
|
|4|drs-cmd|When a {{software.amazon.awssdk.core.exception.SdkClientException}} is thrown with a cause of {{java.net.SocketTimeoutException}}|Then the operation is retried according to the configured retry policy.|
|
||||||
|
|
||||||
|
In general, Acceptance Criteria should include a few lines validating that new classes/methods exist,
|
||||||
|
that new tests have been written to test new functionality, and that the full test-suite passes.
|
||||||
|
|
||||||
|
$ISSUE_PROMPT
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
gemini -i "$GEMINI_PROMPT"
|
||||||
|
}
|
||||||
|
|
||||||
|
function gemini-reviewer(){
|
||||||
|
if ! $(echo "$1" | grep -E "^https://github.com/.*/pull/[0-9]+$" 1>/dev/null); then
|
||||||
|
echo "Usage: gemini-reviewer <github_pr_url>"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local REVIEW_PROMPT="Please review the following GitHub pull request: $1"
|
||||||
|
|
||||||
|
GEMINI_PROMPT=$(cat << EOF
|
||||||
|
You are an expert code reviewer. Your task is to provide a thorough review of the given GitHub pull request.
|
||||||
|
|
||||||
|
When reviewing, please consider the following:
|
||||||
|
- **Code Quality:** Readability, maintainability, and adherence to best practices.
|
||||||
|
- **Functionality:** Does the code do what it says it does? Are there any obvious bugs or edge cases missed?
|
||||||
|
- **Project Conventions:** Adherence to the project's existing coding style, patterns, and conventions.
|
||||||
|
- **Security:** Are there any potential security vulnerabilities?
|
||||||
|
- **Performance:** Could any of the changes introduce performance issues?
|
||||||
|
- **Testing:** Are the tests adequate? Do they cover the changes effectively?
|
||||||
|
|
||||||
|
Please provide your feedback in a clear and constructive manner. Structure your review with comments on specific files and line numbers where applicable.
|
||||||
|
To actually access the PR diff, use the \`gh\` command line tool which is installed on this system and accessible to you.
|
||||||
|
|
||||||
|
$REVIEW_PROMPT
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
gemini -i "$GEMINI_PROMPT"
|
||||||
|
}
|
||||||
|
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
# Functions
|
# Functions
|
||||||
#==============================================================================
|
#==============================================================================
|
||||||
|
@ -149,7 +195,10 @@ bindkey '^[[B' history-substring-search-down
|
||||||
if [ "$(uname)" = "Darwin" ]; then
|
if [ "$(uname)" = "Darwin" ]; then
|
||||||
export PATH="$PATH:/opt/homebrew/bin"
|
export PATH="$PATH:/opt/homebrew/bin"
|
||||||
alias ls="gls --classify --group-directories-first --color"
|
alias ls="gls --classify --group-directories-first --color"
|
||||||
alias gemini="(source ~/.gemini_project && gemini)"
|
GEMINI_BIN=$(which gemini)
|
||||||
|
function gemini(){
|
||||||
|
source ~/.gemini_project && $GEMINI_BIN "$@"
|
||||||
|
}
|
||||||
export NVIM_JDTLS_JAVA_HOME="/Library/Java/JavaVirtualMachines/temurin-21.jdk/Contents/Home/"
|
export NVIM_JDTLS_JAVA_HOME="/Library/Java/JavaVirtualMachines/temurin-21.jdk/Contents/Home/"
|
||||||
# I only start tmux by default on Mac because of dwm+swallow patch
|
# I only start tmux by default on Mac because of dwm+swallow patch
|
||||||
if [[ -z "$TMUX" ]] && [[ -n "$PS1" ]]; then
|
if [[ -z "$TMUX" ]] && [[ -n "$PS1" ]]; then
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue