mirror of
https://github.com/instructkr/claude-code.git
synced 2026-05-27 07:56:46 +00:00
Constraint: roadmap-next-id.sh must preserve single-id stdout on success while failing closed if duplicate validation cannot run. Rejected: Relying only on CI/pre-push duplicate checks | the helper is used immediately before appending and must not certify an already-poisoned file. Confidence: high Scope-risk: narrow Directive: Keep roadmap-next-id.sh stdout machine-clean; route validation failures and checker availability errors to stderr, and keep focused helper behavior coverage in the docs/ROADMAP CI path. Tested: scripts/roadmap-next-id.sh ROADMAP.md printed 725 before appending #725 and 726 after; temp ROADMAP with duplicate 999 exited nonzero and listed duplicate id; scripts/roadmap-check-ids.sh ROADMAP.md; bash -n scripts/roadmap-next-id.sh scripts/roadmap-check-ids.sh; python -m unittest discover -s tests -p test_roadmap_helpers.py; python -m pytest tests/test_roadmap_helpers.py -q; SKIP_CLAW_PRE_PUSH_BUILD=1 bash .github/hooks/pre-push Not-tested: full cargo workspace build, unchanged docs/script-only path
58 lines
1.6 KiB
Bash
Executable File
58 lines
1.6 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# roadmap-next-id.sh — print the next available ROADMAP item id.
|
|
# Usage: scripts/roadmap-next-id.sh [path/to/ROADMAP.md]
|
|
#
|
|
# Designed to be used before appending a new entry so that concurrent
|
|
# dogfood claws do not accidentally reuse the same id:
|
|
#
|
|
# NEXT=$(scripts/roadmap-next-id.sh)
|
|
# cat >> ROADMAP.md << EOF
|
|
# ${NEXT}. **...description...**
|
|
# EOF
|
|
#
|
|
# The script first validates helper-era ids with roadmap-check-ids.sh, then
|
|
# reads the highest numeric id prefix from ROADMAP.md and prints highest+1. It
|
|
# does not lock the file; callers working in parallel should git-pull
|
|
# immediately before appending, run scripts/roadmap-check-ids.sh before push,
|
|
# and resolve any append collision at git-push time.
|
|
set -euo pipefail
|
|
|
|
ROADMAP="${1:-ROADMAP.md}"
|
|
SCRIPT_DIR="$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" && pwd -P)"
|
|
CHECKER="$SCRIPT_DIR/roadmap-check-ids.sh"
|
|
|
|
if [[ ! -f "$ROADMAP" ]]; then
|
|
echo "error: ROADMAP not found at $ROADMAP" >&2
|
|
exit 1
|
|
fi
|
|
|
|
if [[ ! -f "$CHECKER" || ! -r "$CHECKER" ]]; then
|
|
echo "error: required ROADMAP id checker not found or not readable at $CHECKER" >&2
|
|
echo "error: refusing to print a next id without duplicate-id validation" >&2
|
|
exit 1
|
|
fi
|
|
|
|
if ! checker_output="$(bash "$CHECKER" "$ROADMAP" 2>&1)"; then
|
|
printf '%s\n' "$checker_output" >&2
|
|
exit 1
|
|
fi
|
|
|
|
# Find the highest leading integer from lines that start with a number + '.'.
|
|
highest=$(awk '
|
|
/^[0-9]+\./ {
|
|
id = $0
|
|
sub(/\..*/, "", id)
|
|
id += 0
|
|
if (id > highest) {
|
|
highest = id
|
|
}
|
|
}
|
|
END { print highest + 0 }
|
|
' "$ROADMAP")
|
|
|
|
if [[ "$highest" -eq 0 ]]; then
|
|
echo 1
|
|
else
|
|
echo $(( highest + 1 ))
|
|
fi
|