
Writing Shape
Turn a markdown pile of notes or fragments into a publishable article through openings, paragraph-by-paragraph growth, and format decisions.
Overview
writing-shape is an agent skill for the Grow phase that shapes a read-only markdown pile into a publishable article via candidate openings and paragraph-by-paragraph collaborative drafting.
Install
npx skills add https://github.com/mattpocock/skills --skill writing-shapeWhat is this skill?
- Treats the input markdown pile as read-only; writes to a separate article file
- Drafts 2–3 candidate openings that imply different theses and forces a pick or hybrid
- Grows the piece paragraph by paragraph after the opening lands
- Debates format choices (lists, tables, callouts, quotes) at each step
- Re-reads the article file before writes to preserve in-session user edits
- 2–3 candidate openings per shaping session
Adoption & trust: 21.1k installs on skills.sh; 121k GitHub stars; 2/3 security scanners passed (skills.sh audits).
What problem does it solve?
You have a pile of notes or fragments but cannot pick an angle, opening, or paragraph order to make it publishable.
Who is it for?
Solo builders with raw material who want an interactive editor-in-the-loop rather than one-shot AI draft spam.
Skip if: Empty-slate ideation with no input file—use writing-fragments first—or users who want fully automated ghostwriting without choices.
When should I use this skill?
User has notes, fragments, or a rough draft markdown file and wants help turning it into something publishable.
What do I get? / Deliverables
You get a separate shaped article markdown file with a committed opening and grown body, ready for your own polish, SEO pass, or distribution.
- Separate shaped article markdown file
- Chosen opening and incrementally grown body with negotiated formatting
Recommended Skills
Journey fit
How it compares
Use for collaborative structural drafting from an existing pile instead of single-prompt “write my blog post” generation.
Common Questions / FAQ
Who is writing-shape for?
Indie makers and dev bloggers who already captured notes or fragments and need help choosing an angle and growing a full article interactively.
When should I use writing-shape?
During Grow/content when you have a markdown input file and want 2–3 opening options, then paragraph-by-paragraph expansion into a dedicated article document.
Is writing-shape safe to install?
It reads and writes files you specify; review the Security Audits panel on this page and keep sensitive source material out of agent-accessible paths if needed.
Workflow Chain
Requires first: writing fragments
SKILL.md
READMESKILL.md - Writing Shape
<what-to-do> The user has passed (or will pass) a markdown file of raw material. Treat it as the input pile — anything from a tidy list of fragments to a wall of unstructured prose to a transcript. The format does not matter. Read it end-to-end before doing anything else. Then run a shaping session that produces a separate article document. Do not edit the raw material file — it is read-only to this skill. If the user did not say where to save the article, ask once and remember the path. The user will be editing the article file during the session; always re-read it before writing so their edits are preserved. </what-to-do> <supporting-info> ## The loop 1. **Read the pile.** Read the input file in full. Form a sense of what's in it. 2. **Draft 2–3 candidate openings.** Each opening should imply a different thesis or angle for the article. Show all of them. Force the user to pick or compose a hybrid. The chosen opening defines what the rest of the article must do. 3. **Grow paragraph by paragraph.** After the opening lands, ask "given this opening, what does the reader need to hear next?" Pull material from the pile to answer. Argue about whether the next beat is a paragraph, a list, a table, a callout, a quote, a code block. Each format choice should be deliberate and defensible. 4. **Append to the article file as you go.** Don't batch. Write each agreed paragraph or block immediately so the user can see the article taking shape. 5. **Loop step 3 until the article is done.** The user decides when it's done. ## Conversational feel This is a grilling session inverted. In ideation, the question was "what are you actually noticing?" Here it's "what is this article actually arguing, and in what order does the reader need to hear it?" Push back. Refuse to let weak transitions slide. If a paragraph doesn't earn its place, cut it. Specific moves to keep using: - "What does this paragraph do for the reader that the previous one didn't?" - "If I cut this, what breaks?" - "Is this prose, or should it be a list? Why prose?" - "This sentence is doing two jobs — split it or pick one." - "The opening promised X. We've drifted to Y. Either re-thread it or change the opening." ## Pulling from the pile Treat the raw material as a quarry, not a script. Pull a fragment, rework it to fit the surrounding paragraph, and place it. A fragment may be split across multiple paragraphs, merged with another, or paraphrased. The pile's job is to be mined; the article's job is to read as one voice. If the pile lacks something the article needs, name the gap explicitly: "We need an example here and the pile doesn't have one — give me one now or we cut this section." ## Format arguments to actually have When choosing how to render a beat, weigh these tradeoffs out loud with the user, not silently: - **Prose vs. list.** Prose carries argument; lists carry parallel items. If items aren't truly parallel, prose is better. If they are, a list is faster to scan. - **Inline vs. callout.** Tips, warnings, and asides go in callouts (`> [!TIP]`, `> [!NOTE]`) — but only if they'd genuinely derail the main argument inline. Otherwise leave them inline. - **Table vs. repeated structure.** If the same shape repeats 3+ times with the same fields, a table. Otherwise prose with bold leads. - **Quote vs. paraphrase.** Quote when the original wording is the point. Paraphrase when only the idea matters. - **Code block vs. inline code.** Multi-line, runnable, or illustrative → block. Single token or identifier → inline. ## Writing rhythm Append to the article file as