chore: checkpoint before DAG views UX overhaul
This commit is contained in:
parent
5695125a75
commit
a03def1ca1
125 changed files with 40711 additions and 581 deletions
47
.beads/.beads.bak/.gitignore
vendored
Normal file
47
.beads/.beads.bak/.gitignore
vendored
Normal file
|
|
@ -0,0 +1,47 @@
|
|||
# Dolt database (managed by Dolt, not git)
|
||||
dolt/
|
||||
dolt-access.lock
|
||||
|
||||
# Runtime files
|
||||
bd.sock
|
||||
sync-state.json
|
||||
last-touched
|
||||
|
||||
# Local version tracking (prevents upgrade notification spam after git ops)
|
||||
.local_version
|
||||
|
||||
# Worktree redirect file (contains relative path to main repo's .beads/)
|
||||
# Must not be committed as paths would be wrong in other clones
|
||||
redirect
|
||||
|
||||
# Sync state (local-only, per-machine)
|
||||
# These files are machine-specific and should not be shared across clones
|
||||
.sync.lock
|
||||
.jsonl.lock
|
||||
sync_base.jsonl
|
||||
export-state/
|
||||
|
||||
# Legacy files (from pre-Dolt versions)
|
||||
*.db
|
||||
*.db?*
|
||||
*.db-journal
|
||||
*.db-wal
|
||||
*.db-shm
|
||||
db.sqlite
|
||||
bd.db
|
||||
daemon.lock
|
||||
daemon.log
|
||||
daemon-*.log.gz
|
||||
daemon.pid
|
||||
beads.base.jsonl
|
||||
beads.base.meta.json
|
||||
beads.left.jsonl
|
||||
beads.left.meta.json
|
||||
beads.right.jsonl
|
||||
beads.right.meta.json
|
||||
|
||||
# NOTE: Do NOT add negation patterns (e.g., !issues.jsonl) here.
|
||||
# They would override fork protection in .git/info/exclude, allowing
|
||||
# contributors to accidentally commit upstream issue databases.
|
||||
# The JSONL files (issues.jsonl, interactions.jsonl) and config files
|
||||
# are tracked by git by default since no pattern above ignores them.
|
||||
81
.beads/.beads.bak/README.md
Normal file
81
.beads/.beads.bak/README.md
Normal file
|
|
@ -0,0 +1,81 @@
|
|||
# Beads - AI-Native Issue Tracking
|
||||
|
||||
Welcome to Beads! This repository uses **Beads** for issue tracking - a modern, AI-native tool designed to live directly in your codebase alongside your code.
|
||||
|
||||
## What is Beads?
|
||||
|
||||
Beads is issue tracking that lives in your repo, making it perfect for AI coding agents and developers who want their issues close to their code. No web UI required - everything works through the CLI and integrates seamlessly with git.
|
||||
|
||||
**Learn more:** [github.com/steveyegge/beads](https://github.com/steveyegge/beads)
|
||||
|
||||
## Quick Start
|
||||
|
||||
### Essential Commands
|
||||
|
||||
```bash
|
||||
# Create new issues
|
||||
bd create "Add user authentication"
|
||||
|
||||
# View all issues
|
||||
bd list
|
||||
|
||||
# View issue details
|
||||
bd show <issue-id>
|
||||
|
||||
# Update issue status
|
||||
bd update <issue-id> --status in_progress
|
||||
bd update <issue-id> --status done
|
||||
|
||||
# Sync with git remote
|
||||
bd sync
|
||||
```
|
||||
|
||||
### Working with Issues
|
||||
|
||||
Issues in Beads are:
|
||||
- **Git-native**: Stored in `.beads/issues.jsonl` and synced like code
|
||||
- **AI-friendly**: CLI-first design works perfectly with AI coding agents
|
||||
- **Branch-aware**: Issues can follow your branch workflow
|
||||
- **Always in sync**: Auto-syncs with your commits
|
||||
|
||||
## Why Beads?
|
||||
|
||||
✨ **AI-Native Design**
|
||||
- Built specifically for AI-assisted development workflows
|
||||
- CLI-first interface works seamlessly with AI coding agents
|
||||
- No context switching to web UIs
|
||||
|
||||
🚀 **Developer Focused**
|
||||
- Issues live in your repo, right next to your code
|
||||
- Works offline, syncs when you push
|
||||
- Fast, lightweight, and stays out of your way
|
||||
|
||||
🔧 **Git Integration**
|
||||
- Automatic sync with git commits
|
||||
- Branch-aware issue tracking
|
||||
- Intelligent JSONL merge resolution
|
||||
|
||||
## Get Started with Beads
|
||||
|
||||
Try Beads in your own projects:
|
||||
|
||||
```bash
|
||||
# Install Beads
|
||||
curl -sSL https://raw.githubusercontent.com/steveyegge/beads/main/scripts/install.sh | bash
|
||||
|
||||
# Initialize in your repo
|
||||
bd init
|
||||
|
||||
# Create your first issue
|
||||
bd create "Try out Beads"
|
||||
```
|
||||
|
||||
## Learn More
|
||||
|
||||
- **Documentation**: [github.com/steveyegge/beads/docs](https://github.com/steveyegge/beads/tree/main/docs)
|
||||
- **Quick Start Guide**: Run `bd quickstart`
|
||||
- **Examples**: [github.com/steveyegge/beads/examples](https://github.com/steveyegge/beads/tree/main/examples)
|
||||
|
||||
---
|
||||
|
||||
*Beads: Issue tracking that moves at the speed of thought* ⚡
|
||||
1
.beads/.beads.bak/beads.base.meta.json.336192.tmp
Normal file
1
.beads/.beads.bak/beads.base.meta.json.336192.tmp
Normal file
|
|
@ -0,0 +1 @@
|
|||
{"version":"0.49.6","timestamp":"2026-02-18T20:27:49.7992545-08:00","commit":"14a50ad"}
|
||||
63
.beads/.beads.bak/config.yaml
Normal file
63
.beads/.beads.bak/config.yaml
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
# Beads Configuration File
|
||||
# This file configures default behavior for all bd commands in this repository
|
||||
# All settings can also be set via environment variables (BD_* prefix)
|
||||
# or overridden with command-line flags
|
||||
|
||||
# Issue prefix for this repository (used by bd init)
|
||||
# If not set, bd init will auto-detect from directory name
|
||||
# Example: issue-prefix: "myproject" creates issues like "myproject-1", "myproject-2", etc.
|
||||
issue-prefix: "bb"
|
||||
|
||||
# Use no-db mode: load from JSONL, no SQLite, write back after each command
|
||||
# When true, bd will use .beads/issues.jsonl as the source of truth
|
||||
# instead of SQLite database
|
||||
no-db: true
|
||||
|
||||
# Disable daemon for RPC communication (forces direct database access)
|
||||
# no-daemon: false
|
||||
|
||||
# Disable auto-flush of database to JSONL after mutations
|
||||
# no-auto-flush: false
|
||||
|
||||
# Disable auto-import from JSONL when it's newer than database
|
||||
# no-auto-import: false
|
||||
|
||||
# Enable JSON output by default
|
||||
# json: false
|
||||
|
||||
# Default actor for audit trails (overridden by BD_ACTOR or --actor)
|
||||
# actor: ""
|
||||
|
||||
# Path to database (overridden by BEADS_DB or --db)
|
||||
# db: ""
|
||||
|
||||
# Auto-start daemon if not running (can also use BEADS_AUTO_START_DAEMON)
|
||||
# auto-start-daemon: true
|
||||
|
||||
# Debounce interval for auto-flush (can also use BEADS_FLUSH_DEBOUNCE)
|
||||
# flush-debounce: "5s"
|
||||
|
||||
# Git branch for beads commits (bd sync will commit to this branch)
|
||||
# IMPORTANT: Set this for team projects so all clones use the same sync branch.
|
||||
# This setting persists across clones (unlike database config which is gitignored).
|
||||
# Can also use BEADS_SYNC_BRANCH env var for local override.
|
||||
# If not set, bd sync will require you to run 'bd config set sync.branch <branch>'.
|
||||
sync-branch: "beads-sync"
|
||||
|
||||
# Multi-repo configuration (experimental - bd-307)
|
||||
# Allows hydrating from multiple repositories and routing writes to the correct JSONL
|
||||
# repos:
|
||||
# primary: "." # Primary repo (where this database lives)
|
||||
# additional: # Additional repos to hydrate from (read-only)
|
||||
# - ~/beads-planning # Personal planning repo
|
||||
# - ~/work-planning # Work planning repo
|
||||
|
||||
# Integration settings (access with 'bd config get/set')
|
||||
# These are stored in the database, not in this file:
|
||||
# - jira.url
|
||||
# - jira.project
|
||||
# - linear.url
|
||||
# - linear.api-key
|
||||
# - github.org
|
||||
# - github.repo
|
||||
|
||||
16
.beads/.beads.bak/daemon-error
Normal file
16
.beads/.beads.bak/daemon-error
Normal file
|
|
@ -0,0 +1,16 @@
|
|||
|
||||
LEGACY DATABASE DETECTED!
|
||||
|
||||
This database was created before version 0.17.5 and lacks a repository fingerprint.
|
||||
To continue using this database, you must explicitly set its repository ID:
|
||||
|
||||
bd migrate --update-repo-id
|
||||
|
||||
This ensures the database is bound to this repository and prevents accidental
|
||||
database sharing between different repositories.
|
||||
|
||||
If this is a fresh clone, run:
|
||||
rm -rf .beads && bd init
|
||||
|
||||
Note: Auto-claiming legacy databases is intentionally disabled to prevent
|
||||
silent corruption when databases are copied between repositories.
|
||||
23
.beads/.beads.bak/hooks/post-checkout
Normal file
23
.beads/.beads.bak/hooks/post-checkout
Normal file
|
|
@ -0,0 +1,23 @@
|
|||
#!/usr/bin/env sh
|
||||
# bd-shim v1
|
||||
# bd-hooks-version: 0.53.0
|
||||
#
|
||||
# bd (beads) post-checkout hook - thin shim
|
||||
#
|
||||
# This shim delegates to 'bd hook post-checkout' which contains
|
||||
# the actual hook logic. This pattern ensures hook behavior is always
|
||||
# in sync with the installed bd version - no manual updates needed.
|
||||
#
|
||||
# The 'bd hook' command (singular) supports:
|
||||
# - Guard against frequent firing (only imports if JSONL changed)
|
||||
# - Per-worktree state tracking
|
||||
# - Dolt branch-then-merge pattern
|
||||
# - Hook chaining configuration
|
||||
|
||||
# Check if bd is available
|
||||
if ! command -v bd >/dev/null 2>&1; then
|
||||
# Silently skip - post-checkout is called frequently
|
||||
exit 0
|
||||
fi
|
||||
|
||||
exec bd hook post-checkout "$@"
|
||||
24
.beads/.beads.bak/hooks/post-merge
Normal file
24
.beads/.beads.bak/hooks/post-merge
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
#!/usr/bin/env sh
|
||||
# bd-shim v1
|
||||
# bd-hooks-version: 0.53.0
|
||||
#
|
||||
# bd (beads) post-merge hook - thin shim
|
||||
#
|
||||
# This shim delegates to 'bd hook post-merge' which contains
|
||||
# the actual hook logic. This pattern ensures hook behavior is always
|
||||
# in sync with the installed bd version - no manual updates needed.
|
||||
#
|
||||
# The 'bd hook' command (singular) supports:
|
||||
# - Branch-then-merge pattern for Dolt (cell-level conflict resolution)
|
||||
# - Per-worktree state tracking
|
||||
# - Hook chaining configuration
|
||||
|
||||
# Check if bd is available
|
||||
if ! command -v bd >/dev/null 2>&1; then
|
||||
echo "Warning: bd command not found in PATH, skipping post-merge hook" >&2
|
||||
echo " Install bd: brew install beads" >&2
|
||||
echo " Or add bd to your PATH" >&2
|
||||
exit 0
|
||||
fi
|
||||
|
||||
exec bd hook post-merge "$@"
|
||||
25
.beads/.beads.bak/hooks/pre-commit
Normal file
25
.beads/.beads.bak/hooks/pre-commit
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
#!/usr/bin/env sh
|
||||
# bd-shim v2
|
||||
# bd-hooks-version: 0.53.0
|
||||
#
|
||||
# bd (beads) pre-commit hook — thin shim
|
||||
#
|
||||
# Delegates to 'bd hook pre-commit' which contains the actual hook logic.
|
||||
# This pattern ensures hook behavior is always in sync with the installed
|
||||
# bd version — no manual updates needed.
|
||||
#
|
||||
# The 'bd hook' command supports:
|
||||
# - Per-worktree export state tracking
|
||||
# - Dolt in-process export (no lock deadlocks)
|
||||
# - Sync-branch routing
|
||||
# - Hook chaining configuration
|
||||
|
||||
# Check if bd is available
|
||||
if ! command -v bd >/dev/null 2>&1; then
|
||||
echo "Warning: bd command not found in PATH, skipping pre-commit hook" >&2
|
||||
echo " Install bd: brew install beads" >&2
|
||||
echo " Or add bd to your PATH" >&2
|
||||
exit 0
|
||||
fi
|
||||
|
||||
exec bd hook pre-commit "$@"
|
||||
19
.beads/.beads.bak/hooks/pre-push
Normal file
19
.beads/.beads.bak/hooks/pre-push
Normal file
|
|
@ -0,0 +1,19 @@
|
|||
#!/usr/bin/env sh
|
||||
# bd-shim v1
|
||||
# bd-hooks-version: 0.53.0
|
||||
#
|
||||
# bd (beads) pre-push hook - thin shim
|
||||
#
|
||||
# This shim delegates to 'bd hooks run pre-push' which contains
|
||||
# the actual hook logic. This pattern ensures hook behavior is always
|
||||
# in sync with the installed bd version - no manual updates needed.
|
||||
|
||||
# Check if bd is available
|
||||
if ! command -v bd >/dev/null 2>&1; then
|
||||
echo "Warning: bd command not found in PATH, skipping pre-push hook" >&2
|
||||
echo " Install bd: brew install beads" >&2
|
||||
echo " Or add bd to your PATH" >&2
|
||||
exit 0
|
||||
fi
|
||||
|
||||
exec bd hooks run pre-push "$@"
|
||||
24
.beads/.beads.bak/hooks/prepare-commit-msg
Normal file
24
.beads/.beads.bak/hooks/prepare-commit-msg
Normal file
|
|
@ -0,0 +1,24 @@
|
|||
#!/usr/bin/env sh
|
||||
# bd-shim v1
|
||||
# bd-hooks-version: 0.48.0
|
||||
#
|
||||
# bd (beads) prepare-commit-msg hook - thin shim
|
||||
#
|
||||
# This shim delegates to 'bd hooks run prepare-commit-msg' which contains
|
||||
# the actual hook logic. This pattern ensures hook behavior is always
|
||||
# in sync with the installed bd version - no manual updates needed.
|
||||
#
|
||||
# Arguments:
|
||||
# $1 = path to the commit message file
|
||||
# $2 = source of commit message (message, template, merge, squash, commit)
|
||||
# $3 = commit SHA-1 (if -c, -C, or --amend)
|
||||
|
||||
# Check if bd is available
|
||||
if ! command -v bd >/dev/null 2>&1; then
|
||||
echo "Warning: bd command not found in PATH, skipping prepare-commit-msg hook" >&2
|
||||
echo " Install bd: brew install beads" >&2
|
||||
echo " Or add bd to your PATH" >&2
|
||||
exit 0
|
||||
fi
|
||||
|
||||
exec bd hooks run prepare-commit-msg "$@"
|
||||
0
.beads/.beads.bak/interactions.jsonl
Normal file
0
.beads/.beads.bak/interactions.jsonl
Normal file
BIN
.beads/.beads.bak/issues.jsonl
Normal file
BIN
.beads/.beads.bak/issues.jsonl
Normal file
Binary file not shown.
BIN
.beads/.beads.bak/issues.jsonl.tmp.36968.1
Normal file
BIN
.beads/.beads.bak/issues.jsonl.tmp.36968.1
Normal file
Binary file not shown.
6
.beads/.beads.bak/metadata.json
Normal file
6
.beads/.beads.bak/metadata.json
Normal file
|
|
@ -0,0 +1,6 @@
|
|||
{
|
||||
"database": "dolt",
|
||||
"jsonl_export": "issues.jsonl",
|
||||
"backend": "dolt",
|
||||
"dolt_database": "beads_bb"
|
||||
}
|
||||
6
.beads/.gitignore
vendored
6
.beads/.gitignore
vendored
|
|
@ -8,10 +8,8 @@
|
|||
# Daemon runtime files
|
||||
daemon.lock
|
||||
daemon.log
|
||||
daemon-*.log.gz
|
||||
daemon.pid
|
||||
bd.sock
|
||||
bd.sock.startlock
|
||||
sync-state.json
|
||||
last-touched
|
||||
|
||||
|
|
@ -41,10 +39,6 @@ beads.right.meta.json
|
|||
sync_base.jsonl
|
||||
export-state/
|
||||
|
||||
# Dolt database (managed by Dolt remotes, not git)
|
||||
dolt/
|
||||
dolt-access.lock
|
||||
|
||||
# NOTE: Do NOT add negation patterns (e.g., !issues.jsonl) here.
|
||||
# They would override fork protection in .git/info/exclude, allowing
|
||||
# contributors to accidentally commit upstream issue databases.
|
||||
|
|
|
|||
15
.beads/archetypes/architect.json
Normal file
15
.beads/archetypes/architect.json
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
{
|
||||
"id": "architect",
|
||||
"name": "System Architect",
|
||||
"description": "Designs complex system structures and writes detailed implementation plans.",
|
||||
"systemPrompt": "You are a staff-level software architect focused on high-level system design.",
|
||||
"capabilities": [
|
||||
"planning",
|
||||
"design_docs",
|
||||
"arch_review"
|
||||
],
|
||||
"color": "#3b82f6",
|
||||
"createdAt": "2026-02-21T03:19:47.072Z",
|
||||
"updatedAt": "2026-02-21T19:39:45.331Z",
|
||||
"isBuiltIn": true
|
||||
}
|
||||
15
.beads/archetypes/coder.json
Normal file
15
.beads/archetypes/coder.json
Normal file
|
|
@ -0,0 +1,15 @@
|
|||
{
|
||||
"id": "coder",
|
||||
"name": "Implementation Engineer",
|
||||
"description": "Translates plans into precise, type-safe, and tested code.",
|
||||
"systemPrompt": "You are a senior software engineer focused on execution and clean code.",
|
||||
"capabilities": [
|
||||
"coding",
|
||||
"refactoring",
|
||||
"testing"
|
||||
],
|
||||
"color": "#10b981",
|
||||
"createdAt": "2026-02-21T19:37:55.262Z",
|
||||
"updatedAt": "2026-02-21T19:37:55.262Z",
|
||||
"isBuiltIn": true
|
||||
}
|
||||
14
.beads/archetypes/test-agent.json
Normal file
14
.beads/archetypes/test-agent.json
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
{
|
||||
"id": "test-agent",
|
||||
"name": "Test Agent",
|
||||
"description": "A test archetype for verification",
|
||||
"systemPrompt": "You are a test agent.",
|
||||
"capabilities": [
|
||||
"testing",
|
||||
"verification"
|
||||
],
|
||||
"color": "#ff6b6b",
|
||||
"createdAt": "2026-02-21T20:43:00.085Z",
|
||||
"updatedAt": "2026-02-21T20:43:00.085Z",
|
||||
"isBuiltIn": false
|
||||
}
|
||||
1
.beads/beads.base.meta.json.48716.tmp
Normal file
1
.beads/beads.base.meta.json.48716.tmp
Normal file
|
|
@ -0,0 +1 @@
|
|||
{"version":"0.49.6","timestamp":"2026-02-21T10:21:43.4424965-08:00","commit":"dfaf523"}
|
||||
|
|
@ -37,12 +37,17 @@
|
|||
# Debounce interval for auto-flush (can also use BEADS_FLUSH_DEBOUNCE)
|
||||
# flush-debounce: "5s"
|
||||
|
||||
# Export events (audit trail) to .beads/events.jsonl on each flush/sync
|
||||
# When enabled, new events are appended incrementally using a high-water mark.
|
||||
# Use 'bd export --events' to trigger manually regardless of this setting.
|
||||
# events-export: false
|
||||
|
||||
# Git branch for beads commits (bd sync will commit to this branch)
|
||||
# IMPORTANT: Set this for team projects so all clones use the same sync branch.
|
||||
# This setting persists across clones (unlike database config which is gitignored).
|
||||
# Can also use BEADS_SYNC_BRANCH env var for local override.
|
||||
# If not set, bd sync will require you to run 'bd config set sync.branch <branch>'.
|
||||
sync-branch: "beads-sync"
|
||||
# sync-branch: "beads-sync"
|
||||
|
||||
# Multi-repo configuration (experimental - bd-307)
|
||||
# Allows hydrating from multiple repositories and routing writes to the correct JSONL
|
||||
|
|
@ -60,5 +65,3 @@ sync-branch: "beads-sync"
|
|||
# - linear.api-key
|
||||
# - github.org
|
||||
# - github.repo
|
||||
|
||||
dolt.database: "beads_bb"
|
||||
|
|
@ -1,6 +1,4 @@
|
|||
{
|
||||
"database": "dolt",
|
||||
"jsonl_export": "issues.jsonl",
|
||||
"backend": "dolt",
|
||||
"dolt_database": "beads_bb"
|
||||
"database": "beads.db",
|
||||
"jsonl_export": "issues.jsonl"
|
||||
}
|
||||
18
.beads/templates/standard-app.json
Normal file
18
.beads/templates/standard-app.json
Normal file
|
|
@ -0,0 +1,18 @@
|
|||
{
|
||||
"id": "standard-app",
|
||||
"name": "Standard Application Swarm",
|
||||
"description": "A balanced team of an Architect and two Coders for standard feature development.",
|
||||
"team": [
|
||||
{
|
||||
"archetypeId": "architect",
|
||||
"count": 1
|
||||
},
|
||||
{
|
||||
"archetypeId": "coder",
|
||||
"count": 2
|
||||
}
|
||||
],
|
||||
"createdAt": "2026-02-21T03:22:04.089Z",
|
||||
"updatedAt": "2026-02-21T19:39:45.443Z",
|
||||
"isBuiltIn": true
|
||||
}
|
||||
14
.beads/templates/test.json
Normal file
14
.beads/templates/test.json
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
{
|
||||
"id": "test",
|
||||
"name": "test",
|
||||
"description": "test",
|
||||
"team": [
|
||||
{
|
||||
"archetypeId": "architect",
|
||||
"count": 1
|
||||
}
|
||||
],
|
||||
"createdAt": "2026-02-21T19:37:35.674Z",
|
||||
"updatedAt": "2026-02-21T19:37:35.674Z",
|
||||
"isBuiltIn": false
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue