From 2b8d56f4f1c0c4eebd297712c3f4a2d33a7ae25a Mon Sep 17 00:00:00 2001 From: "copilot-swe-agent[bot]" <198982749+Copilot@users.noreply.github.com> Date: Mon, 16 Mar 2026 12:44:26 +0000 Subject: [PATCH 1/5] Initial plan From c9a96cb449c51f11939c111e4d213ea1eefea1a3 Mon Sep 17 00:00:00 2001 From: "copilot-swe-agent[bot]" <198982749+Copilot@users.noreply.github.com> Date: Mon, 16 Mar 2026 12:56:40 +0000 Subject: [PATCH 2/5] Migrate to OpenSpec: initialize, migrate specs, update docs/rules - Install and initialize OpenSpec (openspec init) - Migrate specs from docs/specs/ to openspec/specs/ (organized by domain) - Configure openspec/config.yaml with project context and rules - Update AGENTS.md to reference OpenSpec workflow - Update .windsurf/ rules and README for OpenSpec - Clean up broken symlinks (.github/skills, .claude/skills, .windsurf/skills) - Remove empty .skills/ directory and .kilocode/rules/ - Add OpenSpec skills/commands for GitHub Copilot, Claude, Cursor, Windsurf Co-authored-by: ThePlenkov <6381507+ThePlenkov@users.noreply.github.com> --- .claude/commands/opsx/apply.md | 152 +++++++++ .claude/commands/opsx/archive.md | 157 ++++++++++ .claude/commands/opsx/explore.md | 173 +++++++++++ .claude/commands/opsx/propose.md | 106 +++++++ .claude/skills | 1 - .claude/skills/openspec-apply-change/SKILL.md | 156 ++++++++++ .../skills/openspec-archive-change/SKILL.md | 114 +++++++ .claude/skills/openspec-explore/SKILL.md | 288 ++++++++++++++++++ .claude/skills/openspec-propose/SKILL.md | 110 +++++++ .cursor/commands/opsx-apply.md | 152 +++++++++ .cursor/commands/opsx-archive.md | 157 ++++++++++ .cursor/commands/opsx-explore.md | 173 +++++++++++ .cursor/commands/opsx-propose.md | 106 +++++++ .cursor/skills/openspec-apply-change/SKILL.md | 156 ++++++++++ .../skills/openspec-archive-change/SKILL.md | 114 +++++++ .cursor/skills/openspec-explore/SKILL.md | 288 ++++++++++++++++++ .cursor/skills/openspec-propose/SKILL.md | 110 +++++++ .github/prompts/opsx-apply.prompt.md | 149 +++++++++ .github/prompts/opsx-archive.prompt.md | 154 ++++++++++ .github/prompts/opsx-explore.prompt.md | 170 +++++++++++ .github/prompts/opsx-propose.prompt.md | 103 +++++++ .github/skills | 1 - .github/skills/openspec-apply-change/SKILL.md | 156 ++++++++++ .../skills/openspec-archive-change/SKILL.md | 114 +++++++ .github/skills/openspec-explore/SKILL.md | 288 ++++++++++++++++++ .github/skills/openspec-propose/SKILL.md | 110 +++++++ .kilocode/rules/rules.md | 0 .skills/skills | 1 - .windsurf/README.md | 19 +- .windsurf/rules/project-planning-memory.md | 27 +- .windsurf/rules/spec-first-then-code.md | 18 +- .windsurf/skills | 1 - .../skills/openspec-apply-change/SKILL.md | 156 ++++++++++ .../skills/openspec-archive-change/SKILL.md | 114 +++++++ .windsurf/skills/openspec-explore/SKILL.md | 288 ++++++++++++++++++ .windsurf/skills/openspec-propose/SKILL.md | 110 +++++++ .windsurf/workflows/opsx-apply.md | 152 +++++++++ .windsurf/workflows/opsx-archive.md | 157 ++++++++++ .windsurf/workflows/opsx-explore.md | 173 +++++++++++ .windsurf/workflows/opsx-propose.md | 106 +++++++ AGENTS.md | 31 +- docs/README.md | 91 +++--- docs/planning/abap-code-review.md | 2 +- openspec/config.yaml | 29 ++ .../specs/adk}/abapgit-serialization.md | 0 .../specs/adk}/adk-factory.md | 0 .../specs/adk}/adk2-on-xmld.md | 0 .../specs/adk/intelligent-object-factory.md | 0 .../specs/adk/object-grouping-structure.md | 0 .../adk/redesigned-object-architecture.md | 0 .../README.md => openspec/specs/adk/spec.md | 0 .../specs/adt-cli}/adt-response-logging.md | 0 .../specs/adt-cli/logging-and-utilities.md | 0 .../specs/adt-cli/plugin-architecture.md | 0 .../specs/adt-cli/spec.md | 0 .../specs/adt-client/spec.md | 0 .../specs/cicd/abap-cicd-pipeline.md | 0 .../README.md => openspec/specs/cicd/spec.md | 0 .../specs/oat/adt-cli-integration.md | 0 .../specs/oat/format-comparison.md | 0 .../specs/oat/format-structure.md | 0 .../specs/oat/metadata-schema.md | 0 .../specs/oat/project-structure.md | 0 .../README.md => openspec/specs/oat/spec.md | 0 64 files changed, 5136 insertions(+), 97 deletions(-) create mode 100644 .claude/commands/opsx/apply.md create mode 100644 .claude/commands/opsx/archive.md create mode 100644 .claude/commands/opsx/explore.md create mode 100644 .claude/commands/opsx/propose.md delete mode 120000 .claude/skills create mode 100644 .claude/skills/openspec-apply-change/SKILL.md create mode 100644 .claude/skills/openspec-archive-change/SKILL.md create mode 100644 .claude/skills/openspec-explore/SKILL.md create mode 100644 .claude/skills/openspec-propose/SKILL.md create mode 100644 .cursor/commands/opsx-apply.md create mode 100644 .cursor/commands/opsx-archive.md create mode 100644 .cursor/commands/opsx-explore.md create mode 100644 .cursor/commands/opsx-propose.md create mode 100644 .cursor/skills/openspec-apply-change/SKILL.md create mode 100644 .cursor/skills/openspec-archive-change/SKILL.md create mode 100644 .cursor/skills/openspec-explore/SKILL.md create mode 100644 .cursor/skills/openspec-propose/SKILL.md create mode 100644 .github/prompts/opsx-apply.prompt.md create mode 100644 .github/prompts/opsx-archive.prompt.md create mode 100644 .github/prompts/opsx-explore.prompt.md create mode 100644 .github/prompts/opsx-propose.prompt.md delete mode 120000 .github/skills create mode 100644 .github/skills/openspec-apply-change/SKILL.md create mode 100644 .github/skills/openspec-archive-change/SKILL.md create mode 100644 .github/skills/openspec-explore/SKILL.md create mode 100644 .github/skills/openspec-propose/SKILL.md delete mode 100644 .kilocode/rules/rules.md delete mode 160000 .skills/skills delete mode 120000 .windsurf/skills create mode 100644 .windsurf/skills/openspec-apply-change/SKILL.md create mode 100644 .windsurf/skills/openspec-archive-change/SKILL.md create mode 100644 .windsurf/skills/openspec-explore/SKILL.md create mode 100644 .windsurf/skills/openspec-propose/SKILL.md create mode 100644 .windsurf/workflows/opsx-apply.md create mode 100644 .windsurf/workflows/opsx-archive.md create mode 100644 .windsurf/workflows/opsx-explore.md create mode 100644 .windsurf/workflows/opsx-propose.md create mode 100644 openspec/config.yaml rename {docs/specs => openspec/specs/adk}/abapgit-serialization.md (100%) rename {docs/specs => openspec/specs/adk}/adk-factory.md (100%) rename {docs/specs => openspec/specs/adk}/adk2-on-xmld.md (100%) rename {docs => openspec}/specs/adk/intelligent-object-factory.md (100%) rename {docs => openspec}/specs/adk/object-grouping-structure.md (100%) rename {docs => openspec}/specs/adk/redesigned-object-architecture.md (100%) rename docs/specs/adk/README.md => openspec/specs/adk/spec.md (100%) rename {docs/specs => openspec/specs/adt-cli}/adt-response-logging.md (100%) rename {docs => openspec}/specs/adt-cli/logging-and-utilities.md (100%) rename {docs => openspec}/specs/adt-cli/plugin-architecture.md (100%) rename docs/specs/adt-cli/README.md => openspec/specs/adt-cli/spec.md (100%) rename docs/specs/adt-client/README.md => openspec/specs/adt-client/spec.md (100%) rename {docs => openspec}/specs/cicd/abap-cicd-pipeline.md (100%) rename docs/specs/cicd/README.md => openspec/specs/cicd/spec.md (100%) rename {docs => openspec}/specs/oat/adt-cli-integration.md (100%) rename {docs => openspec}/specs/oat/format-comparison.md (100%) rename {docs => openspec}/specs/oat/format-structure.md (100%) rename {docs => openspec}/specs/oat/metadata-schema.md (100%) rename {docs => openspec}/specs/oat/project-structure.md (100%) rename docs/specs/oat/README.md => openspec/specs/oat/spec.md (100%) diff --git a/.claude/commands/opsx/apply.md b/.claude/commands/opsx/apply.md new file mode 100644 index 00000000..bf23721d --- /dev/null +++ b/.claude/commands/opsx/apply.md @@ -0,0 +1,152 @@ +--- +name: "OPSX: Apply" +description: Implement tasks from an OpenSpec change (Experimental) +category: Workflow +tags: [workflow, artifacts, experimental] +--- + +Implement tasks from an OpenSpec change. + +**Input**: Optionally specify a change name (e.g., `/opsx:apply add-auth`). If omitted, check if it can be inferred from conversation context. If vague or ambiguous you MUST prompt for available changes. + +**Steps** + +1. **Select the change** + + If a name is provided, use it. Otherwise: + - Infer from conversation context if the user mentioned a change + - Auto-select if only one active change exists + - If ambiguous, run `openspec list --json` to get available changes and use the **AskUserQuestion tool** to let the user select + + Always announce: "Using change: " and how to override (e.g., `/opsx:apply `). + +2. **Check status to understand the schema** + ```bash + openspec status --change "" --json + ``` + Parse the JSON to understand: + - `schemaName`: The workflow being used (e.g., "spec-driven") + - Which artifact contains the tasks (typically "tasks" for spec-driven, check status for others) + +3. **Get apply instructions** + + ```bash + openspec instructions apply --change "" --json + ``` + + This returns: + - Context file paths (varies by schema) + - Progress (total, complete, remaining) + - Task list with status + - Dynamic instruction based on current state + + **Handle states:** + - If `state: "blocked"` (missing artifacts): show message, suggest using `/opsx:continue` + - If `state: "all_done"`: congratulate, suggest archive + - Otherwise: proceed to implementation + +4. **Read context files** + + Read the files listed in `contextFiles` from the apply instructions output. + The files depend on the schema being used: + - **spec-driven**: proposal, specs, design, tasks + - Other schemas: follow the contextFiles from CLI output + +5. **Show current progress** + + Display: + - Schema being used + - Progress: "N/M tasks complete" + - Remaining tasks overview + - Dynamic instruction from CLI + +6. **Implement tasks (loop until done or blocked)** + + For each pending task: + - Show which task is being worked on + - Make the code changes required + - Keep changes minimal and focused + - Mark task complete in the tasks file: `- [ ]` → `- [x]` + - Continue to next task + + **Pause if:** + - Task is unclear → ask for clarification + - Implementation reveals a design issue → suggest updating artifacts + - Error or blocker encountered → report and wait for guidance + - User interrupts + +7. **On completion or pause, show status** + + Display: + - Tasks completed this session + - Overall progress: "N/M tasks complete" + - If all done: suggest archive + - If paused: explain why and wait for guidance + +**Output During Implementation** + +``` +## Implementing: (schema: ) + +Working on task 3/7: +[...implementation happening...] +✓ Task complete + +Working on task 4/7: +[...implementation happening...] +✓ Task complete +``` + +**Output On Completion** + +``` +## Implementation Complete + +**Change:** +**Schema:** +**Progress:** 7/7 tasks complete ✓ + +### Completed This Session +- [x] Task 1 +- [x] Task 2 +... + +All tasks complete! You can archive this change with `/opsx:archive`. +``` + +**Output On Pause (Issue Encountered)** + +``` +## Implementation Paused + +**Change:** +**Schema:** +**Progress:** 4/7 tasks complete + +### Issue Encountered + + +**Options:** +1.