Code Simplifier Skill for Gemini CLI
When triggered, perform the following steps to execute a code simplification review:
Phase 1: Installation & Setup
-
Check Dependencies: Ensure the
.gemini/settings.jsonfile in the project directory hasexperimental.enableAgentsset totrue:{ "experimental": { "enableAgents": true } }You must ensure the three review subagents are installed in the project's
.gemini/agents/directory:.gemini/agents/code-reuse-reviewer.md.gemini/agents/code-quality-reviewer.md.gemini/agents/efficiency-reviewer.md
-
Create the Agents (If Missing): Use the
write_filetool to create them if they do not exist:Code Reuse Reviewer (
.gemini/agents/code-reuse-reviewer.md):--- name: code_reuse_reviewer description: Reviews code changes to identify opportunities for reusing existing utilities and helpers. --- For each change: 1. Search for existing utilities and helpers that could replace newly written code. Use grep_search to find similar patterns elsewhere in the codebase — common locations are utility directories, shared modules, and files adjacent to the changed ones. 2. Flag any new function that duplicates existing functionality. Suggest the existing function to use instead. 3. Flag any inline logic that could use an existing utility — hand-rolled string manipulation, manual path handling, custom environment checks, ad-hoc type guards, and similar patterns are common candidates.Code Quality Reviewer (
.gemini/agents/code-quality-reviewer.md):--- name: code_quality_reviewer description: Reviews code changes for hacky patterns, redundant state, parameter sprawl, and leaky abstractions. --- Review the changes for hacky patterns: 1. Redundant state: state that duplicates existing state, cached values that could be derived, observers/effects that could be direct calls 2. Parameter sprawl: adding new parameters to a function instead of generalizing or restructuring existing ones 3. Copy-paste with slight variation: near-duplicate code blocks that should be unified with a shared abstraction 4. Leaky abstractions: exposing internal details that should be encapsulated, or breaking existing abstraction boundaries 5. Stringly-typed code: using raw strings where constants, enums (string unions), or branded types already exist in the codebaseEfficiency Reviewer (
.gemini/agents/efficiency-reviewer.md):--- name: efficiency_reviewer description: Reviews code changes for efficiency, unnecessary work, missed concurrency, and memory leaks. --- Review the changes for efficiency: 1. Unnecessary work: redundant computations, repeated file reads, duplicate network/API calls, N+1 patterns 2. Missed concurrency: independent operations run sequentially when they could run in parallel 3. Hot-path bloat: new blocking work added to startup or per-request/per-render hot paths 4. Unnecessary existence checks: pre-checking file/resource existence before operating (TOCTOU anti-pattern) — operate directly and handle the error 5. Memory: unbounded data structures, missing cleanup, event listener leaks 6. Overly broad operations: reading entire files when only a portion is needed, loading all items when filtering for one -
Prompt for Refresh: If you installed any files or modified settings in step 2, tell the user they must run the
/agents refreshcommand to load the new agents. Stop execution here and wait for the user to run the command.
Phase 2: Execution
- Identify Target: Determine the specific code changes to review based on the user's request (e.g., a specific file, uncommitted changes, or a git diff). Ask them to specify what to review if they haven't already.
- Parallel Invocation: Invoke all three agents (
code_reuse_reviewer,code_quality_reviewer,efficiency_reviewer) in parallel using their respective tools. Pass each agent the full context or diff of the changes to review. - Aggregation and Fix: Wait for all three agents to complete. Aggregate their findings and fix each issue directly. If a finding is a false positive or not worth addressing, note it and move on — do not argue with the finding, just skip it.
Attribution: The overall technique here was adapted from Claude Code's /simplify command, introduced in Feb 2026.