ClearNotation: a docs-first, formally specified markup language
Project description
ClearNotation
A docs-first markup language with a formally specified grammar, fail-closed parsing, and typed extensibility. Not Markdown-compatible. That's the point.
Why
Markdown has no formal grammar, ambiguous parse rules, 41 incompatible flavors, and uses inline HTML as an escape hatch. ClearNotation is a clean-sheet design that trades Markdown compatibility for correctness, predictability, and a real spec you can implement against.
Quick look
::meta{
title = "Example Document"
}
# Getting started
ClearNotation uses +{strong text}, *{emphasized text}, `code spans`,
[links -> https://example.com], and ^{inline footnotes that render as endnotes}.
- Nested lists work // inline comments too
- Two-space indent per level
- Multi-paragraph items via blank line + indent
1. Ordered lists preserve authored numbers
- Mixed nesting (ordered + unordered)
::callout[kind="tip", title="One syntax per concept"]{
No `*` vs `**` ambiguity. No flavor differences. No inline HTML.
}
::include[src="partials/intro.cln"]
Try it
Project site — overview, syntax comparison, and install instructions.
Live editor — visual editing on the left, ClearNotation source on the right, live bidirectional sync.
Features: templates (PRD, design doc, meeting notes), dark mode, keyboard shortcuts, syntax cheat sheet, Markdown paste auto-conversion, File System Access API for open/save, localStorage autosave, HTML export, WCAG 2.1 AA accessibility.
Local dev: cd editor && pnpm dev starts the editor at localhost:5173.
Interactive playground: /playground.html lets you type ClearNotation and see the tree-sitter parse tree update live.
Install
VS Code
Search "ClearNotation" in the extensions marketplace, or:
ext install ClearNotation.clearnotation
Python toolchain (CLI, LSP, renderer)
pip install clearnotation # CLI: cln build, cln check, cln ast, cln fmt, cln init, cln watch
pip install clearnotation[convert] # Markdown-to-CLN converter via mistune
pip install clearnotation[math] # LaTeX math rendering via latex2mathml
pip install clearnotation[highlight] # Syntax highlighting via Pygments
pip install clearnotation[watch] # File watcher for cln watch
pip install clearnotation[lsp] # LSP server for editor integration
JavaScript (normalizer + renderer)
npm install clearnotation-js
Editor (local dev)
git clone https://github.com/rjmitchell/clear-notation.git
cd clear-notation
pnpm install # install all workspace packages
cd editor && pnpm dev # start the visual editor at localhost:5173
Usage
cln build document.cln # compile .cln to HTML
cln build docs/ # compile all .cln files in a directory
cln check document.cln # validate without rendering (for CI)
cln ast document.cln # dump normalized AST as JSON
cln fmt document.cln # format (stdout)
cln fmt --write document.cln # format in place
cln fmt --check document.cln # check formatting (exit 1 if changes needed)
cln init # scaffold a new project (clearnotation.toml + docs/index.cln)
cln init my-project # scaffold in a specific directory
cln watch docs/ # watch for changes, rebuild, serve at localhost:8000
# Document platform tools
cln convert docs.md # convert Markdown to CLN
cln convert docs/ -o out/ # convert directory of Markdown files
cln index docs/ # index .cln files into SQLite (.cln-index.db)
cln query docs/ --stats # corpus stats: directive histogram, broken references
cln query docs/ --directive callout # find docs using a specific directive
cln query docs/ --title "API" # find docs by title (substring match)
cln lint docs/ --schema schema.toml # validate corpus against a TOML schema
What's in the box
Language and toolchain
- Normative EBNF grammar (
clearnotation-v1.0.ebnf) - Reference parser, validator, normalizer, and HTML renderer in Python
- 70 conformance fixtures with a manifest-driven test harness and AST snapshot assertions
- Default stylesheet (
clearnotation.css) with light/dark mode, callouts, tables, footnotes, TOC - Formatter (
cln fmt) with roundtrip-correct formatting - Multi-error diagnostics for the validator (reports all block-level errors, not just the first)
- LaTeX math rendering via
latex2mathml(optional,::math{...}blocks) - Syntax highlighting via Pygments for rendered code blocks (optional)
Browser editor
- Visual editor (BlockNote/React) with live CLN source pane (CodeMirror)
- Bidirectional sync with a discriminated-union
syncState(valid | recovered | broken), 300ms debounce, async race guard via generation counter, and recovery for incomplete source (e.g.+{bold}without a trailing newline still renders as bold) - Round-trip correctness for footnotes (
^{...}), cross-references (::ref[target="x"]), and anchors (::anchor[id="..."]) — structural content survives open → edit → save → reload byte-identical when unedited - Broken-state UX when source has a genuine syntax error: visual pane dims + read-only, source pane shows a CodeMirror gutter marker,
aria-liveannounces the state change - Templates, dark mode, keyboard shortcuts, cheat sheet, Markdown paste conversion
- File operations (File System Access API, download fallback, localStorage autosave)
- Tree-sitter WASM playground at
/playground.html
Developer tooling
- Tree-sitter grammar for syntax highlighting and incremental parsing
- JS normalizer and HTML renderer (
clearnotation-js/) for browser-side HTML export - VS Code extension with LSP diagnostics (in
vscode-clearnotation/) - GitHub Actions CI/CD (TypeScript check, Vitest, Python tests, fixture harness, GitHub Pages deploy)
Architecture
pnpm workspace (repo root)
├── clearnotation_reference/ Python: parser, validator, normalizer, renderer, CLI, LSP
├── editor/ Browser editor: React + BlockNote + CodeMirror + Vite
│ └── src/
│ ├── parser/ Tree-sitter WASM parser (Web Worker)
│ ├── schema/ BlockNote block/inline specs from registry
│ ├── converter/ CST → BlockNote document model
│ ├── serializer/ BlockNote → ClearNotation source text
│ └── components/ React UI (SplitPane, Toolbar, SourcePane, CheatSheet, etc.)
├── clearnotation-js/ JS normalizer + HTML renderer (browser-side HTML export)
├── tree-sitter-clearnotation/ Tree-sitter grammar + WASM build
├── vscode-clearnotation/ VS Code extension
└── fixtures/ Conformance test fixtures + escaping matrix
Key differences from Markdown
| Concept | Markdown | ClearNotation |
|---|---|---|
| Bold | **text** |
+{text} |
| Italic | *text* |
*{text} |
| Link | [label](url) |
[label -> url] |
| Footnote | [^ref] + definition |
^{inline note text} |
| Table | pipe tables | ::table[header=true]{ ... } |
| Callout | blockquote hacks | ::callout[kind="warning"]{ ... } |
| Image |  |
::figure[src="path"]{ caption } |
| Nested lists | indentation (fragile) | 2-space indent, mixed types |
| Include | not built-in | ::include[src="path.cln"] |
| Comments | not built-in | // block and text // inline |
| Code fence | language optional | language required |
| Inline HTML | allowed | always escaped |
Design principles
- One canonical syntax per concept
- Formally defined, trivially parsable grammar
- Fail-closed: unknown directives, attributes, and refs are errors, not silent passthrough
- Extensions declared in
clearnotation.toml, never in documents - No inline HTML, no executable hooks, no Turing completeness
- Readable raw source
Running the test suite
# Python tests (362 tests)
python3 -m unittest discover -s tests -v
# Conformance fixture harness (70 cases)
python3 -m clearnotation_harness --manifest fixtures/manifest.toml \
--adapter clearnotation_reference.adapter:create_adapter
# Editor tests (424 tests)
cd editor && pnpm test
# JS normalizer/renderer tests (129 tests)
cd clearnotation-js && pnpm test
Spec documents
clearnotation-v1.0.ebnf— normative grammarclearnotation-v1.0-syntax.md— syntax decisionsclearnotation-v1.0-ast-conformance.md— AST model and conformanceclearnotation-v0.1-config.md— config contractclearnotation-v0.1-examples.md— conformance corpus
License
MIT
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file clearnotation-1.0.2.tar.gz.
File metadata
- Download URL: clearnotation-1.0.2.tar.gz
- Upload date:
- Size: 77.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2ad85ecbf52aacd899209192c25b63f2dc19cf4c89d813e48b12a5b841a69405
|
|
| MD5 |
cd01867610c080a3c722f83f4115059d
|
|
| BLAKE2b-256 |
c477e4e8338341db75717a8cffeeaa566611dff9fe8bbd8817e0646a2868f585
|
Provenance
The following attestation bundles were made for clearnotation-1.0.2.tar.gz:
Publisher:
publish-pypi.yml on rjmitchell/clear-notation
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
clearnotation-1.0.2.tar.gz -
Subject digest:
2ad85ecbf52aacd899209192c25b63f2dc19cf4c89d813e48b12a5b841a69405 - Sigstore transparency entry: 1280370640
- Sigstore integration time:
-
Permalink:
rjmitchell/clear-notation@c3e97f56684c379d6c406fee3f6b2a6b4894d8ae -
Branch / Tag:
refs/tags/v1.0.2 - Owner: https://github.com/rjmitchell
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@c3e97f56684c379d6c406fee3f6b2a6b4894d8ae -
Trigger Event:
push
-
Statement type:
File details
Details for the file clearnotation-1.0.2-py3-none-any.whl.
File metadata
- Download URL: clearnotation-1.0.2-py3-none-any.whl
- Upload date:
- Size: 63.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce4bc8d772724e2976fd2782d2397b2fedc0937d869984479fc0e1b04c743694
|
|
| MD5 |
c2096a3b11f05cf630e780d52fe7faf7
|
|
| BLAKE2b-256 |
727df300068da6c2dddde263adaa892d0a779acf8d62784252b87ac21e01eab2
|
Provenance
The following attestation bundles were made for clearnotation-1.0.2-py3-none-any.whl:
Publisher:
publish-pypi.yml on rjmitchell/clear-notation
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
clearnotation-1.0.2-py3-none-any.whl -
Subject digest:
ce4bc8d772724e2976fd2782d2397b2fedc0937d869984479fc0e1b04c743694 - Sigstore transparency entry: 1280370644
- Sigstore integration time:
-
Permalink:
rjmitchell/clear-notation@c3e97f56684c379d6c406fee3f6b2a6b4894d8ae -
Branch / Tag:
refs/tags/v1.0.2 - Owner: https://github.com/rjmitchell
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@c3e97f56684c379d6c406fee3f6b2a6b4894d8ae -
Trigger Event:
push
-
Statement type: