ditacraft
Health Pass
- License — License: MIT
- Description — Repository has a description
- Active repo — Last push 0 days ago
- Community trust — 13 GitHub stars
Code Warn
- fs module — File system access in esbuild-standalone.js
Permissions Pass
- Permissions — No dangerous permissions requested
No AI report is available for this listing yet.
DitaCraft is a comprehensive Visual Studio Code extension for editing and publishing DITA (Darwin Information Typing Architecture) content
DitaCraft
The easiest way to edit and publish your DITA files
DitaCraft is a comprehensive Visual Studio Code extension for editing and publishing DITA (Darwin Information Typing Architecture) content. It provides syntax highlighting, real-time validation, smart navigation, AI-powered assistance, an MCP server for external AI agents, and seamless integration with DITA-OT for multi-format publishing.
Table of Contents
- Highlights
- Features
- Installation
- Quick Start
- Commands
- Configuration
- AI Provider Configuration
- MCP Server Integration
- Development
- Roadmap
- License
Highlights
🔗 Smart Navigation - Ctrl+Click on href, conref, keyref, and conkeyref attributes with full key space resolution
🔑 Key Space Resolution - Full DITA 1.3 spec-compliant key space construction: keyref chains, keyscope inheritance (PushDown), inline scope branches, provenance tracking, scope explosion protection (50 k cap), and explainKey() resolution diagnostics
✅ 13-Phase Validation Pipeline - DTD (TypesXML) + optional RelaxNG (salve-annos) + 43 DITA rules + custom rules with DITA 1.2/1.3/2.0 support, per-phase error isolation, severity overrides, and comment-based suppression
🌍 Localized Diagnostics - All 76+ diagnostic messages translatable (English + French included)
⚡ Real-time Validation - Smart debouncing (300ms topics, 1000ms maps) with per-document cancellation
🔒 Enterprise Security - Path traversal protection, XXE neutralization, command injection prevention, and quote-aware entity pre-checks (billion-laughs / XXE bypass-proof)
🚀 One-Click Publishing - Direct DITA-OT integration for HTML5, PDF, EPUB, and more
👁️ Live Preview - Side-by-side HTML5 preview with auto-refresh and bidirectional scroll sync
🗺️ Map Visualizer - Interactive tree view of DITA map hierarchies with navigation
📂 Activity Bar Views - DITA Explorer, Key Space, and Diagnostics views in dedicated sidebar
📝 21 Smart Snippets - Comprehensive DITA code snippets for rapid editing
🛡️ Rate Limiting - Built-in DoS protection for validation operations
🤖 AI-Powered Features - GitHub Copilot integration: @ditacraft chat participant, AI Quick Fix, AI Completion, map restructuring, and multi-provider cascade (Copilot → Anthropic → OpenAI → Ollama)
🔌 MCP Server - Standalone Model Context Protocol server for external AI agents (opencode, Claude Desktop, Cursor, Continue) — 6 tools, 3 resources, zero VS Code dependency
🧪 1564+ Tests - Extensively tested with comprehensive integration, security, and LSP server tests
📚 DITA User Guide - Comprehensive documentation written in DITA (~80 files, bookmap structure)
Features
🖥️ Language Server Protocol (LSP)
- Full-featured DITA Language Server running in a separate process for performance
- IntelliSense: Context-aware element, attribute, and value completions with subject scheme hierarchy grouping
- Hover: Element documentation tooltips from DITA schema with conref content preview
- Document Symbols: Hierarchical outline view (Ctrl+Shift+O)
- Workspace Symbols: Cross-file symbol search (Ctrl+T)
- Go to Definition: Navigate to href/conref/keyref targets with key space resolution
- Find References: Locate all usages of an element ID across files
- Rename: Rename IDs with automatic reference updates across workspace
- Formatting: XML document formatting with inline/block/preformatted handling
- Code Actions: 12 quick fixes for missing DOCTYPE, missing ID, missing title, empty elements, duplicate IDs, missing otherrole, deprecated indextermref, alt attribute conversion, missing alt text, invalid ID format sanitization, missing booktitle, missing mainbooktitle
- Linked Editing: Simultaneous open/close XML tag name editing
- Folding Ranges: Collapse XML elements, comments, and CDATA blocks
- Document Links: Clickable href/conref/keyref links with key resolution
- Diagnostics: XML well-formedness, DITA structure, ID, cross-reference, scope consistency, circular reference detection, DITA rules (43 Schematron-equivalent rules including DITA 2.0), profiling/subject scheme, DTD (OASIS catalog with DITA 1.2/1.3/2.0), optional RelaxNG, workspace-level analysis, DITAVAL validation, custom regex rules, per-rule severity overrides, and comment-based rule suppression
- Localization: All diagnostic messages translatable via i18n system (English + French)
🤖 AI-Powered Features (GitHub Copilot Integration)
@ditacraftChat Participant — Interact with your DITA workspace directly in GitHub Copilot Chat:/restructure— AI-driven DITA map reorganization with diff review before applying/validate— Get AI explanations for validation errors with fix suggestions/explain— Plain-language explanations of DITA structure and element usage/suggest-reuse— Find content reuse opportunities (shared topics, conrefs)
- F2: AI Map Restructure — Bound to
ditacraft.restructureMap; AI proposes a restructured map hierarchy; shows diff and asks for confirmation before writing - F3: AI Quick Fix — AI-generated fixes for 12 diagnostic codes (CM-001/002/003, XREF-001/003/004, STRUCT-003/004/005/008, DTD-001, XML-001) via Code Actions → "Fix with AI"
- F4: AI Completion — Enriched IntelliSense: AI suggests element content and attribute values in context
- Provider Cascade — Auto mode: Copilot → Anthropic → OpenAI → Ollama; supports
copilot-only,byok-only,local-onlymodes - Circuit Breaker — Per-provider resilience: 3 failures in 5 min opens the breaker (10 min cooldown); zero-dependency on unavailable providers
- Streaming Support — AI responses stream in real time via
vscode.lm(Copilot) or server-sent events (Anthropic/OpenAI); Ollama uses/api/generatewith streaming chunks - Metrics Dashboard — Request counts, latency, and error rates per provider; visible in the Configure AI panel
- DitaCraft: Configure AI — Guided setup for provider selection, API keys (stored securely via OS keychain), and feature toggles
✍️ Syntax Highlighting & Snippets
- Syntax highlighting for
.dita,.ditamap,.bookmap, and.ditavalfiles - Intelligent code snippets and auto-completion (21 comprehensive snippets)
- Support for all DITA topic types (concept, task, reference, topic, glossentry, troubleshooting)
🔗 Smart Navigation
- Ctrl+Click navigation in DITA maps, bookmaps, and topics
- Click on
hrefattributes in<topicref>elements to open referenced files - Click on
conrefattributes to navigate to content references - Click on
keyrefandconkeyrefto navigate to key-defined targets - Works with relative paths and handles fragment identifiers (e.g.,
file.dita#topic_id) - Visual link indicators (underlined references when you hover)
- Hover tooltip showing target filename and reference type
- Automatically resolves paths relative to the map file location
- Skips external URLs (http://, https://) - they won't be underlined
- Click on
- Full Key Space Resolution (complete as of v0.7.4)
- Automatically discovers root maps in your workspace
- Builds and caches key space from map hierarchies (DITA 1.3 spec-compliant BFS)
- Resolves
@keyref,@conkeyref, and key-based references including multi-hop keyref chains - Full
@keyscopesupport: PushDown inheritance, inline scope branches, qualified alias explosion cap (50,000 keys) - Provenance tracking: each key definition records its source line for diagnostics
explainKey()API returns a fullKeyResolutionReportwith lookup trace and keyref chain steps- Tiered caching (1-minute root map discovery, 5-minute key space TTL) with intelligent invalidation
- Navigate seamlessly between maps and topics in your documentation structure
- How to use:
- Open a
.ditamap,.bookmap, or.ditafile - Hover over any
href,conref,keyref, orconkeyrefvalue - it will be underlined - Ctrl+Click (Windows/Linux) or Cmd+Click (Mac) to open the target file
- Works with nested topicrefs, key definitions, and complex map structures
- Open a
✅ Advanced Validation
- Real-time validation on file open, save, and change with smart debouncing (300ms topics, 1000ms maps)
- Full DTD validation against DITA 1.2, 1.3, and 2.0 specifications using TypesXML
- Bundled DTDs for all three DITA versions (topic, concept, task, reference, map, bookmap, learning, etc.)
- Master OASIS XML Catalog with
<nextCatalog>chaining — auto-resolves PUBLIC IDs for any DITA version - Custom XML catalog support (
ditacraft.xmlCatalogPath) for DTD specializations - Parser pool (3 concurrent instances) for efficient reuse
- 100% W3C XML Conformance Test Suite compliance
- Optional RelaxNG validation using salve-annos + saxes
- Schema compilation with caching (max 20 grammars, JSON cache files)
- Root element to RNG schema auto-mapping (10 DITA element types)
- Configurable schema directory path
- 43 DITA rules (Schematron-equivalent) with DITA version awareness + custom regex rules
- 4 mandatory rules, 7 recommendation rules, 2 authoring rules, 8 accessibility rules
- 10 DITA 2.0 removal/migration rules (deprecated elements and attributes)
- Version-gated: rules apply only to relevant DITA versions
- Precise attribute-level diagnostic highlighting
- Custom regex rules from user-defined JSON file with fileType filtering and mtime-based caching
- Per-rule severity overrides — change any diagnostic code's severity or suppress it entirely
- Comment-based rule suppression —
<!-- ditacraft-disable CODE -->/<!-- ditacraft-enable CODE -->/<!-- ditacraft-disable-file CODE --> - Large file optimization — heavy validation phases skipped for files exceeding configurable size threshold
- Three validation engines:
- TypesXML (default, recommended) - Pure TypeScript DTD validation with no native dependencies
- Built-in parser with content model checking (lightweight, no full DTD)
- xmllint integration for external validation (requires libxml2 installation)
- DITA version detection: Auto-detects from
@DITAArchVersionattribute or DOCTYPE declaration - Scope validation: Validates
scope="local|peer|external"consistency with href format (DITA-SCOPE-001/002/003) - Circular reference detection: Detects href/conref/mapref cycles using DFS traversal (DITA-CYCLE-001)
- Workspace-level analysis:
DITA: Validate Workspacecommand with progress reporting- Cross-file duplicate root ID detection (DITA-ID-003)
- Unused topic detection — finds topics not referenced by any map (DITA-ORPHAN-001)
- Enterprise Security Features:
- XXE (XML External Entity) neutralization to prevent injection attacks
- Path traversal protection with workspace bounds validation
- Command injection prevention using safe execution methods
- Async file operations to prevent LSP event loop blocking
- Quote-aware entity pre-check —
]>inside quoted entity values cannot bypass billion-laughs or excessive-entity-count detection (defense-in-depth, CVE-class)
- Intelligent error highlighting:
- Inline error highlighting with squiggly underlines
- Errors appear in Problems panel with severity indicators
- Accurate line and column positioning
- Source attribution (DTD validator, XML parser, DITA validator, dita-rules)
- Auto-detection of DITA files:
- By extension:
.dita,.ditamap,.bookmap,.ditaval - By DOCTYPE: Recognizes DITA DOCTYPE declarations in
.xmlfiles
- By extension:
- Manual validation command:
DITA: Validate Current File(Ctrl+Shift+V / Cmd+Shift+V)
🚀 One-Click Publishing
- Publish to multiple formats: HTML5, PDF, EPUB, and more
- Direct integration with DITA Open Toolkit (DITA-OT)
- Real-time progress tracking with visual indicators
- Smart caching for faster preview generation
👁️ Live Preview
- Side-by-side HTML5 preview with WebView panel
- Auto-refresh on save with configurable behavior
- Bidirectional scroll sync - Editor and preview scroll positions stay synchronized
- Theme support - Light, dark, and auto modes (follows VS Code theme)
- Custom CSS - Apply custom stylesheets to preview
- Print preview mode - Print-optimized view with dedicated print button
- Navigate directly from source to preview
📊 Build Output
- Syntax-highlighted output - DITA-OT build output with automatic colorization
- Log level detection - Errors, warnings, info, and debug messages color-coded
- Error diagnostics - Build errors parsed and shown in Problems panel
- Timestamped builds - Build start and completion times displayed
- Validation report - Full guide validation results in WebView panel with filtering, search, and export
📂 Activity Bar Views
- DitaCraft sidebar in the Activity Bar with three dedicated tree views
- DITA Explorer — All workspace maps with expandable hierarchy, type icons, click-to-open navigation
- Key Space View — Defined, undefined, and unused keys with usage locations and key scope support
- Diagnostics View — Aggregated DITA issues, group by file or severity, click-to-navigate
- Root Map Selector — Status bar indicator with click-to-set, auto-discover or explicit mode
- File decorations — Error/warning badges on tree items from validation diagnostics
- Welcome content — Helpful actions shown when views are empty
- Auto-refresh on file and diagnostics changes with debouncing
🗺️ Map Visualizer
- Interactive tree view - Visual hierarchy of DITA maps, bookmaps, and topics
- Element type icons - Different icons for maps, chapters, appendices, parts, topics, keys, and glossrefs
- Missing file detection - Missing referenced files shown with strikethrough styling
- Circular reference protection - Detects and marks circular map references
- Double-click navigation - Open any topic or map directly from the visualizer
- Expand/Collapse controls - Easily navigate large map hierarchies
- Real-time refresh - Update the visualization when map content changes
🎯 Quick File Creation
- Create DITA topics from templates (concept, task, reference)
- Generate DITA maps and bookmaps with proper structure
- Pre-filled DOCTYPE declarations and valid XML structure
⚙️ Flexible Configuration
- Configure DITA-OT installation path
- Customize output formats and directories
- Add custom DITA-OT arguments and filters
- Choose validation engine (xmllint or built-in)
Installation
From VS Code Marketplace
- Open VS Code
- Press
Ctrl+P/Cmd+P - Type
ext install ditacraft - Press Enter
From VSIX
- Download the latest
.vsixfile from Releases - Open VS Code
- Go to Extensions (
Ctrl+Shift+X/Cmd+Shift+X) - Click
...menu → "Install from VSIX..." - Select the downloaded file
Local Installation for Development
If you want to install the plugin locally from source code for development or testing:
Step 1: Prerequisites
Ensure you have the following installed:
- Node.js 18.x or 20.x (Download)
- npm (comes with Node.js)
- VS Code 1.80 or higher
- Git (optional, for cloning)
Step 2: Get the Source Code
# Clone the repository (or download ZIP from GitHub)
git clone https://github.com/jyjeanne/ditacraft.git
cd ditacraft
# OR if you downloaded as ZIP:
# Extract the ZIP file and navigate to the extracted folder
cd DitaCraft
Step 3: Install Dependencies
npm install
This will install all required npm packages (~429 packages).
Step 4: Compile TypeScript
npm run compile
This compiles the TypeScript source code to JavaScript in the out/ directory.
Step 5: Package the Extension
npm run package
This creates a .vsix file in the project root (e.g., ditacraft-0.1.0.vsix).
Note: If you don't have vsce installed, install it first:
npm install -g @vscode/vsce
Step 6: Install in VS Code
Option A: Install from VSIX
- Open VS Code
- Press
Ctrl+Shift+X(orCmd+Shift+Xon macOS) to open Extensions - Click the
...menu at the top right - Select "Install from VSIX..."
- Navigate to your project folder
- Select the
ditacraft-0.1.0.vsixfile - Click "Install"
- Reload VS Code when prompted
Option B: Run in Development Mode (Recommended for testing)
- Open the
ditacraftfolder in VS Code - Press
F5(or Run → Start Debugging) - A new VS Code window opens with the extension loaded
- Test the extension in this window
- Make changes to code, save, and press
Ctrl+Rin the Extension Host window to reload
Step 7: Verify Installation
- Open Command Palette (
Ctrl+Shift+P/Cmd+Shift+P) - Type "DITA" - you should see all DitaCraft commands
- Try creating a new topic: "DITA: Create New Topic"
Step 8: Configure DITA-OT (Optional, for publishing)
- Download DITA-OT from https://www.dita-ot.org/download
- Extract to a location (e.g.,
C:\DITA-OT-4.2.1) - In VS Code, run "DITA: Configure DITA-OT Path"
- Select your DITA-OT installation directory
Troubleshooting Local Installation
Issue: npm install fails
Solution:
- Check Node.js version:
node --version(should be 18.x or 20.x) - Clear npm cache:
npm cache clean --force - Delete
node_modulesandpackage-lock.json, then runnpm installagain
Issue: Compilation errors
Solution:
- Ensure TypeScript is installed:
npm install -g typescript - Check for syntax errors in
.tsfiles - Run
npm run lintto check for code issues
Issue: Extension not appearing in VS Code
Solution:
- Verify the
.vsixfile was created successfully - Check VS Code version is 1.80 or higher
- Try uninstalling any existing version first
- Restart VS Code completely
Issue: "Cannot find module" errors
Solution:
- Run
npm installagain - Check that
node_modulesdirectory exists - Verify
package.jsonhas all dependencies
Development Workflow
For active development on the extension:
# Terminal 1: Watch mode (auto-compile on changes)
npm run watch
# Terminal 2: Run extension in debug mode
# Press F5 in VS Code (or Run → Start Debugging)
Making Changes:
- Edit TypeScript files in
src/ - Watch mode auto-compiles to
out/ - In Extension Host window, press
Ctrl+R(orCmd+R) to reload - Test your changes
Running Tests:
npm test
Linting Code:
npm run lint
Prerequisites
Required
- VS Code 1.80 or higher
- Node.js 18.x or 20.x (for development)
For Publishing
- DITA-OT 4.2.1 or higher (Download)
For Alternative Validation (Optional)
- xmllint (libxml2) for external XML validation (TypesXML is the default and recommended engine)
Quick Start
1. Install DITA-OT
Download and install DITA-OT from https://www.dita-ot.org/download
2. Configure DitaCraft
- Open Command Palette (
Ctrl+Shift+P/Cmd+Shift+P) - Type "DITA: Configure DITA-OT Path"
- Select your DITA-OT installation directory
3. Create Your First DITA File
- Open Command Palette
- Type "DITA: Create New Topic"
- Select topic type (concept, task, reference)
- Enter file name
4. Publish
- Open your
.dita,.ditamap, or.bookmapfile - Press
Ctrl+Shift+B/Cmd+Shift+B - Select output format (HTML5, PDF, etc.)
- View published content
Commands
All commands are accessible via Command Palette (Ctrl+Shift+P / Cmd+Shift+P):
| Command | Shortcut | Description |
|---|---|---|
| DITA: Validate Current File | Ctrl+Shift+V |
Validate DITA syntax and structure |
| DITA: Publish (Select Format) | Ctrl+Shift+B |
Publish with format selection |
| DITA: Publish to HTML5 | - | Quick publish to HTML5 |
| DITA: Preview HTML5 | Ctrl+Shift+H |
Show live HTML5 preview |
| DITA: Show Map Visualizer | - | Show interactive map hierarchy |
| DITA: Create New Topic | - | Create new DITA topic |
| DITA: Create New Map | - | Create new DITA map |
| DITA: Create New Bookmap | - | Create new bookmap |
| DITA: Configure DITA-OT Path | - | Set DITA-OT installation path |
| DITA: Set Root Map | - | Choose explicit root map for key resolution |
| DITA: Clear Root Map | - | Revert to automatic root map discovery |
| DITA: Validate Workspace | - | Validate all DITA files across workspace |
| DITA: Validate Entire Guide | - | Full DITA-OT validation of root map with report panel |
| DITA: Configure AI Settings | - | Configure AI provider, API keys, and feature toggles |
| DITA: Restructure Map with AI | F2 |
AI-driven map restructuring with diff review |
| DITA: Setup cSpell Configuration (deprecated) | - | Create a lean cSpell config for DITA files |
Spell Checking with cSpell
DitaCraft provides a lean .cspellrc.json template that works alongside the LSP server. Rather than maintaining a large DITA word list (which is now handled by the LSP), the configuration uses regex-based patterns to silently ignore XML tags and attribute syntax, so cSpell focuses exclusively on prose spelling errors in your content.
What the config does
The generated .cspellrc.json:
- Suppresses XML tag noise — ignores
<element-name>andattr="value"patterns inside DITA files viaignoreRegExpList, so cSpell doesn't flag DITA markup as misspelled words - Leaves prose spell-checking intact — actual text content in
<p>,<title>,<shortdesc>, etc. is still checked - Includes a TypeScript word allowlist — common DITA/LSP terms (
dita,keyref,conref,oasis,vscode, etc.) allowed in.tssource files - Ignores generated/binary paths —
node_modules,out,dist,.git,*.ditavalexcluded
Note: The
DITA: Setup cSpell Configurationcommand is deprecated. The DITA Language Server now handles DITA vocabulary validation; cSpell is only needed for prose spell-checking.
Setup cSpell
Option 1: Run the command (still works, now creates the lean config)
- Open Command Palette (
Ctrl+Shift+P/Cmd+Shift+P) - Type "DITA: Setup cSpell Configuration"
- Click the command — DitaCraft creates a
.cspellrc.jsonin your workspace root
Option 2: Manual setup
Create .cspellrc.json at your workspace root:
{
"version": "0.2",
"language": "en",
"ignorePaths": ["node_modules", "out", "dist", ".git", ".vscode-test", "*.ditaval"],
"overrides": [
{
"filename": "**/*.{dita,ditamap,bookmap,xml}",
"ignoreRegExpList": ["<[^>]+>", "\\s[a-zA-Z-]+=(\"[^\"]*\"|'[^']*')"]
},
{
"filename": "src/**/*.ts",
"words": ["dita","dtd","conref","keyref","topicref","ditamap","xml","xpath","oasis","vscode","textmate"]
}
]
}
Configuration
Basic Settings
{
"ditacraft.ditaOtPath": "C:\\DITA-OT-4.2.1",
"ditacraft.defaultTranstype": "html5",
"ditacraft.outputDirectory": "${workspaceFolder}/out"
}
All Settings
| Setting | Type | Default | Description |
|---|---|---|---|
ditacraft.ditaOtPath |
string | "" |
DITA-OT installation path |
ditacraft.defaultTranstype |
string | "html5" |
Default output format |
ditacraft.outputDirectory |
string | "${workspaceFolder}/out" |
Output directory |
ditacraft.autoValidate |
boolean | true |
Auto-validate on save |
ditacraft.previewAutoRefresh |
boolean | true |
Auto-refresh preview |
ditacraft.previewScrollSync |
boolean | true |
Bidirectional scroll sync |
ditacraft.previewTheme |
string | "auto" |
Preview theme (auto/light/dark) |
ditacraft.previewCustomCss |
string | "" |
Custom CSS for preview |
ditacraft.showProgressNotifications |
boolean | true |
Show progress notifications |
ditacraft.validationEngine |
string | "built-in" |
Validation engine (built-in/typesxml/xmllint) |
ditacraft.ditaOtArgs |
array | [] |
Custom DITA-OT arguments |
ditacraft.enableSnippets |
boolean | true |
Enable code snippets |
ditacraft.maxNumberOfProblems |
number | 100 |
Maximum diagnostics per file |
ditacraft.ditaRulesEnabled |
boolean | true |
Enable Schematron-equivalent DITA rules |
ditacraft.ditaRulesCategories |
string[] | all | Rule categories to activate (mandatory, recommendation, authoring, accessibility) |
ditacraft.crossRefValidationEnabled |
boolean | true |
Validate cross-file references (href, conref, keyref) |
ditacraft.subjectSchemeValidationEnabled |
boolean | true |
Validate attribute values against subject schemes |
ditacraft.rootMap |
string | "" |
Explicit root map path (relative to workspace). Empty = auto-discover |
ditacraft.xmlCatalogPath |
string | "" |
Path to external XML catalog for custom DTD specializations |
ditacraft.validationSeverityOverrides |
object | {} |
Per-rule severity overrides (e.g., {"DITA-SCH-001": "hint", "DITA-ID-002": "off"}) |
ditacraft.largeFileThresholdKB |
number | 500 |
Skip heavy validation phases for files larger than this (0 = disabled) |
ditacraft.customRulesFile |
string | "" |
Absolute path to a JSON file defining custom regex validation rules |
📖 See the All Settings reference table above for the full list of configuration options.
AI Provider Configuration
DitaCraft supports four LLM backends with automatic fallback. This section shows how to set up each one.
Provider Overview
| Provider | Requires | Privacy | Best For |
|---|---|---|---|
| GitHub Copilot | Active Copilot subscription | Data sent to GitHub | Default — zero config |
| Anthropic Claude | ANTHROPIC_API_KEY (BYOK) |
Data sent to Anthropic | Best reasoning quality |
| OpenAI (ChatGPT / GPT-4o) | OPENAI_API_KEY (BYOK) |
Data sent to OpenAI | Broad compatibility |
| Ollama (local) | Ollama running on your machine | Stays local | Air-gapped / privacy-first |
The active mode is set with ditacraft.ai.mode:
{
"ditacraft.ai.mode": "auto"
}
| Value | Behaviour |
|---|---|
"auto" |
Copilot first, then Anthropic, then OpenAI, then Ollama |
"copilot-only" |
Only GitHub Copilot (error if no Copilot subscription) |
"byok-only" |
Only Anthropic / OpenAI (skips Copilot entirely) |
"local-only" |
Only Ollama — no data leaves your machine |
🤖 GitHub Copilot (Default — No Setup Required)
DitaCraft uses the built-in vscode.lm API; no npm package or API key needed.
Requirements:
- GitHub Copilot extension installed and signed in
- Active Copilot Individual, Business, or Enterprise subscription
Steps:
- Install the GitHub Copilot extension
- Sign in with your GitHub account
- DitaCraft auto-detects Copilot and uses it immediately — nothing else to configure
Optional override (to use a specific Copilot model):
{
"ditacraft.ai.mode": "copilot-only"
}
🧠 Anthropic Claude (BYOK)
Claude is the highest-quality model available for structured content tasks like DITA map restructuring.
Supported models: claude-3-5-sonnet-20241022 (default), claude-3-opus-20240229, claude-3-haiku-20240307
Steps:
- Get an API key from console.anthropic.com
- Open the Command Palette and run DitaCraft: Configure AI Settings
- In the panel, paste your key into the Anthropic field and click Save Key
- The key is stored in your OS keychain via
vscode.SecretStorage— never insettings.json - Optionally choose your model:
{
"ditacraft.ai.mode": "byok-only",
"ditacraft.ai.provider.anthropic.model": "claude-3-5-sonnet-20241022"
}
Key format: Anthropic API keys start with
sk-ant-. Keys not matching this prefix are rejected before any network call.
💬 OpenAI / ChatGPT (BYOK)
Supports GPT-4o (default), GPT-4 Turbo, and other OpenAI Chat Completions models.
Supported models: gpt-4o (default), gpt-4-turbo, gpt-4, gpt-3.5-turbo
Steps:
- Get an API key from platform.openai.com
- Run DitaCraft: Configure AI Settings from the Command Palette
- Paste your key into the OpenAI field and click Save Key
- Optionally set the model:
{
"ditacraft.ai.mode": "byok-only",
"ditacraft.ai.provider.openai.model": "gpt-4o"
}
OpenAI-compatible APIs (LM Studio, Jan, etc.): These are not yet supported natively, but you can expose them via Ollama's OpenAI-compatible proxy endpoint in the meantime.
🏠 Local LLM with Ollama (Air-Gapped / Privacy Mode)
Ollama lets you run open-source models entirely on your machine — no data ever leaves your computer.
Install Ollama: ollama.ai
Recommended DITA-capable models:
| Model | Command | Context | Notes |
|---|---|---|---|
llama3 |
ollama pull llama3 |
8 k | Default; good general quality |
llama3.1 |
ollama pull llama3.1 |
128 k | Large context — better for big maps |
mistral |
ollama pull mistral |
8 k | Fast, lighter footprint |
codellama |
ollama pull codellama |
16 k | Good for XML/structured content |
gemma3 |
ollama pull gemma3 |
8 k | Google Gemma 3 (open weights) |
phi3 |
ollama pull phi3 |
8 k | Microsoft Phi-3; compact and fast |
Steps:
- Install and start Ollama:
ollama serve - Pull your preferred model:
ollama pull llama3 - Configure DitaCraft:
{
"ditacraft.ai.mode": "local-only",
"ditacraft.ai.provider.ollama.enabled": true,
"ditacraft.ai.provider.ollama.baseUrl": "http://localhost:11434",
"ditacraft.ai.provider.ollama.model": "llama3"
}
- Run DitaCraft: Configure AI Settings and click Test Connection to verify Ollama is reachable
Custom Ollama endpoint (remote server / Docker):
{
"ditacraft.ai.provider.ollama.baseUrl": "http://my-gpu-server:11434"
}
Gemini via Ollama: Google does not publish full Gemini weights, but you can run
gemma3(Google's open-weights model) locally viaollama pull gemma3. For cloud Gemini (Gemini 1.5 Pro etc.), native support is planned in a future release.
☁️ Gemini (Google) — Planned
Native Google Gemini support (gemini-1.5-pro, gemini-1.5-flash) is planned for a future release via the Google Generative AI SDK.
Workarounds available today:
- Local Gemma — run Google's open-weights model via Ollama:
ollama pull gemma3 - OpenAI-compatible proxy — expose Gemini through a proxy that implements the OpenAI Chat Completions API
Track progress: see the Roadmap section.
⚙️ Full AI Settings Reference
{
"ditacraft.ai.enabled": true,
"ditacraft.ai.mode": "auto",
"ditacraft.ai.provider.anthropic.model": "claude-3-5-sonnet-20241022",
"ditacraft.ai.provider.openai.model": "gpt-4o",
"ditacraft.ai.provider.ollama.enabled": true,
"ditacraft.ai.provider.ollama.baseUrl": "http://localhost:11434",
"ditacraft.ai.provider.ollama.model": "llama3",
"ditacraft.ai.context.maxTokens": 8000,
"ditacraft.ai.quickfix.enabled": true,
"ditacraft.ai.completion.enabled": true,
"ditacraft.ai.streaming.enabled": true
}
MCP Server Integration (External AI Agents)
DitaCraft exposes its DITA intelligence — validation, key space, context snapshots — over the Model Context Protocol (MCP), letting external AI coding agents read and query your DITA workspace.
Status: MCP server is available in v0.8.0 (current). Build with
npm run build-standaloneto producedist/mcp-server.jsanddist/lsp-server.js.
What is MCP?
Model Context Protocol is an open standard (by Anthropic) that lets AI agents call tools and read resources from external servers. Compatible agents include opencode, Claude Desktop, Continue, Cursor, and any MCP-aware tool.
DitaCraft MCP Server
Run npm run build-standalone then configure your agent:
| Tool | Description |
|---|---|
dita_validate |
Validate a DITA file or XML fragment and return diagnostics |
dita_context_snapshot |
Token-budgeted map snapshot for LLM injection (L1/L2/L3) |
dita_key_space |
List all defined keys and their resolved targets |
dita_map_structure |
Return the full topic hierarchy (JSON/tree/CSV) |
dita_resolve_reference |
Resolve an href/keyref/conref/conkeyref to its target |
dita_explain_key |
Detailed step-by-step key resolution trace |
| Resource | Description |
|---|---|
dita://workspace/maps |
All DITA maps in the workspace |
dita://workspace/diagnostics |
Current validation diagnostics |
dita://workspace/keys |
Full key space |
Using DitaCraft with opencode
// ~/.config/opencode/opencode.json
{
"mcpServers": {
"ditacraft": {
"command": "node",
"args": ["/path/to/ditacraft/dist/mcp-server.js"],
"env": {
"WORKSPACE": "/home/user/projects/my-dita-docs"
}
}
}
}
> @ditacraft validate topics/intro.dita
> @ditacraft show me the map structure as a tree
> @ditacraft explain why keyref install-guide isn't resolving
Using DitaCraft with Claude Desktop
// macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
// Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"ditacraft": {
"command": "node",
"args": ["/absolute/path/to/dist/mcp-server.js"],
"env": { "WORKSPACE": "/path/to/dita/project" }
}
}
}
Standalone LSP Server
DitaCraft also ships a standalone LSP server bundle for embedding in other Node.js projects:
npm run build-standalone
# → dist/lsp-server.js (2.0 MB) — self-contained, no node_modules needed
# Launch as headless LSP server:
node dist/lsp-server.js --stdio
Embed in any Node.js LSP client via child_process.spawn:
const { spawn } = require('child_process');
const server = spawn('node', ['lsp-server.js', '--stdio'], {
env: { DITACRAFT_EXTENSION_ROOT: __dirname },
});
// Communicate via server.stdin / server.stdout using vscode-languageserver
Supported Output Formats
DitaCraft supports all DITA-OT transtypes:
- HTML5 - Modern responsive HTML
- PDF - PDF via Apache FOP
- XHTML - XHTML output
- EPUB - EPUB3 e-books
- HTML Help - Windows CHM files
- Markdown - Markdown conversion
Additional formats available through DITA-OT plugins.
Workflows
Navigating Your Documentation Structure
- Open a
.ditamapor.bookmapfile - Ctrl+Click (Cmd+Click on Mac) on any
hrefattribute value in<topicref>elements - The referenced topic file opens in a new tab
- Navigate back and forth between map and topics seamlessly
Example:
<map>
<topicref href="introduction.dita"/> <!-- Ctrl+Click opens introduction.dita -->
<topicref href="chapters/ch1.dita"/> <!-- Works with relative paths -->
<topicref href="overview.dita#intro"/> <!-- Handles fragment IDs -->
</map>
Publishing a Book
- Create bookmap:
DITA: Create New Bookmap - Create chapters:
DITA: Create New Topic(multiple times) - Edit bookmap to reference chapters
- Use Ctrl+Click navigation to quickly jump between bookmap and chapter files
- Validate:
Ctrl+Shift+V - Publish:
Ctrl+Shift+B→ Select format - Open output folder
Previewing Changes
- Open
.ditafile - Make edits
- Press
Ctrl+Shift+Hto preview - Preview auto-refreshes on save
- Toggle between source and preview
Using Filters (DITAVAL)
{
"ditacraft.ditaOtArgs": [
"--filter=filters/product-a.ditaval"
]
}
Development
Building from Source
# Clone repository
git clone https://github.com/jyjeanne/ditacraft.git
cd ditacraft
# Install dependencies
npm install
# Compile TypeScript
npm run compile
# Run tests
npm test
# Package extension
npm run package
Project Structure
ditacraft/
├── src/ # Client-side extension code
│ ├── extension.ts # Entry point
│ ├── commands/ # Command handlers
│ ├── providers/ # Tree views, validation, link & decoration providers
│ ├── utils/ # Utilities (DITA-OT, key space, map parser, rate limiter)
│ └── test/ # Client test suites (683+ tests)
├── server/ # LSP Language Server (separate process)
│ ├── src/
│ │ ├── server.ts # Server entry point & capability registration
│ │ ├── serverHandlers.ts # Extracted LSP handler wiring & capabilities
│ │ ├── features/ # LSP feature handlers
│ │ │ ├── validation.ts # Diagnostics (XML, DITA structure, IDs)
│ │ │ ├── completion.ts # IntelliSense completions
│ │ │ ├── hover.ts # Hover documentation
│ │ │ ├── symbols.ts # Document & workspace symbols
│ │ │ ├── definition.ts # Go to definition
│ │ │ ├── references.ts # Find references
│ │ │ ├── rename.ts # Rename with reference updates
│ │ │ ├── formatting.ts # XML formatting
│ │ │ ├── codeActions.ts # Quick fixes (12 actions)
│ │ │ ├── linkedEditing.ts # Tag name sync editing
│ │ │ ├── folding.ts # Folding ranges
│ │ │ ├── documentLinks.ts # Clickable links
│ │ │ ├── crossRefValidation.ts # Cross-file reference + scope validation
│ │ │ ├── circularRefDetection.ts # Circular reference detection (DFS)
│ │ │ ├── workspaceValidation.ts # Cross-file duplicate IDs, unused topics
│ │ │ ├── ditaRulesValidator.ts # 43 Schematron-equivalent DITA rules (incl. DITA 2.0)
│ │ │ ├── profilingValidation.ts # Subject scheme controlled values
│ │ │ └── customRulesValidator.ts # User-defined regex validation rules
│ │ ├── services/ # Domain services with caching
│ │ │ ├── validationPipeline.ts # 13-phase orchestration
│ │ │ ├── suppressionEngine.ts # Comment-based rule suppression
│ │ │ ├── interfaces.ts # Service interfaces (IKeySpaceService, etc.)
│ │ │ ├── catalogValidationService.ts # DTD validation (TypesXML)
│ │ │ ├── rngValidationService.ts # RNG validation (salve-annos)
│ │ │ ├── keySpaceService.ts # Key space resolution + caching
│ │ │ └── subjectSchemeService.ts # Subject scheme parsing
│ │ ├── utils/ # Server utilities
│ │ │ ├── types.ts # Shared types (DitaVersion, RuleCategory)
│ │ │ ├── diagnosticCodes.ts # Central diagnostic code registry (78 codes)
│ │ │ ├── textUtils.ts # Comment stripping, offsetToRange, offsetToPosition
│ │ │ ├── xmlTokenizer.ts # Error-tolerant state-machine tokenizer
│ │ │ ├── i18n.ts # Localization (80+ messages EN+FR)
│ │ │ └── ...
│ │ ├── messages/ # Localization bundles (en.json, fr.json — 80+ message keys)
│ │ └── data/ # DITA schema & specialization data (@class matching)
│ └── test/ # Server test suites (881+ tests)
├── mcp/ # Standalone MCP server (Model Context Protocol)
│ ├── src/
│ │ └── server.ts # MCP entry point (6 tools, 3 resources)
│ └── test/ # MCP test suites + smoke tests
├── dist/ # Standalone bundles (built by npm run build-standalone)
│ ├── mcp-server.js # Self-contained MCP server (3.2 MB)
│ └── lsp-server.js # Self-contained LSP server (2.0 MB)
├── dtds/ # DITA 1.2, 1.3, and 2.0 DTD files (master catalog)
├── docs/ # Documentation
│ ├── architecture.puml # Architecture diagram (PlantUML)
│ └── user-guide/ # DITA user guide (~80 files, bookmap structure)
├── ARCHITECTURE.md
├── DITA_LSP_ARCHITECTURE.md # LSP server architecture documentation
├── ROADMAP.md
├── TEST_PLAN.md # LSP feature test plan
└── CHANGELOG.md
Quality & Testing
DitaCraft includes comprehensive test coverage across client and server:
Client Tests (683+ tests):
- DTD validation, real-time validation, command & auto-detection
- Link navigation with key resolution, key space building & caching
- Security (path traversal, XXE protection), rate limiting
- Preview, file creation, configuration integration
- Activity bar views: DITA Explorer, Key Space, Diagnostics, file decorations
- Map hierarchy parser (25 tests)
LSP Server Tests (881+ tests):
- Reference parser (40 tests) - all 6 exported parsing functions
- XML tokenizer (26 tests) - state machine, error recovery, CRLF, context detection, Unicode/CJK
- XML formatting (25 tests) - indentation, inline, preformatted, edge cases, range formatting
- Folding ranges (10 tests) - elements, comments, CDATA, CRLF
- Workspace scanner (8 tests) - offset-to-position conversion
- Validation diagnostics (30 tests) - XML, DITA structure, IDs, maps, DITAVAL
- Completions (19 tests) - element, attribute, value, DITAVAL, subject scheme completions
- Hover (17 tests) - documentation, fallback, non-tag, DITAVAL, conref preview
- Document symbols (13 tests) - outline, titles, maps, self-closing
- Workspace symbols (8 tests) - cross-file search, in-memory preference
- Code actions (19 tests) - all 12 quick fixes + edge cases
- Linked editing (15 tests) - tag pairing, nesting, boundaries
- Cross-reference validation - href, conref, keyref target validation
- DITA rules validator - 43 Schematron-equivalent rules (5 categories incl. DITA 2.0) + 25 DITA 2.0 tests
- Custom rules validator - 23 tests (regex matching, fileTypes, caching, severity mapping, ReDoS protection)
- Profiling validation - subject scheme controlled value checks
- Validation pipeline - severity overrides, comment-based suppression, large file optimization, pipeline budget
- Subject scheme service - parsing, caching, hierarchy, value constraints
- DITA specialization - @class matching, topic/map type names, utility functions
- DITA version detector - version detection from content (1.0-2.0)
- Key space service - 100+ tests: keyref chains, keyscope nesting/inheritance/inline branches, provenance, scope explosion cap, explainKey reporting
- Server handlers - 31 wiring tests + 19 settings tests
- Edge cases - empty files, long lines, mixed CRLF, Unicode/CJK content
MCP Server Tests (standalone Mocha):
- Tool tests:
dita_validate,dita_context_snapshot,dita_key_space,dita_map_structure,dita_resolve_reference,dita_explain_key - Resource tests: all 3 workspace resources
- Security tests: path traversal rejection, workspace isolation
- Smoke test:
npx tsx mcp/test/smoke-test.ts(end-to-end tools + resources)
Running Tests:
# Run client tests (requires VS Code)
npm test
# Run server tests (standalone, no VS Code needed)
cd server && npm test
# Run a single server test suite
cd server && npm test -- --grep "KeySpaceService"
# Run MCP server tests (standalone, no VS Code needed)
cd mcp && npx tsc -p test/tsconfig.json && npx mocha out/test/mcp/test/*.test.js --ui tdd --timeout 30000
# MCP smoke test (validates tools + resources end-to-end)
npx tsx mcp/test/smoke-test.ts
# Compile everything
npm run compile
Known Limitations
Smart Navigation
The current implementation provides comprehensive navigation support. Remaining minor limitations:
Same-file Content References (
@conrefwith#) - e.g.,<ph conref="#v4.3/summary"/>- References starting with
#point to elements within the same file - Currently opens the file but doesn't scroll to the specific element
- References starting with
Conditional Key Definitions
- Keys with DITAVAL conditions may not be resolved correctly
- The key space builder uses the first definition found (no condition evaluation)
What works:
- ✅
href="path/to/file.dita"— Direct file paths with or without fragment identifiers - ✅
conref="file.dita#element_id"— Content references - ✅
keyref="key-name"— Key references with full key space resolution - ✅
conkeyref="key-name/element"— Content key references - ✅ Keyref chains (multi-hop) across nested key scopes
- ✅
@keyscopenesting, inheritance, inline scope branches (DITA 1.3 spec-compliant) - ✅ Scope explosion protection (50,000-key cap)
- ✅ Automatic root map discovery and tiered caching
Contributing
Contributions are welcome! Please:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Add tests for new features
- Ensure all tests pass (
npm test) - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Troubleshooting
DITA-OT Not Found
Problem: Extension shows "DITA-OT not found"
Solution:
- Verify DITA-OT is installed
- Run "DITA: Configure DITA-OT Path" command
- Select DITA-OT installation directory
- Verify with "DITA: Validate Current File"
Validation Errors
Problem: Validation shows unexpected errors
Solution:
- Check XML syntax (closing tags, quotes, etc.)
- Verify DOCTYPE declaration
- Try switching validation engine:
"ditacraft.validationEngine": "built-in"
Publishing Fails
Problem: Publishing fails with error
Solution:
- Check DITA-OT logs in Output panel
- Verify output directory is writable
- Check for syntax errors in DITA file
- Try publishing with
--verboseflag:"ditacraft.ditaOtArgs": ["--verbose"]
Smart Navigation Not Working
Problem: Ctrl+Click on href attributes doesn't open files
Solution:
- Verify you're in a
.ditamapor.bookmapfile (check file extension in status bar) - Hover over the href value - it should be underlined if detected as a link
- Make sure you're clicking on the href value itself (e.g.,
introduction.dita), not the attribute namehref= - Check that the referenced file path is correct and file exists
- Try reloading VS Code window (
Ctrl+R/Cmd+Rin VS Code) - Verify extension is activated (look for "DitaCraft" in Extensions)
Example of correct usage:
<topicref href="introduction.dita"/>
^^^^^^^^^^^^^^^^^^^^
Ctrl+Click here (on the value)
Preview Not Showing
Problem: Preview panel is blank or shows error
Solution:
- Verify HTML5 output was generated
- Check output directory exists
- Look for JavaScript errors in Developer Tools
- Try republishing:
Ctrl+Shift+B→ HTML5
Documentation
DitaCraft includes comprehensive documentation written in DITA format:
📖 User Guide (docs/user-guide/)
A complete DITA bookmap with ~80 files covering:
| Section | Contents |
|---|---|
| Part I: Getting Started | Introduction, Installation & Setup |
| Part II: Using DitaCraft | Commands (validation, publishing, file creation, navigation, guide validation), Features (smart navigation, validation, preview, map visualizer, key resolution) |
| Part III: Configuration | Settings (general, validation, publishing, preview) |
| Appendix | Keyboard Shortcuts reference |
| Backmatter | Glossary (40 terms), Index |
The user guide demonstrates DitaCraft's own capabilities - you can open it in VS Code to test validation, navigation, preview, and publishing features.
Resources
DITA Resources
VS Code Resources
Recent Updates
Version 0.8.0 (Current)
MCP Server, Standalone LSP Server & Standalone Bundles
MCP Server (mcp/):
- Standalone MCP server —
dist/mcp-server.js(3.2 MB, nonode_modulesneeded); exposes DitaCraft's DITA intelligence to any MCP-aware AI agent (opencode, Claude Desktop, Cursor, Continue) - 6 MCP tools —
dita_validate,dita_context_snapshot,dita_key_space,dita_map_structure,dita_resolve_reference,dita_explain_key - 3 MCP resources —
dita://workspace/maps,dita://workspace/diagnostics,dita://workspace/keys - Workspace isolation — Path traversal protection, HTTP/UNC/null-byte rejection; all communication stays local via stdio transport
- Smoke test —
npx tsx mcp/test/smoke-test.tsvalidates all tools and resources end-to-end
Standalone LSP Server (dist/lsp-server.js):
- Self-contained bundle (2.0 MB); no
node_modulesneeded at runtime - Launch via
node dist/lsp-server.js --stdio; embed viachild_process.spawnin any Node.js LSP client - Set
DITACRAFT_EXTENSION_ROOTto point to the directory containingdtds/
Build Commands:
npm run build-standalone— produces bothdist/mcp-server.jsanddist/lsp-server.jsnpm run package— produces the VS Code extension.vsixfile
Testing:
- MCP server tests:
cd mcp && npx tsc -p test/tsconfig.json && npx mocha out/test/mcp/test/*.test.js --ui tdd --timeout 30000 - LSP standalone smoke test:
npx tsx mcp/test/lsp-smoke-test.ts
1564+ Total Tests — Client (683) + Server (881)
Version 0.7.4
AI Integration — GitHub Copilot, Anthropic, OpenAI & Ollama
AI Infrastructure:
- LLMRouterService — Provider cascade with automatic fallback: Copilot (
vscode.lm) → Anthropic → OpenAI → Ollama;auto,copilot-only,byok-only,local-onlymodes - CircuitBreaker — Per-provider resilience: 3 failures in 5 min opens the breaker (10 min cooldown); AbortError (cancellations) never counted as failures
- MetricsCollector — Rolling buffer (1000 entries) tracking request count, latency, and error rate per provider
- SecretManager — API keys stored via
vscode.SecretStorage(OS keychain); no plaintext settings
AI Features:
- @ditacraft Chat Participant — 4 slash commands:
/restructure,/validate,/explain,/suggest-reuse - F2: AI Map Restructure — AI proposes restructured map hierarchy; diff view with user confirmation before writing
- F3: AI Quick Fix — Code Actions "Fix with AI" for 12 diagnostic codes (CM-001/002/003, XREF-001/003/004, STRUCT-003/004/005/008, DTD-001, XML-001)
- F4: AI Completion — AI-enriched IntelliSense for element content and attribute values
- Configure AI WebView — Guided setup for provider selection, API keys, feature toggles, and live metrics
LSP Additions:
dita/getContextGraph,dita/validateFragment,dita/buildContextSnapshot(Levels 1/2/3 sliding window)
1537+ Total Tests — Client (642) + Server (895)
Version 0.7.3
Key Space Algorithm Completion, Validation Pipeline Hardening, TypeScript 6.0 & TypesXML 2.0
Key Space (7-gap improvement plan complete):
- Keyref Chains — Multi-hop keyref resolution across scopes; chain scope prefix bug fixed so chains inside scoped peer maps resolve correctly
- Keyscope Inheritance & Inline Branches — PushDown scope inheritance and
@keyscopeon non-map topicrefs treated as anonymous scope branches per DITA 1.3 spec; three additional cascade/fallback/peer-map spec improvements - Provenance Tracking —
sourceLine(1-based) added toKeyDefinition; qualified scope aliases inherit source line from their origin definition - Scope Explosion Cap —
MAX_KEY_SPACE_ENTRIES(50,000) gates all 6 qualified-alias insertion sites;scopeExplosionWarningflag set onKeySpacewhen cap is hit - Resolution Reporting —
explainKey()returnsKeyResolutionReportwith full lookup trace and keyref chain steps;reportKeySpace()/formatResolutionReport()provide human-readable key-space summaries - Bug Fixes (4) — XMLParser is now a class-level singleton (was re-instantiated per call), topicmeta array guard for duplicate
<topicmeta>elements,?xmlPI pseudo-node skipping incollectXmlElements
Validation Pipeline:
- Pipeline Budget — Configurable
pipelineBudgetMs(default 30 s) with early-exit before each major phase; prevents runaway validation on large or complex files - ReDoS Protection — Custom regex rules screened for nested-quantifier patterns; 10,000-match iteration cap and 2 s timeout enforced per rule
- LSP 3.17 Conformance —
executeCommandProvider,serverInfo(name + version from package.json), andinterFileDependencies: trueadvertised inInitializeResult - Range Formatting Fix — Falls back to full-document replacement when structural reflow detected, preventing silent content loss
- DITA-OT Error Parsing — Severity-first log format (
[ERROR] [DOTJ013E]) now recognized alongside legacy[DOTJ013E][ERROR]format
Dependencies & Tooling:
- TypesXML 2.0.0 — Upgraded from 1.19.0
- TypeScript 6.0 — Upgraded from 5.9.3;
moduleResolution: nodewithignoreDeprecations: "6.0", explicittypeRootsin all tsconfig files
Earlier 0.7.3 changes:
- cSpell Simplification — Replaced 350-term DITA word list with two
ignoreRegExpListpatterns;DITA: Setup cSpell Configurationcommand deprecated - LSP Async File I/O — All sync
fscalls inhover.tsconverted tofs/promises;[object Promise]in hover output fixed - Security: DOCTYPE
]>Bypass Fix — Quote-aware regex prevents]>inside quoted entity values from terminating internal-subset scan early (billion-laughs / XXE bypass) - Security:
ENTITY_ANY_REHardening — Quote-aware alternation prevents early>termination insideSYSTEMidentifiers - 1537+ Total Tests — Client (683) + Server (881); key space service tests expanded from 7 to 100+
Version 0.7.2
Advanced Validation Controls, Custom Rules, Architecture Improvements
- Per-Rule Severity Override — New
ditacraft.validationSeverityOverridessetting lets you change any diagnostic code's severity (error, warning, information, hint) or suppress it entirely with"off" - Comment-Based Rule Suppression — Inline
<!-- ditacraft-disable CODE -->/<!-- ditacraft-enable CODE -->directives for range-based suppression;<!-- ditacraft-disable-file CODE -->for whole-file suppression - Custom Regex Rules — Define custom validation rules in a JSON file (
ditacraft.customRulesFile); supports regex patterns, fileType filtering, severity mapping, and mtime-based caching - Large File Optimization — Files exceeding
ditacraft.largeFileThresholdKB(default 500 KB) skip heavy validation phases (6–12) for performance; shows DITA-PERF-001 informational diagnostic - 3 New Quick Fixes — Sanitize invalid ID format (DITA-ID-002), insert missing
<booktitle>(DITA-STRUCT-006), insert missing<mainbooktitle>(DITA-STRUCT-007); total now 12 quick fixes - 43 DITA Rules — Rule count corrected from 35 to 43 (29 SCH + 4 ATTR + 4 TABLE + 6 additional authoring rules)
- DITA 2.0 Test Coverage — 25 new tests covering all 10 DITA 2.0 rules (SCH-050 through SCH-059) including self-closing audio/video elements
- Architecture Improvements — Extracted
SuppressionEnginefrom ValidationPipeline; centralizeddiagnosticCodes.tsregistry (78 codes); service interfaces (IKeySpaceService,ISubjectSchemeService,ICatalogValidationService); sharedtypes.tseliminates circular dependency; deduplicatedoffsetToPositioninto single canonical implementation; SubjectSchemeService cache bug fix; robustdeactivate()error handling - Bug Fixes — CRLF handling in comment suppression, exclusive endLine for suppression ranges, threshold boundary comparison, self-closing audio/video regex for SCH-054/055, SubjectSchemeService stale cache on scheme change
- 1375+ Total Tests — Client (678) + Server (697)
Version 0.7.1
ValidationPipeline, Guide Validation & Bug Fixes
- Validate Entire Guide — New
DITA: Validate Entire Guide Using DITA-OTcommand runs DITA-OT against root map; results displayed in WebView report with filtering (severity), search, grouping (by file/severity/module), and JSON export; enriched with 160+ DITA-OT error code descriptions - ValidationPipeline Extraction — Refactored validation handler into 10-phase orchestrator with per-phase error isolation
- Shared Utilities — Extracted textUtils.ts and patterns.ts, eliminating 15 duplicate function definitions
- Bug Fixes — Profiling validation positioning, code action single-quote IDs, completion startPos clamping, XML tokenizer CRLF, openFile error handling, parser regex for PDF/INDX/XEP codes
- 1242+ Total Tests — Client (683) + Server (559)
Version 0.7.0
Multi-Version DTD, Workspace Analysis, Glossref & Validation Fixes
- Multi-Version DTD Support — Bundled DITA 1.2, 1.3, and 2.0 DTDs with OASIS XML Catalog chaining;
ditacraft.xmlCatalogPathsetting for custom specializations - Scope Validation — Validates
scope="local|peer|external"consistency with href format (DITA-SCOPE-001/002/003) - Circular Reference Detection — DFS traversal detects structural map reference cycles; only follows topicref/mapref/chapter/etc. (not keydef/xref/link), excludes
.xmlfiles - Workspace Validation —
DITA: Validate Workspacecommand with progress, cross-file duplicate ID detection, and unused topic detection - Glossref Element — Full support across schema, autocompletion, explorer, map visualizer, content model, and hierarchy parser
- Glossentry/Troubleshooting Support — Recognized as valid topic root elements; glossentry validates
<glossterm>as first child (not<title>) - Bookmap in .ditamap — Bookmaps using
.ditamapextension no longer produce false root element errors - SCH-023 Fix — Section title rule now uses depth-tracking to count only direct-child titles (ignores titles in nested
<fig>,<div>, etc.) - SCH-040 Fix — Self-closing
<xref/>no longer triggers false nested-xref error - Bug Fixes — Bookmap title boundary checks, conditional mainbooktitle warning, single-quote ID handling, error ranges, completion position clamping, XML tokenizer CRLF, openFile command
- 652 Client Tests + 435 Server Tests — 1087+ total
Version 0.6.1
Localization, DITA 2.0 Rules, Root Map & Validation Enhancements
- Localization (i18n) — All 67 diagnostic messages translatable; English + French bundles included; auto-detects LSP locale
- DITA 2.0 Rules — 10 new version-specific rules (SCH-050 to SCH-059): removed elements (
<boolean>,<indextermref>,<object>, learning specializations), removed attributes (@print,@copy-to,@navtitle,@query),<audio>/<video>fallback accessibility checks - 43 Total DITA Rules — Expanded from 18 to 43 Schematron-equivalent rules across 5 categories (mandatory, recommendation, authoring, accessibility, DITA 2.0 removal); version-gated per DITA version
- Root Map Feature — Set/clear explicit root map via command palette or clickable status bar item; workspace-level
rootMapsetting; auto-discover mode by default - DITA Specialization —
@classattribute matching for specialization-aware element handling; pre-built matchers for 20+ element types - Catalog Validation Service — DTD validation with OASIS XML Catalog resolution and parser pool (3 concurrent instances)
- RNG Validation Service — Optional RelaxNG schema validation via salve-annos + saxes; grammar compilation with caching (max 20 schemas)
- Subject Scheme Enhancements — Hierarchy path display in completions, grouping by parent subject, default value preselection
- Conref Content Preview — Hover on
conref/conkeyrefshows inline preview of referenced content - Smart Debouncing — Tiered validation delays (300ms topics, 1000ms maps) with per-document cancellation
- Key Scope Support —
@keyscopeattribute handling with scope-qualified key resolution - New Logo — Updated extension icon
- Bug Fixes — Code action single-quote ID handling, DITA Explorer error handling, completion position clamping, XML tokenizer CRLF,
openFiledeclaration
Version 0.6.0
Project Management, Activity Bar Views & Advanced LSP
- Activity Bar Views — DITA Explorer, Key Space, and Diagnostics views in dedicated sidebar
- File Decorations — Error/warning badges on tree items from validation diagnostics
- Cross-Reference Validation — Validates href, conref, keyref, and conkeyref targets across files (6 diagnostic codes)
- DITA Rules Engine — Schematron-equivalent rules in 4 categories (mandatory, recommendation, authoring, accessibility)
- Profiling Validation — Subject scheme controlled value validation with automatic scheme discovery
- Subject Scheme Service — Parses subject scheme maps for controlled vocabularies with caching
- Error-Tolerant XML Tokenizer — State-machine tokenizer with error recovery for malformed XML
- DITA Version Detection — Auto-detects DITA version from
@DITAArchVersionor DOCTYPE - 4 New Code Actions — Add missing
otherrole, remove deprecated<indextermref>, convertaltattribute to element, add missing<alt>to<image> - 5 New Settings —
maxNumberOfProblems,ditaRulesEnabled,ditaRulesCategories,crossRefValidationEnabled,subjectSchemeValidationEnabled - LSP Architecture Documentation — Comprehensive
DITA_LSP_ARCHITECTURE.mddescribing server internals - 1040+ Total Tests — Client (620) + Server (419)
Version 0.5.0
DITA Language Server with IntelliSense
- ✅ Full LSP Implementation - 14 language features in a dedicated server process
- ✅ IntelliSense - Context-aware completion for elements, attributes, and values (364 DITA elements)
- ✅ DITAVAL Support - Full IntelliSense, validation, and hover docs for
.ditavalfiles - ✅ Hover Documentation - Element docs from DITA schema with children fallback
- ✅ Document & Workspace Symbols - Outline view and cross-file symbol search (Ctrl+T)
- ✅ Go to Definition - Navigate href/conref/keyref targets with full key space resolution
- ✅ Find References & Rename - Cross-file ID references and rename with updates
- ✅ Formatting - XML formatter with inline/block/preformatted element handling
- ✅ Code Actions - 5 quick fixes (DOCTYPE, ID, title, empty element, duplicate ID)
- ✅ Linked Editing - Simultaneous open/close tag name editing
- ✅ Folding & Document Links - Collapsible ranges and clickable references
- ✅ Key Space Resolution Fix - Improved root map discovery across nested directories
- ✅ cSpell Auto-Prompt - Suggests cSpell setup when extension detected without config
- ✅ Server Test Suite - 190 standalone Mocha tests (no VS Code dependency)
- ✅ 737+ Total Tests - Client (547) + Server (190) with CI integration
Version 0.4.2
Architecture, Security & Documentation
- ✅ Modular Validation Engine - Refactored validation with pluggable engine architecture
- ✅ Rate Limiting - DoS protection for validation operations (10 req/sec per file)
- ✅ Adaptive Cache Cleanup - Intelligent cache management that skips cleanup when empty
- ✅ Architecture Documentation - Comprehensive ARCHITECTURE.md with data flow diagrams
- ✅ DITA User Guide - Complete user documentation in DITA format (55 files with bookmap, glossary, index)
- ✅ Preview Scroll Sync Fix - Fixed scroll sync for content smaller than viewport
- ✅ Preview Print Mode Fix - Fixed toolbar injection for non-standard HTML structures
- ✅ 547+ Tests - Expanded test suite with security and edge case coverage
Version 0.4.1
TypesXML DTD Validation
- ✅ TypesXML DTD Validation - Pure TypeScript validation with 100% W3C conformance (no native dependencies)
- ✅ OASIS XML Catalog Support - Full DITA public identifier resolution via TypesXML
- ✅ Three Validation Engines - TypesXML (default), built-in, xmllint
Version 0.4.0
Enhanced Preview, Build Output & Map Visualizer
- ✅ DITA Map Visualizer - Interactive tree view showing map hierarchies with navigation
- ✅ Bidirectional Scroll Sync - Editor and preview scroll positions stay synchronized
- ✅ Print Preview Mode - Print-optimized view with dedicated print button
- ✅ Syntax-Highlighted Build Output - DITA-OT output with automatic colorization by log level
- ✅ Log Level Detection - Errors, warnings, info, debug messages auto-classified
- ✅ Build Timestamps - Build start and completion times displayed
- ✅ Circular Reference Detection - Map visualizer detects and warns about circular map references
- ✅ 490+ Tests - Comprehensive test suite with new feature coverage
Version 0.3.0
Developer Experience & Quality Milestone
- ✅ Code Coverage with c8 - Switched from nyc to c8 for VS Code extension-compatible coverage
- ✅ Coverage Threshold Enforcement - CI enforces minimum coverage (62% lines, 65% functions, 73% branches)
- ✅ CI Security Audit - Dedicated security audit job with weekly scheduled scans
- ✅ Cross-Platform CI - Tests run on Windows, macOS, and Linux
- ✅ Dynamic Configuration - Centralized ConfigurationManager with real-time change propagation
- ✅ Advanced Element Navigation - Same-file and cross-file element navigation with fragment support
- ✅ Configurable Settings - Validation debounce, key space TTL, DITA-OT timeout, max link matches
- ✅ Code Quality - Removed unused dependencies, consolidated file reading, standardized async patterns
Version 0.2.4
- ✅ Fixed DITA-OT HTML5 Publishing - Resolved Windows path case sensitivity issue
- ✅ Comprehensive Test Suite - 307+ tests including error handling tests
- ✅ Improved Error Handling - Added
fireAndForgetutility for safe async handling
Version 0.2.0
- ✅ Full Key Space Resolution - Navigate
@keyref,@conkeyref, and key-based references with automatic key space building - ✅ Enhanced Security - XXE neutralization, path traversal protection, and command injection prevention
- ✅ Performance Optimizations - Async file operations, intelligent caching (1-min TTL), and file watcher debouncing
- ✅ Content Reference Navigation - Ctrl+Click on
@conrefattributes to navigate to referenced content - ✅ Better UI Responsiveness - Async operations prevent UI blocking during file operations
Version 0.1.3 Fixes
- ✅ Fixed preview and publishing with paths containing spaces - File paths with spaces now work correctly
- ✅ Fixed DITA validation - Title element is now correctly validated as required per DTD spec
- ✅ Enhanced DTD validation - Added proper DTD validation support with xmllint
- ✅ Improved error messages - Better, more descriptive validation and publishing error messages
- ✅ Fixed file path validation - Comprehensive checks to ensure files are being processed
- ✅ Added verbose logging - Detailed console logging for easier debugging
Roadmap
We have an exciting roadmap planned for DitaCraft! See our detailed ROADMAP.md for:
- v0.3.0 - Developer Experience & Quality ✅ COMPLETE
- v0.4.0 - Enhanced Preview, Build Output & Map Visualizer ✅ COMPLETE
- v0.5.0 - IntelliSense & Content Assistance (LSP, DITAVAL, 737+ tests) ✅ COMPLETE
- v0.6.0 - Project Management, Views & Advanced LSP (1010+ tests) ✅ COMPLETE
- v0.7.0 - Advanced Validation (DITA 1.2/2.0 DTDs, workspace-level analysis) ✅ COMPLETE
- v0.7.1 - Guide Validation, ValidationPipeline & Bug Fixes (1242+ tests) ✅ COMPLETE
- v0.7.2 - Severity Overrides, Custom Rules, Architecture Improvements (1375+ tests) ✅ COMPLETE
- v0.7.3 - Key space algorithm completion (all 7 gaps), pipeline budget/ReDoS, TypeScript 6.0, TypesXML 2.0 (1564+ tests) ✅ COMPLETE
- v0.7.4 - AI Integration: Copilot, Anthropic, OpenAI, Ollama; @ditacraft chat participant, AI Quick Fix, AI Completion ✅ COMPLETE
- v0.8.0 - MCP Server (6 tools, 3 resources), Standalone LSP Server, standalone bundles ✅ CURRENT
- v0.9.0 - Publishing Enhancements (profiles, DITAVAL editor)
Contributing
We welcome contributions! Here's how you can help:
Good First Issues
Look for issues labeled good first issue - these are great starting points for new contributors.
Development Setup
git clone https://github.com/jyjeanne/ditacraft.git
cd ditacraft
npm install
npm run compile
# Press F5 in VS Code to run in debug mode
Areas Needing Help
| Area | Difficulty | Description |
|---|---|---|
| Test Coverage | Easy-Medium | Add tests for commands and providers |
| Documentation | Easy | Improve README, add tutorials |
| DITAVAL Editor | Medium | Visual condition editing |
See ROADMAP.md for detailed feature breakdown and contribution opportunities.
Changelog
See CHANGELOG.md for release history.
Third-Party Licenses & Attributions
DitaCraft includes third-party components with the following licenses:
OASIS DITA 1.3 Grammar Files
This extension bundles DITA 1.3 DTD files for validation purposes.
- Copyright: OASIS Open 2005, 2015. All rights reserved.
- Source: OASIS DITA Technical Committee
- License: OASIS IPR Policy (RF on Limited Terms)
These grammar files are included to enable DTD-based validation of DITA documents, as permitted under the OASIS IPR Policy for implementing the standard.
NPM Dependencies
| Package | License | Purpose |
|---|---|---|
typesxml |
EPL-1.0 | Full DTD validation with OASIS catalog support |
@xmldom/xmldom |
MIT | XML DOM parsing for fallback validation |
fast-xml-parser |
MIT | Fast XML validation and parsing |
For complete license texts, see THIRD-PARTY-NOTICES.md.
License
This project is licensed under the MIT License - see LICENSE file for details.
Support
- 🐛 Bug Reports: GitHub Issues
- 💡 Feature Requests: GitHub Issues
- 💬 Discussions: GitHub Discussions
- 📧 Email: [email protected]
Acknowledgments
- DITA Open Toolkit team for the excellent DITA-OT
- OASIS DITA Technical Committee
- VS Code extension development community
- All contributors and users
Made with ❤️ for technical writers and documentation teams
Reviews (0)
Sign in to leave a review.
Leave a reviewNo results found