skills/way-of-working/SKILL.md
Ronan's default working norms — commit cadence, checkpointing, asking for decisions, definition-of-done. Reference skill that should inform every coding session. Load at session start alongside coding-principles.
npx skillsauth add RonanCodes/ronan-skills way-of-workingInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
How Ronan wants day-to-day coding to feel. Short, blunt, non-negotiable unless he says otherwise mid-session.
Treat commits as save points, not milestones.
Use /ro:commit — it handles the emoji prefix, the timestamp rules, and the Co-Authored-By exclusion.
Before starting a multi-step task, spell out the checkpoints. After each one:
If a task fans out unexpectedly, break it into a second commit rather than bundling unrelated changes.
If a decision comes up that isn't obvious from context, use AskUserQuestion, not a question typed inline in chat. This is enforced by the global CLAUDE.md. Keep doing it — Ronan prefers the structured UI.
A task isn't done until:
tsc --noEmit clean on TS projects)"It probably works" is not done.
When you discover something unrelated that also wants fixing:
Scope creep is how clean commits turn into 2,000-line diffs nobody can review.
--no-verify on commits unless the user explicitly says sogit reset --hard or force-push without askingThe whole point of the cadence above is that recovery is always cheap. Respect that.
Claude Code is primary. Codex (GPT-5.5-backed desktop app) earns a slot for parallel async refactors and high-volume cheap-token bulk jobs (one cited 10x cost win on a mechanical refactor). Reach for it when the work is mechanical, fan-out parallel, and Claude Code's per-task latency dominates. Default everything else to Claude Code; the .claude/skills/ library, hooks, and ralph loop are a Claude-Code-native moat that does not port.
/ro:coding-principles — the what: simplicity, SOLID, DRY, testing normsBoth should be in mental scope for every session.
development
Close the loop on a Linear ticket when its work ships - move the status and post a deploy comment with the PR link, what shipped, and a try-it link, mentioning the collaborator. Used as the tail of /ro:linear-nightshift for every merged mirror, or manually after an ad-hoc build. Triggers on "linear update", "update the linear ticket", "mark NUT-x done", "tell eoin it shipped", "/ro:linear-update".
devops
Run a night-shift against a collaborator's Linear board. Pulls the team's Grilled tickets (/ro:linear-grill moves a ticket to Grilled once its questions are answered), VERIFIES the questions were actually answered (unanswered → bounce the ticket to the "Question for <name>" state), mirrors verified tickets to ephemeral GitHub issues with ready-for-agent, then runs the standard /ro:night-shift machinery on GitHub. Tail-calls /ro:linear-update for everything that merged + deployed. Triggers on "linear nightshift", "nightshift linear", "drain the linear board", "run the shift off linear", "/ro:linear-nightshift".
development
Grill a collaborator's Linear tickets and move every processed ticket to where it belongs. Resolves the board from the repo's .ro-linear.json, reads the collaborator's Backlog / Ready-for-agent issues, then per ticket either posts 3-5 decision-extracting questions (state moves to "Question for <name>") or confirms it build-ready (state moves to "Grilled", the gate /ro:linear-nightshift consumes); shipped-and-confirmed tickets close as Done. The async-collaborator counterpart of /ro:day-shift for people who never touch GitHub. Triggers on "grill linear", "grill eoin's tickets", "linear grill", "add questions to the linear tickets", "/ro:linear-grill".
development
--- name: about-page description: Add a standard About page to any web app, what it is, the tech stack, and an FAQ, wired into a footer link with a sticky footer. Built with Spartan + Tailwind (the canonical component layer) and falls back to semantic HTML so it ships reliably. Use whenever building, polishing, or shipping an app, every app should have one. Triggers on "add an about page", "about page", "footer about link", or as a standard step in app build/polish. category: frontend argument-h