Skip to main content

Spec-Up-T Cheatsheet

info

Since “Installation & Setup” is used less often, this is listed below.

Set up your editing environment

We advice to keep a production version of your latest generated/rendered index.html file open, next to your IDE. This way you're able to:

  1. Create/check internal cross-references: Find and copy the anchor to the found header in the browser, and paste it in the markdown via IDE.
  2. Check where an existing link goes while hovering over the link.

Example of copying anchors (1):

  • use browser find-function (command-F) to find a block to cross-reference to
  • use the § anchor link to copy the anchor URL
  • paste and shorten the full URL to only the anchor.

NB 1. You can bypass this workflow, by predicting the way the markdown header will be transformed into an anchor and do all of this in the IDE. Safer is copy via the browser.

NB 2. If you change the header in markdown the link will be broken

Go to a Spec-Up-T specification or glossary and hover over any link, the browser will show the URL (including an anchor if applicable). A visual check is now possible and also the link can be copied.

hover over link

TL;DR

  1. npx create-spec-up-t project-name
  2. Add terms in spec/terms-definitions/*.md with [[def: term, alias]] or [[tref: term, alias]] (external definition)
  3. Reference with [[ref: term]] or [[xref: spec, term]]
  4. npm run menu → Option 4 (Also runs Option 1)
  5. Open docs/index.html

Run npm run menu to access the interactive menu. You can also run these commands directly using npm run <command>.

OptionDescriptionNPM Command
[0]Add contentN/A
[1]Render specificationnpm run render
[2]Export to PDFnpm run topdf
[3]Export to DOCXnpm run todocx
[4]Collect external referencesnpm run collectExternalReferences
[5]Add, remove or view xref sourcenpm run addremovexrefsource
[6]Configurenpm run configure
[7]Run health checknpm run healthCheck
[8]Open documentation websiteN/A
[9]Freeze specificationnpm run freeze
[Q]QuitN/A

Reference Types

TypeSyntaxPurposeOutput
def[[def:term,alias]]🏷️ Define new termCreates anchor point
ref[[ref:term]]🔗 Link to local termClickable internal link
xref[[xref:spec,term]]🌐 Link to externalOpens external spec
tref[[tref:spec,term, alias]]📥 Import external definitionEmbeds full content
spec[[spec:RFC-7519]]📚 Cite specificationLinks to standard spec
info

The , (comma) is the delimiter. A space after a comma is okay, but not necessary.

Creating Definition Files

1. Create a new term file

# Navigate to terms directory
cd spec/terms-definitions/

# Create new definition file
touch my-new-term.md
info

File name should be descriptive but doesn't need to match the term

2. Basic term file structure

[[def: primary-term, synonym1, synonym2]]

~ This is the definition of the term using tilde prefix.

~ Additional paragraphs also use the tilde prefix.

~ Each paragraph represents a separate concept or detail.

Here follows a description of the structure of a term file:

Markdown snippetExplanation
[[def: primary-term, synonym1, synonym2]]The definition should be the first line
~ This is the definition of the term using tilde prefix.Each new line should start with a ~ to indicate that it belongs to the definition (it becomes a <dd>…</dd> in HTML)
~ Additional paragraphs also use the tilde prefix."
~ Each paragraph represents a separate concept or detail."
info

[[def: primary-term,synonym1,synonym2]] without the spaces is also okay.

Key Points:

  • File name should be descriptive but doesn't need to match the term
  • [[def:]] tag must be the first line
  • Multiple synonyms are comma-separated
  • Definition content uses ~ prefix for each paragraph

Reference Syntax

[[def: ...]]

Local Term Definition example:

[[def: authentication, auth, authn]]

~ The process of verifying the identity of a user or system.

Usage: First line of term definition files only

[[ref: ...]]

Internal Reference example:

[[def: access-control]]

~ Access control is a security technique that regulates who or what can view or use resources in a computing environment.

~ The system requires [[ref: authentication]] before access.

Usage: Anywhere in the definition part of the content, to link to locally defined terms

[[xref: ...]]

External Reference example:

[[def: verifiable-credential]]

~ A verifiable credential is a tamper-evident credential that has authorship that can be cryptographically verified.

~ See the [[xref: external-spec, credential]] specification for more details.

Usage: Anywhere in the definition part of the content, to link to terms in other Spec-Up-T repositories

[[tref: ...]]

Transcluded Reference example:

[[tref: external-spec, digital-signature, alias]]

Usage: Embeds complete external definition (file can contain only this tag, but optionally you can add text in your local file, that will be added below the external, embedded definition)

info

Final result:

[[tref: …]]

External definition text.

Optional: your own text.

Specification Reference: [[spec: ...]]

According to [[spec: RFC-7519]], JSON Web Tokens are...

Usage: Reference standard specifications (from specref.org database) currently under development.

Rendering & Menu Navigation

Launch Menu

npm run menu

Menu Options:

  ,---.                  .   .        --.--
`---.,---.,---.,---. | |,---. |
|| ||---'| ---| || |--- |
`---'|---'`---'`---' `---'|---' `
| |


Please choose one of the following options:

[0] Add content
[1] Render specification
[2] Export to PDF
[3] Export to DOCX
[4] Collect external references
[5] Add/remove xref source
[6] Configure
[7] Run health check
[8] Open documentation website
[9] Freeze specification
[Q] Quit


An xref is a reference to another repository.

Enter your choice:

[0]: Add content

What it does:

  • Shows a short instruction on how to add content
  • Shows a link to the this website (the website you are currently reading)

[1]: Render Specification

What it does:

  • Processes all markdown files
  • Resolves term references
  • Generates docs/index.html
  • Creates complete specification
  • Opening in a browser via local file system (file:///) will work for almost everything (simply put: double click on the file in “Finder” or “Explorer”)

[2]: Export to PDF

What it does:

  • Exports the specification to PDF format
  • Creates a .pdf file

[3]: Export to DOCX

What it does:

  • Exports the specification to Microsoft Word format
  • Creates a .docx file

[4]: Collect External References

What it does:

  • Fetches definitions from external repositories
  • Updates local cache with latest versions
  • Also runs option 1

When to use:

  • After adding new external specifications

[5]: Add/remove xref source

What it does:

  • Allows you to add or remove external specification sources
  • Manages the list of repositories that can be referenced with [[xref: ...]] and [[tref: ...]]

[6]: Configure

What it does:

  • Opens configuration options for the Spec-Up-T project
  • Allows you to modify settings in specs.json

[7]: Run Health Check

What it does:

  • Provides diagnostic information

[8]: Open Documentation Website

Alternative: Opens https://blockchainbird.github.io/spec-up-t-website/

[9]: Freeze Specification

What it does:

  • Creates a snapshot of your current specification

[Q]: Quit

What it does:

  • Quits the menu

Installation & Setup

# Create new Spec-Up-T project
npx create-spec-up-t my-spec-project
cd my-spec-project

# npm install will run automatically

# Launch interactive menu
npm run menu

Clone Existing Repository

# Clone existing Spec-Up-T repository
git clone https://github.com/username/repository-name.git
cd repository-name

# Check out correct branch (if needed)
git checkout branch-name

# Install dependencies
npm install

# Launch interactive menu
npm run menu

Key Steps:

  1. Get repository URL from GitHub (green "Code" button)
  2. Clone with git clone <url>
  3. Navigate into cloned directory
  4. Install dependencies with npm install
  5. Run menu to start working

Remote Setup (Recommended):

# Add upstream remote for original repo
git remote add upstream https://github.com/original/repo.git

# Set origin to your fork
git remote set-url origin https://github.com/yourusername/repo.git

Project Structure

docs/: output files spec/: input files

my-spec-project/
├── .cache/ # 📝 Can be removed at all times
├── docs/
│ ├── versions/ # 📝 Versioned files
│ │ ├── v1
│ │ └── v2
│ ├── index.html # 📄 The final specification file

├── spec/
│ ├── terms-definitions/ # 📝 Individual term files
│ │ ├── term-1.md
│ │ └── term-2.md
│ ├── spec-head.md # 📄 Main content files
│ └── spec-body.md
└── specs.json # ⚙️ Configuration

Configuration Example

specs.json: Go to specs.json (raw file in the Spec-Up-T repo boilerplate code)

Common Patterns & Tips

❌ DON'T

  • … put content before [[def:]] or [[tref:]] tag in term files
  • … forget the ~ prefix for definition content
  • … skip re-running menu option 4 when using new xref/tref