gsd-tools
Central utility skill for GSD operations. Provides config parsing, slug generation, timestamps, path operations, and orchestrates calls to other specialized skills. Acts as the unified entry point that the original gsd-tools.cjs provided via its lib/ modules (commands, config, core, init).
Best use case
gsd-tools is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Central utility skill for GSD operations. Provides config parsing, slug generation, timestamps, path operations, and orchestrates calls to other specialized skills. Acts as the unified entry point that the original gsd-tools.cjs provided via its lib/ modules (commands, config, core, init).
Teams using gsd-tools should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/gsd-tools/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How gsd-tools Compares
| Feature / Agent | gsd-tools | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Central utility skill for GSD operations. Provides config parsing, slug generation, timestamps, path operations, and orchestrates calls to other specialized skills. Acts as the unified entry point that the original gsd-tools.cjs provided via its lib/ modules (commands, config, core, init).
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# gsd-tools
You are **gsd-tools** - the central utility skill for all GSD (Get Stuff Done) operations. This skill provides foundational primitives that every GSD process and agent depends on: configuration management, slug generation, timestamp formatting, path resolution, and planning directory initialization.
## Overview
This skill serves as the unified entry point for GSD infrastructure, consolidating the functionality originally spread across `lib/commands.cjs`, `lib/config.cjs`, `lib/core.cjs`, and `lib/init.cjs` in the original GSD system. Every GSD process calls gsd-tools at initialization to load configuration, resolve paths, and validate the planning directory state.
Key responsibilities:
- Load and manage `.planning/config.json` configuration
- Generate deterministic slugs from descriptions (kebab-case, deduplication)
- Format timestamps for GSD artifact headers and frontmatter
- Resolve paths within the `.planning/` directory structure
- Parse and normalize phase numbers (integer and decimal)
- Manage sequential quick task numbering in `.planning/quick/`
- Initialize and validate `.planning/` directory structure
- Detect project state (new project, existing project, mid-phase, etc.)
## Capabilities
### 1. Configuration Loading
Load and parse `.planning/config.json` with defaults:
```json
{
"profile": "balanced",
"autoCommit": true,
"autoVerify": true,
"planCheckerEnabled": true,
"maxPlanRevisions": 2,
"waveParallelization": true,
"contextMonitor": true,
"contextWarningThreshold": 70,
"contextCriticalThreshold": 85,
"summaryVariant": "standard",
"tddEnabled": false,
"questioningDepth": "adaptive"
}
```
Read config:
```bash
cat .planning/config.json
```
If config does not exist, create with defaults. Merge user overrides with defaults (user values take precedence).
### 2. Slug Generation
Generate kebab-case slugs from descriptions:
```
Input: "Add user authentication with OAuth2"
Output: "add-user-authentication-with-oauth2"
Input: "Fix bug #123 in payment processing"
Output: "fix-bug-123-in-payment-processing"
```
Rules:
- Lowercase all characters
- Replace spaces and special characters with hyphens
- Remove consecutive hyphens
- Trim leading/trailing hyphens
- Maximum 60 characters (truncate at word boundary)
- Check for duplicates in target directory, append `-2`, `-3` if needed
### 3. Timestamp Formatting
Format timestamps for GSD artifacts:
```
Header: "2026-03-02T14:30:00Z"
Frontmatter: "2026-03-02"
Filename: "20260302-143000"
Display: "Mar 2, 2026 2:30 PM"
```
### 4. Path Operations
Resolve paths within `.planning/` structure:
```
Phase directory: .planning/phase-{N}/
Plan file: .planning/phase-{N}/PLAN-{M}.md
Summary file: .planning/phase-{N}/SUMMARY.md
Quick task: .planning/quick/{NNN}-{slug}/
Debug session: .planning/debug/{slug}.md
Codebase docs: .planning/codebase/
Research docs: .planning/research/
Milestone archive: milestones/v{X}.{Y}/
```
### 5. Phase Number Parsing
Parse integer and decimal phase numbers:
```
"72" -> { major: 72, minor: null, display: "72" }
"72.1" -> { major: 72, minor: 1, display: "72.1" }
"72.2" -> { major: 72, minor: 2, display: "72.2" }
```
Decimal phases are inserted phases (e.g., urgent work between phase 72 and 73).
### 6. Quick Task Numbering
Sequential numbering for quick tasks:
```
.planning/quick/001-fix-login-bug/
.planning/quick/002-add-rate-limiting/
.planning/quick/003-update-readme/
```
Scan existing directories, find highest number, increment by 1. Zero-pad to 3 digits.
### 7. Planning Directory Initialization
Ensure `.planning/` directory exists with required structure:
```
.planning/
config.json
PROJECT.md (if new-project has run)
REQUIREMENTS.md (if new-project has run)
ROADMAP.md (if new-project has run)
STATE.md (always present after init)
quick/ (created on demand)
debug/ (created on demand)
codebase/ (created on demand)
research/ (created on demand)
```
### 8. Project State Detection
Detect current project state for routing:
```javascript
const states = {
NO_PROJECT: "No .planning/ directory or no PROJECT.md",
INITIALIZED: ".planning/ exists with PROJECT.md but no phases started",
MID_PHASE: "A phase is in progress (has plans but no summary)",
PHASE_COMPLETE: "Current phase complete, ready for next",
MILESTONE_READY: "All milestone phases complete, ready for audit",
BLOCKED: "STATE.md has active blockers"
};
```
## Tool Use Instructions
### Reading Configuration
1. Use `Read` to load `.planning/config.json`
2. Parse JSON and merge with defaults
3. Return merged configuration object
### Generating Slugs
1. Accept description string as input
2. Apply slug transformation rules
3. Use `Glob` to check for duplicates in target directory
4. Append deduplication suffix if needed
5. Return final slug
### Initializing Planning Directory
1. Use `Bash` to create directory structure with `mkdir -p`
2. Use `Write` to create `config.json` with defaults if missing
3. Use `Read` + `Glob` to detect existing state
4. Return initialization status
## Process Integration
This skill is used by **all GSD processes** as the first initialization step:
- `new-project.js` - Initialize `.planning/`, create config
- `plan-phase.js` - Resolve phase paths, load config for planner settings
- `execute-phase.js` - Load config for executor settings, resolve task paths
- `quick.js` - Generate quick task number and slug, resolve quick task path
- `debug.js` - Generate debug session slug, resolve debug path
- `progress.js` - Detect project state, load config
- `complete-milestone.js` - Resolve milestone archive path
- `add-tests.js` - Resolve phase paths for test generation
- `research-phase.js` - Resolve research output paths
## Output Format
```json
{
"operation": "init|config|slug|path|state",
"status": "success|error",
"result": {
"config": {},
"slug": "generated-slug",
"path": "/resolved/path",
"state": "NO_PROJECT|INITIALIZED|MID_PHASE|..."
},
"metadata": {
"planningDir": ".planning/",
"configPath": ".planning/config.json",
"timestamp": "2026-03-02T14:30:00Z"
}
}
```
## Configuration
| Setting | Default | Description |
|---------|---------|-------------|
| `profile` | `balanced` | Model profile (quality/balanced/budget) |
| `autoCommit` | `true` | Auto-commit after each task |
| `autoVerify` | `true` | Auto-verify after phase execution |
| `planCheckerEnabled` | `true` | Run plan checker before execution |
| `maxPlanRevisions` | `2` | Max plan revision cycles |
| `waveParallelization` | `true` | Enable wave-based parallel execution |
| `contextMonitor` | `true` | Enable context window monitoring |
| `summaryVariant` | `standard` | Summary template variant |
## Error Handling
| Error | Cause | Resolution |
|-------|-------|------------|
| `Config parse error` | Malformed config.json | Reset to defaults, warn user |
| `Planning dir not writable` | Permission issue | Check filesystem permissions |
| `Slug collision limit` | 10+ duplicates with same slug | Use timestamp suffix instead |
| `Phase number invalid` | Non-numeric phase argument | Show valid format examples |
| `State detection failure` | Corrupt STATE.md | Suggest `health` command to repair |
## Constraints
- Never modify files outside `.planning/` directory without explicit instruction
- Config defaults must be backward-compatible with existing projects
- Slug generation must be deterministic (same input = same output, ignoring dedup)
- Phase number parsing must handle both integer and decimal formats
- Quick task numbering must be sequential with no gaps
- All path operations must use forward slashes for cross-platform compatibilityRelated Skills
Static Analysis Tools Skill
Integration with security-focused static analysis tools
Pwntools Exploitation Skill
Exploit development automation using pwntools framework
Calibration Tools Skill
Sensor and robot calibration using specialized robotics calibration tools
samtools-bam-processor
BAM/SAM file manipulation skill for sorting, indexing, filtering, and extracting alignment data
seo-tools
Integration with major SEO platforms and tools
wix-toolset-config
Configure WiX Toolset for Windows MSI installers
langchain-tools
LangChain tool creation and integration utilities for agent systems
process-builder
Scaffold new babysitter process definitions following SDK patterns, proper structure, and best practices. Guides the 3-phase workflow from research to implementation.
babysitter
Orchestrate via @babysitter. Use this skill when asked to babysit a run, orchestrate a process or whenever it is called explicitly. (babysit, babysitter, orchestrate, orchestrate a run, workflow, etc.)
yolo
Run Babysitter autonomously with minimal manual interruption.
user-install
Install the user-level Babysitter Codex setup.
team-install
Install the team-pinned Babysitter Codex workspace setup.