@arborium/arborium 2.10.0 → 2.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/arborium.d.ts +1 -1
- package/dist/arborium.iife.js +2 -2
- package/dist/arborium.iife.js.map +1 -1
- package/dist/arborium.js +171 -185
- package/dist/arborium.js.map +1 -1
- package/dist/arborium_host.js +3 -3
- package/dist/arborium_host_bg.wasm +0 -0
- package/dist/loader.d.ts +0 -1
- package/dist/plugins-manifest.d.ts +1 -1
- package/dist/types.d.ts +80 -15
- package/dist/utils.d.ts +0 -14
- package/package.json +1 -1
- /package/dist/{loader.test.d.ts → highlight.test.d.ts} +0 -0
package/dist/arborium.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"arborium.js","sources":["../src/plugins-manifest.ts","../src/utils.ts","../src/loader.ts","../src/detect.ts"],"sourcesContent":["// AUTO-GENERATED by `cargo xtask gen-manifest` - DO NOT EDIT\n\nimport type { Highlight } from \"./types.js\"; \n\n/** Version of plugin packages (all @arborium/* packages share this version) */\nexport const pluginVersion = \"2.10.0\";\n\n/** All available languages */\nexport const availableLanguages: string[] = [\n \"ada\",\n \"agda\",\n \"asciidoc\",\n \"asm\",\n \"awk\",\n \"bash\",\n \"batch\",\n \"c\",\n \"c-sharp\",\n \"caddy\",\n \"capnp\",\n \"cedar\",\n \"cedarschema\",\n \"clojure\",\n \"cmake\",\n \"cobol\",\n \"commonlisp\",\n \"cpp\",\n \"css\",\n \"d\",\n \"dart\",\n \"devicetree\",\n \"diff\",\n \"dockerfile\",\n \"dot\",\n \"elisp\",\n \"elixir\",\n \"elm\",\n \"erlang\",\n \"fish\",\n \"fsharp\",\n \"gleam\",\n \"glsl\",\n \"go\",\n \"graphql\",\n \"groovy\",\n \"haskell\",\n \"hcl\",\n \"hlsl\",\n \"html\",\n \"idris\",\n \"ini\",\n \"java\",\n \"javascript\",\n \"jinja2\",\n \"jq\",\n \"json\",\n \"julia\",\n \"kotlin\",\n \"lean\",\n \"lua\",\n \"markdown\",\n \"matlab\",\n \"meson\",\n \"nginx\",\n \"ninja\",\n \"nix\",\n \"objc\",\n \"ocaml\",\n \"perl\",\n \"php\",\n \"postscript\",\n \"powershell\",\n \"prolog\",\n \"python\",\n \"query\",\n \"r\",\n \"rescript\",\n \"ron\",\n \"ruby\",\n \"rust\",\n \"scala\",\n \"scheme\",\n \"scss\",\n \"solidity\",\n \"sparql\",\n \"sql\",\n \"ssh-config\",\n \"starlark\",\n \"svelte\",\n \"swift\",\n \"textproto\",\n \"thrift\",\n \"tlaplus\",\n \"toml\",\n \"tsx\",\n \"typescript\",\n \"typst\",\n \"uiua\",\n \"vb\",\n \"verilog\",\n \"vhdl\",\n \"vim\",\n \"vue\",\n \"wit\",\n \"x86asm\",\n \"xml\",\n \"yaml\",\n \"yuri\",\n \"zig\",\n \"zsh\",\n];\n\n/** All possible highlights and their short tags */\nexport const highlights: Highlight[] = [\n {\n name: \"attribute\",\n tag: \"at\",\n },\n {\n name: \"constant\",\n tag: \"co\",\n },\n {\n name: \"constant.builtin\",\n tag: \"cb\",\n parentTag: \"constant\",\n },\n {\n name: \"constructor\",\n tag: \"cr\",\n },\n {\n name: \"function.builtin\",\n tag: \"fb\",\n parentTag: \"function\",\n },\n {\n name: \"function\",\n tag: \"f\",\n },\n {\n name: \"function.method\",\n tag: \"fm\",\n parentTag: \"function\",\n },\n {\n name: \"keyword\",\n tag: \"k\",\n },\n {\n name: \"keyword.conditional\",\n tag: \"kc\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.coroutine\",\n tag: \"ko\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.debug\",\n tag: \"kd\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.exception\",\n tag: \"ke\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.function\",\n tag: \"kf\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.import\",\n tag: \"ki\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.operator\",\n tag: \"kp\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.repeat\",\n tag: \"kr\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.return\",\n tag: \"kt\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.type\",\n tag: \"ky\",\n parentTag: \"keyword\",\n },\n {\n name: \"operator\",\n tag: \"o\",\n },\n {\n name: \"property\",\n tag: \"pr\",\n },\n {\n name: \"punctuation\",\n tag: \"p\",\n },\n {\n name: \"punctuation.bracket\",\n tag: \"pb\",\n parentTag: \"punctuation\",\n },\n {\n name: \"punctuation.delimiter\",\n tag: \"pd\",\n parentTag: \"punctuation\",\n },\n {\n name: \"punctuation.special\",\n tag: \"ps\",\n parentTag: \"punctuation\",\n },\n {\n name: \"string\",\n tag: \"s\",\n },\n {\n name: \"string.special\",\n tag: \"ss\",\n parentTag: \"string\",\n },\n {\n name: \"tag\",\n tag: \"tg\",\n },\n {\n name: \"tag.delimiter\",\n tag: \"td\",\n parentTag: \"tag\",\n },\n {\n name: \"tag.error\",\n tag: \"te\",\n parentTag: \"tag\",\n },\n {\n name: \"type\",\n tag: \"t\",\n },\n {\n name: \"type.builtin\",\n tag: \"tb\",\n parentTag: \"type\",\n },\n {\n name: \"type.qualifier\",\n tag: \"tq\",\n parentTag: \"type\",\n },\n {\n name: \"variable\",\n tag: \"v\",\n },\n {\n name: \"variable.builtin\",\n tag: \"vb\",\n parentTag: \"variable\",\n },\n {\n name: \"variable.parameter\",\n tag: \"vp\",\n parentTag: \"variable\",\n },\n {\n name: \"comment\",\n tag: \"c\",\n },\n {\n name: \"comment.documentation\",\n tag: \"cd\",\n parentTag: \"comment\",\n },\n {\n name: \"macro\",\n tag: \"m\",\n },\n {\n name: \"label\",\n tag: \"l\",\n },\n {\n name: \"diff.addition\",\n tag: \"da\",\n },\n {\n name: \"diff.deletion\",\n tag: \"dd\",\n },\n {\n name: \"number\",\n tag: \"n\",\n },\n {\n name: \"text.literal\",\n tag: \"tl\",\n },\n {\n name: \"text.emphasis\",\n tag: \"em\",\n },\n {\n name: \"text.strong\",\n tag: \"st\",\n },\n {\n name: \"text.uri\",\n tag: \"tu\",\n },\n {\n name: \"text.reference\",\n tag: \"tr\",\n },\n {\n name: \"string.escape\",\n tag: \"se\",\n parentTag: \"string\",\n },\n {\n name: \"text.title\",\n tag: \"tt\",\n },\n {\n name: \"text.strikethrough\",\n tag: \"tx\",\n },\n {\n name: \"spell\",\n tag: \"sp\",\n },\n {\n name: \"embedded\",\n tag: \"eb\",\n },\n {\n name: \"error\",\n tag: \"er\",\n },\n {\n name: \"namespace\",\n tag: \"ns\",\n },\n {\n name: \"include\",\n tag: \"in\",\n parentTag: \"keyword\",\n },\n {\n name: \"storageclass\",\n tag: \"sc\",\n parentTag: \"keyword\",\n },\n {\n name: \"repeat\",\n tag: \"rp\",\n parentTag: \"keyword\",\n },\n {\n name: \"conditional\",\n tag: \"cn\",\n parentTag: \"keyword\",\n },\n {\n name: \"exception\",\n tag: \"ex\",\n parentTag: \"keyword\",\n },\n {\n name: \"preproc\",\n tag: \"pp\",\n parentTag: \"keyword\",\n },\n {\n name: \"none\",\n tag: \"\",\n },\n {\n name: \"character\",\n tag: \"ch\",\n parentTag: \"string\",\n },\n {\n name: \"character.special\",\n tag: \"cs\",\n parentTag: \"string\",\n },\n {\n name: \"variable.member\",\n tag: \"vm\",\n parentTag: \"variable\",\n },\n {\n name: \"function.definition\",\n tag: \"fd\",\n parentTag: \"function\",\n },\n {\n name: \"type.definition\",\n tag: \"tf\",\n parentTag: \"type\",\n },\n {\n name: \"function.call\",\n tag: \"fc\",\n parentTag: \"function\",\n },\n {\n name: \"keyword.modifier\",\n tag: \"km\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.directive\",\n tag: \"dr\",\n parentTag: \"keyword\",\n },\n {\n name: \"string.regexp\",\n tag: \"rx\",\n parentTag: \"string\",\n },\n {\n name: \"nospell\",\n tag: \"\",\n },\n {\n name: \"float\",\n tag: \"n\",\n },\n {\n name: \"boolean\",\n tag: \"cb\",\n },\n];","import type { Span } from \"./types.js\";\n\n// Shared TextEncoder instance\nconst encoder = new TextEncoder();\n\n/**\n * Get the UTF-8 byte length of a string.\n */\nexport function utf8ByteLength(str: string): number {\n return encoder.encode(str).length;\n}\n\n/**\n * Convert a UTF-8 byte offset to a UTF-16 code unit index.\n *\n * This is needed because tree-sitter returns UTF-8 byte offsets,\n * but JavaScript's String methods use UTF-16 code unit indices.\n */\nexport function utf8OffsetToUtf16(source: string, utf8Offset: number): number {\n const utf8Bytes = encoder.encode(source);\n\n if (utf8Offset <= 0) return 0;\n if (utf8Offset >= utf8Bytes.length) return source.length;\n\n // Decode just the bytes up to the offset to get the UTF-16 length\n const decoder = new TextDecoder();\n const prefix = decoder.decode(utf8Bytes.slice(0, utf8Offset));\n return prefix.length;\n}\n\n/**\n * Build a mapping from UTF-8 byte offsets to UTF-16 code unit indices.\n *\n * More efficient than calling utf8OffsetToUtf16 repeatedly when you\n * have many offsets to convert for the same string.\n */\nfunction buildUtf8ToUtf16Map(source: string): Uint32Array {\n const utf8Bytes = encoder.encode(source);\n const map = new Uint32Array(utf8Bytes.length + 1);\n\n let utf8Offset = 0;\n let utf16Index = 0;\n\n for (const char of source) {\n // Record mapping at current UTF-8 position\n map[utf8Offset] = utf16Index;\n\n // Get UTF-8 byte length of this character\n const charUtf8Len = encoder.encode(char).length;\n\n // Fill intermediate bytes (they map to the same UTF-16 index)\n for (let i = 1; i < charUtf8Len; i++) {\n map[utf8Offset + i] = utf16Index;\n }\n\n utf8Offset += charUtf8Len;\n // Characters >= U+10000 are surrogate pairs (2 UTF-16 code units)\n utf16Index += char.codePointAt(0)! >= 0x10000 ? 2 : 1;\n }\n\n // Map the end-of-string position\n map[utf8Offset] = utf16Index;\n\n return map;\n}\n\n/** Convert spans to HTML */\nexport function spansToHtml(source: string, spans: Span[]): string {\n // Build UTF-8 to UTF-16 offset mapping\n const utf8ToUtf16 = buildUtf8ToUtf16Map(source);\n\n // Convert span offsets from UTF-8 bytes to UTF-16 code units\n const convertedSpans = spans.map(span => ({\n ...span,\n start: utf8ToUtf16[span.start] ?? span.start,\n end: utf8ToUtf16[span.end] ?? span.end,\n }));\n\n // Sort spans by start position\n const sorted = [...convertedSpans].sort((a, b) => a.start - b.start);\n\n let html = \"\";\n let pos = 0;\n\n for (const span of sorted) {\n // Skip overlapping spans\n if (span.start < pos) continue;\n\n // Add text before span\n if (span.start > pos) {\n html += escapeHtml(source.slice(pos, span.start));\n }\n\n // Get tag for capture\n const tag = getTagForCapture(span.capture);\n const text = escapeHtml(source.slice(span.start, span.end));\n\n if (tag) {\n html += `<a-${tag}>${text}</a-${tag}>`;\n } else {\n html += text;\n }\n\n pos = span.end;\n }\n\n // Add remaining text\n if (pos < source.length) {\n html += escapeHtml(source.slice(pos));\n }\n\n return html;\n}\n\n/** Get the short tag for a capture name */\nfunction getTagForCapture(capture: string): string | null {\n if (capture.startsWith(\"keyword\") || capture === \"include\" || capture === \"conditional\") {\n return \"k\";\n }\n if (capture.startsWith(\"function\") || capture.startsWith(\"method\")) {\n return \"f\";\n }\n if (capture.startsWith(\"string\") || capture === \"character\") {\n return \"s\";\n }\n if (capture.startsWith(\"comment\")) {\n return \"c\";\n }\n if (capture.startsWith(\"type\")) {\n return \"t\";\n }\n if (capture.startsWith(\"variable\")) {\n return \"v\";\n }\n if (capture.startsWith(\"number\") || capture === \"float\") {\n return \"n\";\n }\n if (capture.startsWith(\"operator\")) {\n return \"o\";\n }\n if (capture.startsWith(\"punctuation\")) {\n return \"p\";\n }\n if (capture.startsWith(\"tag\")) {\n return \"tg\";\n }\n if (capture.startsWith(\"attribute\")) {\n return \"at\";\n }\n return null;\n}\n\n/** Escape HTML special characters */\nexport function escapeHtml(text: string): string {\n return text\n .replace(/&/g, \"&\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .replace(/\"/g, \""\");\n}\n","/**\n * Arborium loader - loads grammar plugins and highlights code.\n *\n * Architecture:\n * 1. Grammar registry is bundled at build time (no network request needed in production)\n * - Can be overridden via pluginsUrl config for local development\n * 2. Load grammar wasm-bindgen modules on demand from @arborium/<lang> packages\n * 3. Parse and highlight using the grammar's tree-sitter parser\n */\n\nimport type { ParseResult, ArboriumConfig, Grammar, Session } from \"./types.js\";\nimport { availableLanguages, pluginVersion } from \"./plugins-manifest.js\";\nimport { spansToHtml, escapeHtml } from \"./utils.js\";\n\n// Re-export utilities\nexport { spansToHtml } from \"./utils.js\";\n\n// Default config\nexport const defaultConfig: Required<ArboriumConfig> = {\n manual: false,\n theme: \"one-dark\",\n selector: \"pre code\",\n cdn: \"jsdelivr\",\n version: pluginVersion, // Precise version from manifest\n pluginsUrl: \"\", // Empty means use bundled manifest\n hostUrl: \"\", // Empty means use CDN based on version\n resolveJs: ({ baseUrl, path }) => import(/* @vite-ignore */ `${baseUrl}/${path}`),\n resolveWasm: ({ baseUrl, path }) => fetch(`${baseUrl}/${path}`),\n};\n\n// Rust host module (loaded on demand)\ninterface HostModule {\n highlight: (language: string, source: string) => string;\n isLanguageAvailable: (language: string) => boolean;\n}\nlet hostModule: HostModule | null = null;\nlet hostLoadPromise: Promise<HostModule | null> | null = null;\n\n// Merged config\nlet globalConfig: Required<ArboriumConfig> = { ...defaultConfig };\n\n// Grammar plugins cache\nconst grammarCache = new Map<string, GrammarPlugin>();\n\n// In-flight grammar load promises (to prevent double-loading)\nconst grammarLoadPromises = new Map<string, Promise<GrammarPlugin | null>>();\n\n// Languages we know are available (bundled at build time)\nconst knownLanguages: Set<string> = new Set(availableLanguages);\n\n// For local development: can override with pluginsUrl to load from dev server\ninterface LocalManifest {\n entries: Array<{\n language: string;\n local_js: string;\n local_wasm: string;\n }>;\n}\nlet localManifest: LocalManifest | null = null;\nlet localManifestPromise: Promise<void> | null = null;\n\n/** Load local manifest if pluginsUrl is configured (for dev server) */\nasync function ensureLocalManifest(config: Required<ArboriumConfig>): Promise<void> {\n if (!config.pluginsUrl) {\n return;\n }\n\n if (localManifestPromise) {\n return localManifestPromise;\n }\n\n localManifestPromise = (async () => {\n console.debug(`[arborium] Loading local plugins manifest from: ${config.pluginsUrl}`);\n const response = await fetch(config.pluginsUrl);\n if (!response.ok) {\n throw new Error(`Failed to load plugins.json: ${response.status}`);\n }\n localManifest = await response.json();\n console.debug(`[arborium] Loaded local manifest with ${localManifest?.entries.length} entries`);\n })();\n\n return localManifestPromise;\n}\n\n/** Get the CDN base URL for a grammar */\nfunction getGrammarBaseUrl(language: string, config: Required<ArboriumConfig>): string {\n // If we have a local manifest (dev mode), use the local path\n if (localManifest) {\n const entry = localManifest.entries.find((e) => e.language === language);\n if (entry) {\n // Extract base URL from local_js path (e.g., \"/langs/group-hazel/python/npm/grammar.js\" -> \"/langs/group-hazel/python/npm\")\n return entry.local_js.substring(0, entry.local_js.lastIndexOf(\"/\"));\n }\n }\n\n // Production: derive from language name using precise version\n const cdn = config.cdn;\n const version = config.version;\n let baseUrl: string;\n if (cdn === \"jsdelivr\") {\n baseUrl = \"https://cdn.jsdelivr.net/npm\";\n } else if (cdn === \"unpkg\") {\n baseUrl = \"https://unpkg.com\";\n } else {\n baseUrl = cdn;\n }\n return `${baseUrl}/@arborium/${language}@${version}`;\n}\n\ntype MaybePromise<T> = Promise<T> | T;\n\n// See https://github.com/wasm-bindgen/wasm-bindgen/blob/dda4821ee2fbcaa7adc58bc8c385ed8d3627a272/crates/cli-support/src/js/mod.rs#L860\n/** Source of the WASM module for wasm-bindgen */\ntype WbgInitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module;\n\n/** wasm-bindgen plugin module interface */\ninterface WasmBindgenPlugin {\n default: (\n module_or_path?: { module_or_path: MaybePromise<WbgInitInput> } | undefined\n // deprecated: | MaybePromise<WbgInitInput>,\n ) => Promise<void>;\n language_id: () => string;\n injection_languages: () => string[];\n create_session: () => number;\n free_session: (session: number) => void;\n set_text: (session: number, text: string) => void;\n parse: (session: number) => ParseResult;\n cancel: (session: number) => void;\n}\n\n/** A loaded grammar plugin */\ninterface GrammarPlugin {\n languageId: string;\n injectionLanguages: string[];\n module: WasmBindgenPlugin;\n parse: (text: string) => ParseResult;\n}\n\n/** Load a grammar plugin */\nasync function loadGrammarPlugin(language: string, config: Required<ArboriumConfig>): Promise<GrammarPlugin | null> {\n // Check cache first\n const cached = grammarCache.get(language);\n if (cached) {\n console.debug(`[arborium] Grammar '${language}' found in cache`);\n return cached;\n }\n\n // Check if there's already an in-flight load for this language\n const inFlight = grammarLoadPromises.get(language);\n if (inFlight) {\n console.debug(`[arborium] Grammar '${language}' already loading, waiting...`);\n return inFlight;\n }\n\n // Start the actual load and track the promise\n const loadPromise = loadGrammarPluginInner(language, config);\n grammarLoadPromises.set(language, loadPromise);\n\n try {\n return await loadPromise;\n } finally {\n // Clean up the in-flight promise once done\n grammarLoadPromises.delete(language);\n }\n}\n\n/** Internal grammar loading - called only once per language */\nasync function loadGrammarPluginInner(language: string, config: Required<ArboriumConfig>): Promise<GrammarPlugin | null> {\n // Load local manifest if in dev mode\n await ensureLocalManifest(config);\n\n // Check if language is known\n if (\n !knownLanguages.has(language) &&\n !localManifest?.entries.some((e) => e.language === language)\n ) {\n console.debug(`[arborium] Grammar '${language}' not available`);\n return null;\n }\n\n try {\n const baseUrl = getGrammarBaseUrl(language, config);\n const detail = config.resolveJs === defaultConfig.resolveJs ? ` from ${baseUrl}/grammar.js` : \"\";\n console.debug(`[arborium] Loading grammar '${language}'${detail}`);\n\n const module = (await config.resolveJs({ language, baseUrl, path: \"grammar.js\" })) as WasmBindgenPlugin;\n const wasm = await config.resolveWasm({ language, baseUrl, path: \"grammar_bg.wasm\" });\n\n // Initialize the WASM module\n await module.default({ module_or_path: wasm });\n\n // Verify it loaded correctly\n const loadedId = module.language_id();\n if (loadedId !== language) {\n console.warn(`[arborium] Language ID mismatch: expected '${language}', got '${loadedId}'`);\n }\n\n // Get injection languages\n const injectionLanguages = module.injection_languages();\n\n // Wrap as GrammarPlugin with session-based parsing\n const plugin: GrammarPlugin = {\n languageId: language,\n injectionLanguages,\n module,\n parse: (text: string) => {\n const session = module.create_session();\n try {\n module.set_text(session, text);\n // wasm-bindgen returns ParseResult directly (or throws on error)\n const result = module.parse(session);\n return {\n spans: result.spans || [],\n injections: result.injections || [],\n };\n } catch (e) {\n console.error(`[arborium] Parse error:`, e);\n return { spans: [], injections: [] };\n } finally {\n module.free_session(session);\n }\n },\n };\n\n grammarCache.set(language, plugin);\n console.debug(`[arborium] Grammar '${language}' loaded successfully`);\n return plugin;\n } catch (e) {\n console.error(`[arborium] Failed to load grammar '${language}':`, e);\n return null;\n }\n}\n\n// Handle to plugin mapping for the host interface\nconst handleToPlugin = new Map<number, GrammarPlugin>();\nlet nextHandle = 1;\n\n/** Setup window.arboriumHost for the Rust host to call into */\nfunction setupHostInterface(config: Required<ArboriumConfig>): void {\n (window as any).arboriumHost = {\n /** Check if a language is available (sync) */\n isLanguageAvailable(language: string): boolean {\n return knownLanguages.has(language) || grammarCache.has(language);\n },\n\n /** Load a grammar and return a handle (async) */\n async loadGrammar(language: string): Promise<number> {\n const plugin = await loadGrammarPlugin(language, config);\n if (!plugin) return 0; // 0 = not found\n\n // Check if we already have a handle\n for (const [handle, p] of handleToPlugin) {\n if (p === plugin) return handle;\n }\n\n // Create new handle\n const handle = nextHandle++;\n handleToPlugin.set(handle, plugin);\n return handle;\n },\n\n /** Parse text using a grammar handle (sync) */\n parse(handle: number, text: string): ParseResult {\n const plugin = handleToPlugin.get(handle);\n if (!plugin) return { spans: [], injections: [] };\n return plugin.parse(text);\n },\n };\n}\n\n/** Get the host URL based on config */\nfunction getHostUrl(config: Required<ArboriumConfig>): string {\n if (config.hostUrl) {\n return config.hostUrl;\n }\n // Use CDN\n const cdn = config.cdn;\n const version = config.version;\n let baseUrl: string;\n if (cdn === \"jsdelivr\") {\n baseUrl = \"https://cdn.jsdelivr.net/npm\";\n } else if (cdn === \"unpkg\") {\n baseUrl = \"https://unpkg.com\";\n } else {\n baseUrl = cdn;\n }\n const versionSuffix = version === \"latest\" ? \"\" : `@${version}`;\n return `${baseUrl}/@arborium/arborium${versionSuffix}/dist`;\n}\n\n/** Load the Rust host module */\nasync function loadHost(config: Required<ArboriumConfig>): Promise<HostModule | null> {\n if (hostModule) return hostModule;\n if (hostLoadPromise) return hostLoadPromise;\n\n hostLoadPromise = (async () => {\n // Setup the interface the host imports\n setupHostInterface(config);\n\n const hostUrl = getHostUrl(config);\n const jsUrl = `${hostUrl}/arborium_host.js`;\n const wasmUrl = `${hostUrl}/arborium_host_bg.wasm`;\n\n console.debug(`[arborium] Loading host from ${jsUrl}`);\n try {\n const module = await import(/* @vite-ignore */ jsUrl);\n await module.default(wasmUrl);\n\n hostModule = {\n highlight: module.highlight,\n isLanguageAvailable: module.isLanguageAvailable,\n };\n console.debug(`[arborium] Host loaded successfully`);\n return hostModule;\n } catch (e) {\n console.error(\"[arborium] Failed to load host:\", e);\n return null;\n }\n })();\n\n return hostLoadPromise;\n}\n\n/** Highlight source code */\nexport async function highlight(\n language: string,\n source: string,\n configOverrides?: ArboriumConfig,\n): Promise<string> {\n const config = getConfig(configOverrides);\n // Try to use the Rust host (handles injections properly)\n const host = await loadHost(config);\n if (host) {\n try {\n return host.highlight(language, source);\n } catch (e) {\n console.warn(\"Host highlight failed, falling back to JS:\", e);\n }\n }\n\n // Fallback to JS-only highlighting (no injection support)\n const plugin = await loadGrammarPlugin(language, config);\n if (!plugin) {\n return escapeHtml(source);\n }\n\n const result = plugin.parse(source);\n return spansToHtml(source, result.spans);\n}\n\n/** Load a grammar for direct use */\nexport async function loadGrammar(\n language: string,\n configOverrides?: ArboriumConfig,\n): Promise<Grammar | null> {\n const config = getConfig(configOverrides);\n const plugin = await loadGrammarPlugin(language, config);\n if (!plugin) return null;\n\n const { module } = plugin;\n\n return {\n languageId: () => plugin.languageId,\n injectionLanguages: () => plugin.injectionLanguages,\n highlight: async (source: string) => {\n const result = plugin.parse(source);\n return spansToHtml(source, result.spans);\n },\n parse: (source: string) => plugin.parse(source),\n createSession: (): Session => {\n const handle = module.create_session();\n return {\n setText: (text: string) => module.set_text(handle, text),\n parse: () => {\n try {\n const result = module.parse(handle);\n return {\n spans: result.spans || [],\n injections: result.injections || [],\n };\n } catch (e) {\n console.error(`[arborium] Session parse error:`, e);\n return { spans: [], injections: [] };\n }\n },\n cancel: () => module.cancel(handle),\n free: () => module.free_session(handle),\n };\n },\n dispose: () => {\n // No-op for now, plugins are cached\n },\n };\n}\n\n/** Get current config, optionally merging with overrides */\nexport function getConfig(overrides?: Partial<ArboriumConfig>): Required<ArboriumConfig> {\n if (overrides) {\n return { ...globalConfig, ...overrides };\n }\n return { ...globalConfig };\n}\n\n/** Set/merge config */\nexport function setConfig(newConfig: Partial<ArboriumConfig>): void {\n globalConfig = { ...globalConfig, ...newConfig };\n}\n\n/** Check if a language is available */\nexport async function isLanguageAvailable(language: string, configOverrides?: ArboriumConfig): Promise<boolean> {\n const config = getConfig(configOverrides);\n await ensureLocalManifest(config);\n return (\n knownLanguages.has(language) ||\n (localManifest?.entries.some((e) => e.language === language) ?? false)\n );\n}\n\n/** Get list of available languages */\nexport async function getAvailableLanguages(configOverrides?: ArboriumConfig): Promise<string[]> {\n const config = getConfig(configOverrides);\n await ensureLocalManifest(config);\n // In dev mode, use local manifest if available\n if (localManifest) {\n return localManifest.entries.map((e) => e.language);\n }\n return Array.from(knownLanguages);\n}\n","/**\n * Simple language detection heuristics.\n * Not meant to be comprehensive - just catches common cases.\n */\n\n/** Shebang patterns */\nconst SHEBANG_PATTERNS: Array<[RegExp, string]> = [\n [/^#!.*\\bpython[23]?\\b/, 'python'],\n [/^#!.*\\bnode\\b/, 'javascript'],\n [/^#!.*\\bdeno\\b/, 'typescript'],\n [/^#!.*\\bbun\\b/, 'typescript'],\n [/^#!.*\\bruby\\b/, 'ruby'],\n [/^#!.*\\bperl\\b/, 'perl'],\n [/^#!.*\\bphp\\b/, 'php'],\n [/^#!.*\\bbash\\b/, 'bash'],\n [/^#!.*\\bzsh\\b/, 'zsh'],\n [/^#!.*\\bsh\\b/, 'bash'],\n [/^#!.*\\blua\\b/, 'lua'],\n [/^#!.*\\bawk\\b/, 'awk'],\n];\n\n/** Keyword fingerprints - first few unique keywords that identify a language */\nconst KEYWORD_FINGERPRINTS: Array<[RegExp, string]> = [\n // Rust - distinctive keywords\n [/\\b(fn|impl|trait|pub\\s+fn|let\\s+mut|&mut|->)\\b/, 'rust'],\n\n // Go - distinctive keywords\n [/\\b(func|package\\s+\\w+|import\\s+\\(|go\\s+func|chan\\s+\\w+)\\b/, 'go'],\n\n // Python - distinctive patterns\n [/\\b(def\\s+\\w+\\s*\\(|import\\s+\\w+|from\\s+\\w+\\s+import|class\\s+\\w+:)\\b/, 'python'],\n\n // TypeScript - distinctive type annotations\n [/:\\s*(string|number|boolean|void)\\b|\\binterface\\s+\\w+\\s*\\{/, 'typescript'],\n\n // JavaScript - distinctive patterns (after TS check)\n [/\\b(const|let|var)\\s+\\w+\\s*=|function\\s+\\w+\\s*\\(|=>\\s*\\{/, 'javascript'],\n\n // Ruby - distinctive keywords\n [/\\b(def\\s+\\w+|end\\b|do\\s*\\|.*\\||puts\\s+|require\\s+['\"])\\b/, 'ruby'],\n\n // Java - distinctive patterns\n [/\\b(public\\s+class|private\\s+\\w+|System\\.out\\.println)\\b/, 'java'],\n\n // C++ - distinctive patterns\n [/\\b(#include\\s*<|std::|template\\s*<|nullptr|cout\\s*<<)\\b/, 'cpp'],\n\n // C - distinctive patterns (after C++ check)\n [/\\b(#include\\s*[<\"]|printf\\s*\\(|int\\s+main\\s*\\(|void\\s+\\w+\\s*\\()\\b/, 'c'],\n\n // C# - distinctive patterns\n [/\\b(namespace\\s+\\w+|using\\s+System|public\\s+static\\s+void)\\b/, 'c-sharp'],\n\n // PHP - distinctive patterns\n [/<\\?php|\\$\\w+\\s*=/, 'php'],\n\n // Swift - distinctive patterns\n [/\\b(func\\s+\\w+|var\\s+\\w+:\\s*\\w+|let\\s+\\w+:\\s*\\w+|@objc)\\b/, 'swift'],\n\n // Kotlin - distinctive patterns\n [/\\b(fun\\s+\\w+|val\\s+\\w+|var\\s+\\w+:|data\\s+class)\\b/, 'kotlin'],\n\n // Scala - distinctive patterns\n [/\\b(def\\s+\\w+|val\\s+\\w+|var\\s+\\w+|object\\s+\\w+|case\\s+class)\\b/, 'scala'],\n\n // Haskell - distinctive patterns\n [/\\b(module\\s+\\w+|import\\s+qualified|data\\s+\\w+\\s*=|::\\s*\\w+\\s*->)\\b/, 'haskell'],\n\n // Elixir - distinctive patterns\n [/\\b(defmodule\\s+\\w+|def\\s+\\w+|defp\\s+\\w+|\\|>)\\b/, 'elixir'],\n\n // Lua - distinctive patterns\n [/\\b(local\\s+\\w+\\s*=|function\\s+\\w+\\.\\w+|require\\s*\\()\\b/, 'lua'],\n\n // SQL - distinctive patterns\n [/\\b(SELECT\\s+.*\\s+FROM|INSERT\\s+INTO|CREATE\\s+TABLE|ALTER\\s+TABLE)\\b/i, 'sql'],\n\n // Shell/Bash - distinctive patterns\n [/\\b(if\\s+\\[\\s*|then\\b|fi\\b|echo\\s+[\"']|export\\s+\\w+=)\\b/, 'bash'],\n\n // YAML - distinctive patterns\n [/^\\s*[\\w-]+:\\s*[\\w\\-\"'[{]|^---\\s*$/, 'yaml'],\n\n // JSON - distinctive patterns\n [/^\\s*\\{[\\s\\S]*\"[\\w-]+\":\\s*/, 'json'],\n\n // TOML - distinctive patterns\n [/^\\s*\\[[\\w.-]+\\]\\s*$|^\\s*\\w+\\s*=\\s*[\"'\\d\\[]/, 'toml'],\n\n // HTML - distinctive patterns\n [/<(!DOCTYPE|html|head|body|div|span|p|a\\s)/i, 'html'],\n\n // CSS - distinctive patterns\n [/^\\s*[\\w.#@][\\w\\s,#.:>+~-]*\\{[^}]*\\}|@media\\s|@import\\s/, 'css'],\n\n // Markdown - distinctive patterns\n [/^#{1,6}\\s+\\w|^\\s*[-*+]\\s+\\w|^\\s*\\d+\\.\\s+\\w|```\\w*\\n/, 'markdown'],\n\n // XML - distinctive patterns\n [/<\\?xml|<[\\w:-]+\\s+xmlns/, 'xml'],\n\n // Dockerfile\n [/^FROM\\s+\\w+|^RUN\\s+|^COPY\\s+|^ENTRYPOINT\\s+/m, 'dockerfile'],\n\n // Nginx config\n [/\\b(server\\s*\\{|location\\s+[\\/~]|proxy_pass\\s+)\\b/, 'nginx'],\n\n // Zig\n [/\\b(pub\\s+fn|const\\s+\\w+\\s*=|@import\\(|comptime)\\b/, 'zig'],\n];\n\n/**\n * Detect the language of a code snippet.\n * Returns null if detection fails.\n */\nexport function detectLanguage(source: string): string | null {\n // Check shebang first (most reliable)\n const firstLine = source.split('\\n')[0];\n for (const [pattern, language] of SHEBANG_PATTERNS) {\n if (pattern.test(firstLine)) {\n return language;\n }\n }\n\n // Check keyword fingerprints\n for (const [pattern, language] of KEYWORD_FINGERPRINTS) {\n if (pattern.test(source)) {\n return language;\n }\n }\n\n return null;\n}\n\n/**\n * Extract language from class name.\n * Supports multiple patterns:\n * - \"language-rust\" -> \"rust\" (standard)\n * - \"lang-rust\" -> \"rust\" (common alternative)\n * - \"rust\" -> \"rust\" (docs.rs style, bare language name)\n */\nexport function extractLanguageFromClass(className: string): string | null {\n // Try \"language-*\" pattern first (most specific)\n const langMatch = className.match(/\\blanguage-(\\w+)\\b/);\n if (langMatch) return langMatch[1];\n\n // Try \"lang-*\" pattern\n const shortMatch = className.match(/\\blang-(\\w+)\\b/);\n if (shortMatch) return shortMatch[1];\n\n // Try bare language names (for docs.rs compatibility)\n // Only match known language names to avoid false positives\n const knownLanguages = new Set([\n 'rust', 'javascript', 'typescript', 'python', 'ruby', 'go', 'java',\n 'c', 'cpp', 'csharp', 'php', 'swift', 'kotlin', 'scala', 'haskell',\n 'elixir', 'lua', 'sql', 'bash', 'shell', 'yaml', 'json', 'toml',\n 'html', 'css', 'xml', 'markdown', 'dockerfile', 'nginx', 'zig',\n 'text', 'plaintext', 'console', 'sh',\n ]);\n\n for (const cls of className.split(/\\s+/)) {\n if (knownLanguages.has(cls.toLowerCase())) {\n return cls.toLowerCase();\n }\n }\n\n return null;\n}\n\n/**\n * Normalize language identifier (handle aliases)\n */\nexport function normalizeLanguage(lang: string): string {\n const aliases: Record<string, string> = {\n js: 'javascript',\n ts: 'typescript',\n py: 'python',\n rb: 'ruby',\n rs: 'rust',\n sh: 'bash',\n shell: 'bash',\n yml: 'yaml',\n cs: 'c-sharp',\n csharp: 'c-sharp',\n 'c++': 'cpp',\n 'c#': 'c-sharp',\n 'f#': 'fsharp',\n dockerfile: 'dockerfile',\n docker: 'dockerfile',\n makefile: 'make',\n plaintext: 'text',\n plain: 'text',\n txt: 'text',\n };\n\n const lower = lang.toLowerCase();\n return aliases[lower] || lower;\n}\n"],"names":["pluginVersion","availableLanguages","highlights","encoder","buildUtf8ToUtf16Map","source","utf8Bytes","map","utf8Offset","utf16Index","char","charUtf8Len","spansToHtml","spans","utf8ToUtf16","sorted","span","a","b","html","pos","escapeHtml","tag","getTagForCapture","text","capture","defaultConfig","baseUrl","path","hostModule","hostLoadPromise","globalConfig","grammarCache","grammarLoadPromises","knownLanguages","localManifest","localManifestPromise","ensureLocalManifest","config","response","getGrammarBaseUrl","language","entry","e","cdn","version","loadGrammarPlugin","cached","inFlight","loadPromise","loadGrammarPluginInner","detail","module","wasm","loadedId","injectionLanguages","plugin","session","result","handleToPlugin","nextHandle","setupHostInterface","handle","p","getHostUrl","versionSuffix","loadHost","hostUrl","jsUrl","wasmUrl","highlight","configOverrides","getConfig","host","loadGrammar","overrides","setConfig","newConfig","SHEBANG_PATTERNS","KEYWORD_FINGERPRINTS","detectLanguage","firstLine","pattern","extractLanguageFromClass","className","langMatch","shortMatch","cls","normalizeLanguage","lang","aliases","lower"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"arborium.js","sources":["../src/plugins-manifest.ts","../src/utils.ts","../src/loader.ts","../src/detect.ts"],"sourcesContent":["// AUTO-GENERATED by `cargo xtask gen-manifest` - DO NOT EDIT\n\nimport type { Highlight } from \"./types.js\"; \n\n/** Version of plugin packages (all @arborium/* packages share this version) */\nexport const pluginVersion = \"2.11.0\";\n\n/** All available languages */\nexport const availableLanguages: string[] = [\n \"ada\",\n \"agda\",\n \"asciidoc\",\n \"asm\",\n \"awk\",\n \"bash\",\n \"batch\",\n \"c\",\n \"c-sharp\",\n \"caddy\",\n \"capnp\",\n \"cedar\",\n \"cedarschema\",\n \"clojure\",\n \"cmake\",\n \"cobol\",\n \"commonlisp\",\n \"cpp\",\n \"css\",\n \"d\",\n \"dart\",\n \"devicetree\",\n \"diff\",\n \"dockerfile\",\n \"dot\",\n \"elisp\",\n \"elixir\",\n \"elm\",\n \"erlang\",\n \"fish\",\n \"fsharp\",\n \"gleam\",\n \"glsl\",\n \"go\",\n \"graphql\",\n \"groovy\",\n \"haskell\",\n \"hcl\",\n \"hlsl\",\n \"html\",\n \"idris\",\n \"ini\",\n \"java\",\n \"javascript\",\n \"jinja2\",\n \"jq\",\n \"json\",\n \"julia\",\n \"kotlin\",\n \"lean\",\n \"lua\",\n \"markdown\",\n \"matlab\",\n \"meson\",\n \"nginx\",\n \"ninja\",\n \"nix\",\n \"objc\",\n \"ocaml\",\n \"perl\",\n \"php\",\n \"postscript\",\n \"powershell\",\n \"prolog\",\n \"python\",\n \"query\",\n \"r\",\n \"rescript\",\n \"ron\",\n \"ruby\",\n \"rust\",\n \"scala\",\n \"scheme\",\n \"scss\",\n \"solidity\",\n \"sparql\",\n \"sql\",\n \"ssh-config\",\n \"starlark\",\n \"styx\",\n \"svelte\",\n \"swift\",\n \"textproto\",\n \"thrift\",\n \"tlaplus\",\n \"toml\",\n \"tsx\",\n \"typescript\",\n \"typst\",\n \"uiua\",\n \"vb\",\n \"verilog\",\n \"vhdl\",\n \"vim\",\n \"vue\",\n \"wit\",\n \"x86asm\",\n \"xml\",\n \"yaml\",\n \"yuri\",\n \"zig\",\n \"zsh\",\n];\n\n/** All possible highlights and their short tags */\nexport const highlights: Highlight[] = [\n {\n name: \"attribute\",\n tag: \"at\",\n },\n {\n name: \"constant\",\n tag: \"co\",\n },\n {\n name: \"constant.builtin\",\n tag: \"cb\",\n parentTag: \"constant\",\n },\n {\n name: \"constructor\",\n tag: \"cr\",\n },\n {\n name: \"function.builtin\",\n tag: \"fb\",\n parentTag: \"function\",\n },\n {\n name: \"function\",\n tag: \"f\",\n },\n {\n name: \"function.method\",\n tag: \"fm\",\n parentTag: \"function\",\n },\n {\n name: \"keyword\",\n tag: \"k\",\n },\n {\n name: \"keyword.conditional\",\n tag: \"kc\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.coroutine\",\n tag: \"ko\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.debug\",\n tag: \"kd\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.exception\",\n tag: \"ke\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.function\",\n tag: \"kf\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.import\",\n tag: \"ki\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.operator\",\n tag: \"kp\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.repeat\",\n tag: \"kr\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.return\",\n tag: \"kt\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.type\",\n tag: \"ky\",\n parentTag: \"keyword\",\n },\n {\n name: \"operator\",\n tag: \"o\",\n },\n {\n name: \"property\",\n tag: \"pr\",\n },\n {\n name: \"punctuation\",\n tag: \"p\",\n },\n {\n name: \"punctuation.bracket\",\n tag: \"pb\",\n parentTag: \"punctuation\",\n },\n {\n name: \"punctuation.delimiter\",\n tag: \"pd\",\n parentTag: \"punctuation\",\n },\n {\n name: \"punctuation.special\",\n tag: \"ps\",\n parentTag: \"punctuation\",\n },\n {\n name: \"string\",\n tag: \"s\",\n },\n {\n name: \"string.special\",\n tag: \"ss\",\n parentTag: \"string\",\n },\n {\n name: \"tag\",\n tag: \"tg\",\n },\n {\n name: \"tag.delimiter\",\n tag: \"td\",\n parentTag: \"tag\",\n },\n {\n name: \"tag.error\",\n tag: \"te\",\n parentTag: \"tag\",\n },\n {\n name: \"type\",\n tag: \"t\",\n },\n {\n name: \"type.builtin\",\n tag: \"tb\",\n parentTag: \"type\",\n },\n {\n name: \"type.qualifier\",\n tag: \"tq\",\n parentTag: \"type\",\n },\n {\n name: \"variable\",\n tag: \"v\",\n },\n {\n name: \"variable.builtin\",\n tag: \"vb\",\n parentTag: \"variable\",\n },\n {\n name: \"variable.parameter\",\n tag: \"vp\",\n parentTag: \"variable\",\n },\n {\n name: \"comment\",\n tag: \"c\",\n },\n {\n name: \"comment.documentation\",\n tag: \"cd\",\n parentTag: \"comment\",\n },\n {\n name: \"macro\",\n tag: \"m\",\n },\n {\n name: \"label\",\n tag: \"l\",\n },\n {\n name: \"diff.addition\",\n tag: \"da\",\n },\n {\n name: \"diff.deletion\",\n tag: \"dd\",\n },\n {\n name: \"number\",\n tag: \"n\",\n },\n {\n name: \"text.literal\",\n tag: \"tl\",\n },\n {\n name: \"text.emphasis\",\n tag: \"em\",\n },\n {\n name: \"text.strong\",\n tag: \"st\",\n },\n {\n name: \"text.uri\",\n tag: \"tu\",\n },\n {\n name: \"text.reference\",\n tag: \"tr\",\n },\n {\n name: \"string.escape\",\n tag: \"se\",\n parentTag: \"string\",\n },\n {\n name: \"text.title\",\n tag: \"tt\",\n },\n {\n name: \"text.strikethrough\",\n tag: \"tx\",\n },\n {\n name: \"spell\",\n tag: \"sp\",\n },\n {\n name: \"embedded\",\n tag: \"eb\",\n },\n {\n name: \"error\",\n tag: \"er\",\n },\n {\n name: \"namespace\",\n tag: \"ns\",\n },\n {\n name: \"include\",\n tag: \"in\",\n parentTag: \"keyword\",\n },\n {\n name: \"storageclass\",\n tag: \"sc\",\n parentTag: \"keyword\",\n },\n {\n name: \"repeat\",\n tag: \"rp\",\n parentTag: \"keyword\",\n },\n {\n name: \"conditional\",\n tag: \"cn\",\n parentTag: \"keyword\",\n },\n {\n name: \"exception\",\n tag: \"ex\",\n parentTag: \"keyword\",\n },\n {\n name: \"preproc\",\n tag: \"pp\",\n parentTag: \"keyword\",\n },\n {\n name: \"none\",\n tag: \"\",\n },\n {\n name: \"character\",\n tag: \"ch\",\n parentTag: \"string\",\n },\n {\n name: \"character.special\",\n tag: \"cs\",\n parentTag: \"string\",\n },\n {\n name: \"variable.member\",\n tag: \"vm\",\n parentTag: \"variable\",\n },\n {\n name: \"function.definition\",\n tag: \"fd\",\n parentTag: \"function\",\n },\n {\n name: \"type.definition\",\n tag: \"tf\",\n parentTag: \"type\",\n },\n {\n name: \"function.call\",\n tag: \"fc\",\n parentTag: \"function\",\n },\n {\n name: \"keyword.modifier\",\n tag: \"km\",\n parentTag: \"keyword\",\n },\n {\n name: \"keyword.directive\",\n tag: \"dr\",\n parentTag: \"keyword\",\n },\n {\n name: \"string.regexp\",\n tag: \"rx\",\n parentTag: \"string\",\n },\n {\n name: \"nospell\",\n tag: \"\",\n },\n {\n name: \"float\",\n tag: \"n\",\n },\n {\n name: \"boolean\",\n tag: \"cb\",\n },\n];","/** Escape HTML special characters */\nexport function escapeHtml(text: string): string {\n return text\n .replace(/&/g, \"&\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .replace(/\"/g, \""\");\n}\n","/**\n * Arborium loader - loads grammar plugins and highlights code.\n *\n * Architecture:\n * 1. Grammar registry is bundled at build time (no network request needed in production)\n * - Can be overridden via pluginsUrl config for local development\n * 2. Load grammar wasm-bindgen modules on demand from @arborium/<lang> packages\n * 3. Parse and highlight using the grammar's tree-sitter parser\n */\n\nimport type {\n Utf8ParseResult,\n Utf16ParseResult,\n ArboriumConfig,\n Grammar,\n Session,\n} from \"./types.js\";\nimport { availableLanguages, pluginVersion } from \"./plugins-manifest.js\";\nimport { escapeHtml } from \"./utils.js\";\n\n// Default config\nexport const defaultConfig: Required<ArboriumConfig> = {\n manual: false,\n theme: \"one-dark\",\n selector: \"pre code\",\n cdn: \"jsdelivr\",\n version: pluginVersion, // Precise version from manifest\n pluginsUrl: \"\", // Empty means use bundled manifest\n hostUrl: \"\", // Empty means use CDN based on version\n resolveJs: ({ baseUrl, path }) => import(/* @vite-ignore */ `${baseUrl}/${path}`),\n resolveWasm: ({ baseUrl, path }) => fetch(`${baseUrl}/${path}`),\n};\n\n// Rust host module (loaded on demand)\ninterface HostModule {\n highlight: (language: string, source: string) => string;\n isLanguageAvailable: (language: string) => boolean;\n}\nlet hostModule: HostModule | null = null;\nlet hostLoadPromise: Promise<HostModule | null> | null = null;\n\n// Merged config\nlet globalConfig: Required<ArboriumConfig> = { ...defaultConfig };\n\n// Grammar plugins cache\nconst grammarCache = new Map<string, GrammarPlugin>();\n\n// In-flight grammar load promises (to prevent double-loading)\nconst grammarLoadPromises = new Map<string, Promise<GrammarPlugin | null>>();\n\n// Languages we know are available (bundled at build time)\nconst knownLanguages: Set<string> = new Set(availableLanguages);\n\n// For local development: can override with pluginsUrl to load from dev server\ninterface LocalManifest {\n entries: Array<{\n language: string;\n local_js: string;\n local_wasm: string;\n }>;\n}\nlet localManifest: LocalManifest | null = null;\nlet localManifestPromise: Promise<void> | null = null;\n\n/** Load local manifest if pluginsUrl is configured (for dev server) */\nasync function ensureLocalManifest(config: Required<ArboriumConfig>): Promise<void> {\n if (!config.pluginsUrl) {\n return;\n }\n\n if (localManifestPromise) {\n return localManifestPromise;\n }\n\n localManifestPromise = (async () => {\n console.debug(`[arborium] Loading local plugins manifest from: ${config.pluginsUrl}`);\n const response = await fetch(config.pluginsUrl);\n if (!response.ok) {\n throw new Error(`Failed to load plugins.json: ${response.status}`);\n }\n localManifest = await response.json();\n console.debug(`[arborium] Loaded local manifest with ${localManifest?.entries.length} entries`);\n })();\n\n return localManifestPromise;\n}\n\n/** Get the CDN base URL for a grammar */\nfunction getGrammarBaseUrl(language: string, config: Required<ArboriumConfig>): string {\n // If we have a local manifest (dev mode), use the local path\n if (localManifest) {\n const entry = localManifest.entries.find((e) => e.language === language);\n if (entry) {\n // Extract base URL from local_js path (e.g., \"/langs/group-hazel/python/npm/grammar.js\" -> \"/langs/group-hazel/python/npm\")\n return entry.local_js.substring(0, entry.local_js.lastIndexOf(\"/\"));\n }\n }\n\n // Production: derive from language name using precise version\n const cdn = config.cdn;\n const version = config.version;\n let baseUrl: string;\n if (cdn === \"jsdelivr\") {\n baseUrl = \"https://cdn.jsdelivr.net/npm\";\n } else if (cdn === \"unpkg\") {\n baseUrl = \"https://unpkg.com\";\n } else {\n baseUrl = cdn;\n }\n return `${baseUrl}/@arborium/${language}@${version}`;\n}\n\ntype MaybePromise<T> = Promise<T> | T;\n\n// See https://github.com/wasm-bindgen/wasm-bindgen/blob/dda4821ee2fbcaa7adc58bc8c385ed8d3627a272/crates/cli-support/src/js/mod.rs#L860\n/** Source of the WASM module for wasm-bindgen */\ntype WbgInitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module;\n\n/** wasm-bindgen plugin module interface */\ninterface WasmBindgenPlugin {\n default: (\n module_or_path?: { module_or_path: MaybePromise<WbgInitInput> } | undefined,\n // deprecated: | MaybePromise<WbgInitInput>,\n ) => Promise<void>;\n language_id: () => string;\n injection_languages: () => string[];\n create_session: () => number;\n free_session: (session: number) => void;\n set_text: (session: number, text: string) => void;\n /** Parse and return UTF-8 byte offsets (for Rust host) */\n parse: (session: number) => Utf8ParseResult;\n /** Parse and return UTF-16 code unit indices (for JavaScript) */\n parse_utf16: (session: number) => Utf16ParseResult;\n cancel: (session: number) => void;\n}\n\n/** A loaded grammar plugin */\ninterface GrammarPlugin {\n languageId: string;\n injectionLanguages: string[];\n module: WasmBindgenPlugin;\n /** Parse returning UTF-8 offsets (for Rust host) */\n parseUtf8: (text: string) => Utf8ParseResult;\n /** Parse returning UTF-16 offsets (for JavaScript public API) */\n parseUtf16: (text: string) => Utf16ParseResult;\n}\n\n/** Load a grammar plugin */\nasync function loadGrammarPlugin(\n language: string,\n config: Required<ArboriumConfig>,\n): Promise<GrammarPlugin | null> {\n // Check cache first\n const cached = grammarCache.get(language);\n if (cached) {\n console.debug(`[arborium] Grammar '${language}' found in cache`);\n return cached;\n }\n\n // Check if there's already an in-flight load for this language\n const inFlight = grammarLoadPromises.get(language);\n if (inFlight) {\n console.debug(`[arborium] Grammar '${language}' already loading, waiting...`);\n return inFlight;\n }\n\n // Start the actual load and track the promise\n const loadPromise = loadGrammarPluginInner(language, config);\n grammarLoadPromises.set(language, loadPromise);\n\n try {\n return await loadPromise;\n } finally {\n // Clean up the in-flight promise once done\n grammarLoadPromises.delete(language);\n }\n}\n\n/** Internal grammar loading - called only once per language */\nasync function loadGrammarPluginInner(\n language: string,\n config: Required<ArboriumConfig>,\n): Promise<GrammarPlugin | null> {\n // Load local manifest if in dev mode\n await ensureLocalManifest(config);\n\n // Check if language is known\n if (\n !knownLanguages.has(language) &&\n !localManifest?.entries.some((e) => e.language === language)\n ) {\n console.debug(`[arborium] Grammar '${language}' not available`);\n return null;\n }\n\n try {\n const baseUrl = getGrammarBaseUrl(language, config);\n const detail =\n config.resolveJs === defaultConfig.resolveJs ? ` from ${baseUrl}/grammar.js` : \"\";\n console.debug(`[arborium] Loading grammar '${language}'${detail}`);\n\n const module = (await config.resolveJs({\n language,\n baseUrl,\n path: \"grammar.js\",\n })) as WasmBindgenPlugin;\n const wasm = await config.resolveWasm({ language, baseUrl, path: \"grammar_bg.wasm\" });\n\n // Initialize the WASM module\n await module.default({ module_or_path: wasm });\n\n // Verify it loaded correctly\n const loadedId = module.language_id();\n if (loadedId !== language) {\n console.warn(`[arborium] Language ID mismatch: expected '${language}', got '${loadedId}'`);\n }\n\n // Get injection languages\n const injectionLanguages = module.injection_languages();\n\n // Wrap as GrammarPlugin with session-based parsing\n const plugin: GrammarPlugin = {\n languageId: language,\n injectionLanguages,\n module,\n // UTF-8 parsing for Rust host\n parseUtf8: (text: string) => {\n const session = module.create_session();\n try {\n module.set_text(session, text);\n const result = module.parse(session);\n return {\n spans: result.spans || [],\n injections: result.injections || [],\n };\n } catch (e) {\n console.error(`[arborium] Parse error:`, e);\n return { spans: [], injections: [] };\n } finally {\n module.free_session(session);\n }\n },\n // UTF-16 parsing for JavaScript public API\n parseUtf16: (text: string) => {\n const session = module.create_session();\n try {\n module.set_text(session, text);\n const result = module.parse_utf16(session);\n return {\n spans: result.spans || [],\n injections: result.injections || [],\n };\n } catch (e) {\n console.error(`[arborium] Parse error:`, e);\n return { spans: [], injections: [] };\n } finally {\n module.free_session(session);\n }\n },\n };\n\n grammarCache.set(language, plugin);\n console.debug(`[arborium] Grammar '${language}' loaded successfully`);\n return plugin;\n } catch (e) {\n console.error(`[arborium] Failed to load grammar '${language}':`, e);\n return null;\n }\n}\n\n// Handle to plugin mapping for the host interface\nconst handleToPlugin = new Map<number, GrammarPlugin>();\nlet nextHandle = 1;\n\n/** Setup window.arboriumHost for the Rust host to call into */\nfunction setupHostInterface(config: Required<ArboriumConfig>): void {\n (window as any).arboriumHost = {\n /** Check if a language is available (sync) */\n isLanguageAvailable(language: string): boolean {\n return knownLanguages.has(language) || grammarCache.has(language);\n },\n\n /** Load a grammar and return a handle (async) */\n async loadGrammar(language: string): Promise<number> {\n const plugin = await loadGrammarPlugin(language, config);\n if (!plugin) return 0; // 0 = not found\n\n // Check if we already have a handle\n for (const [handle, p] of handleToPlugin) {\n if (p === plugin) return handle;\n }\n\n // Create new handle\n const handle = nextHandle++;\n handleToPlugin.set(handle, plugin);\n return handle;\n },\n\n /** Parse text using a grammar handle (sync) - returns UTF-8 offsets for Rust host */\n parse(handle: number, text: string): Utf8ParseResult {\n const plugin = handleToPlugin.get(handle);\n if (!plugin) return { spans: [], injections: [] };\n return plugin.parseUtf8(text);\n },\n };\n}\n\n/** Get the host URL based on config */\nfunction getHostUrl(config: Required<ArboriumConfig>): string {\n if (config.hostUrl) {\n return config.hostUrl;\n }\n // Use CDN\n const cdn = config.cdn;\n const version = config.version;\n let baseUrl: string;\n if (cdn === \"jsdelivr\") {\n baseUrl = \"https://cdn.jsdelivr.net/npm\";\n } else if (cdn === \"unpkg\") {\n baseUrl = \"https://unpkg.com\";\n } else {\n baseUrl = cdn;\n }\n const versionSuffix = version === \"latest\" ? \"\" : `@${version}`;\n return `${baseUrl}/@arborium/arborium${versionSuffix}/dist`;\n}\n\n/** Load the Rust host module */\nasync function loadHost(config: Required<ArboriumConfig>): Promise<HostModule | null> {\n if (hostModule) return hostModule;\n if (hostLoadPromise) return hostLoadPromise;\n\n hostLoadPromise = (async () => {\n // Setup the interface the host imports\n setupHostInterface(config);\n\n const hostUrl = getHostUrl(config);\n const jsUrl = `${hostUrl}/arborium_host.js`;\n const wasmUrl = `${hostUrl}/arborium_host_bg.wasm`;\n\n console.debug(`[arborium] Loading host from ${jsUrl}`);\n try {\n const module = await import(/* @vite-ignore */ jsUrl);\n await module.default(wasmUrl);\n\n hostModule = {\n highlight: module.highlight,\n isLanguageAvailable: module.isLanguageAvailable,\n };\n console.debug(`[arborium] Host loaded successfully`);\n return hostModule;\n } catch (e) {\n console.error(\"[arborium] Failed to load host:\", e);\n return null;\n }\n })();\n\n return hostLoadPromise;\n}\n\n/** Highlight source code */\nexport async function highlight(\n language: string,\n source: string,\n configOverrides?: ArboriumConfig,\n): Promise<string> {\n const config = getConfig(configOverrides);\n // Use the Rust host (handles injections, proper span deduplication, etc.)\n const host = await loadHost(config);\n if (host) {\n try {\n return host.highlight(language, source);\n } catch (e) {\n console.error(\"[arborium] Host highlight failed:\", e);\n }\n }\n\n // Host not available - return escaped source\n return escapeHtml(source);\n}\n\n/** Load a grammar for direct use */\nexport async function loadGrammar(\n language: string,\n configOverrides?: ArboriumConfig,\n): Promise<Grammar | null> {\n const config = getConfig(configOverrides);\n const plugin = await loadGrammarPlugin(language, config);\n if (!plugin) return null;\n\n const { module } = plugin;\n\n return {\n languageId: () => plugin.languageId,\n injectionLanguages: () => plugin.injectionLanguages,\n highlight: async (source: string) => {\n // Use the Rust host for proper highlighting with injection support\n return highlight(language, source, configOverrides);\n },\n // Public API returns UTF-16 offsets for JavaScript compatibility\n parse: (source: string) => plugin.parseUtf16(source),\n createSession: (): Session => {\n const handle = module.create_session();\n return {\n setText: (text: string) => module.set_text(handle, text),\n // Session.parse() returns UTF-16 offsets for JavaScript compatibility\n parse: () => {\n try {\n const result = module.parse_utf16(handle);\n return {\n spans: result.spans || [],\n injections: result.injections || [],\n };\n } catch (e) {\n console.error(`[arborium] Session parse error:`, e);\n return { spans: [], injections: [] };\n }\n },\n cancel: () => module.cancel(handle),\n free: () => module.free_session(handle),\n };\n },\n dispose: () => {\n // No-op for now, plugins are cached\n },\n };\n}\n\n/** Get current config, optionally merging with overrides */\nexport function getConfig(overrides?: Partial<ArboriumConfig>): Required<ArboriumConfig> {\n if (overrides) {\n return { ...globalConfig, ...overrides };\n }\n return { ...globalConfig };\n}\n\n/** Set/merge config */\nexport function setConfig(newConfig: Partial<ArboriumConfig>): void {\n globalConfig = { ...globalConfig, ...newConfig };\n}\n\n/** Check if a language is available */\nexport async function isLanguageAvailable(\n language: string,\n configOverrides?: ArboriumConfig,\n): Promise<boolean> {\n const config = getConfig(configOverrides);\n await ensureLocalManifest(config);\n return (\n knownLanguages.has(language) ||\n (localManifest?.entries.some((e) => e.language === language) ?? false)\n );\n}\n\n/** Get list of available languages */\nexport async function getAvailableLanguages(configOverrides?: ArboriumConfig): Promise<string[]> {\n const config = getConfig(configOverrides);\n await ensureLocalManifest(config);\n // In dev mode, use local manifest if available\n if (localManifest) {\n return localManifest.entries.map((e) => e.language);\n }\n return Array.from(knownLanguages);\n}\n","/**\n * Simple language detection heuristics.\n * Not meant to be comprehensive - just catches common cases.\n */\n\n/** Shebang patterns */\nconst SHEBANG_PATTERNS: Array<[RegExp, string]> = [\n [/^#!.*\\bpython[23]?\\b/, 'python'],\n [/^#!.*\\bnode\\b/, 'javascript'],\n [/^#!.*\\bdeno\\b/, 'typescript'],\n [/^#!.*\\bbun\\b/, 'typescript'],\n [/^#!.*\\bruby\\b/, 'ruby'],\n [/^#!.*\\bperl\\b/, 'perl'],\n [/^#!.*\\bphp\\b/, 'php'],\n [/^#!.*\\bbash\\b/, 'bash'],\n [/^#!.*\\bzsh\\b/, 'zsh'],\n [/^#!.*\\bsh\\b/, 'bash'],\n [/^#!.*\\blua\\b/, 'lua'],\n [/^#!.*\\bawk\\b/, 'awk'],\n];\n\n/** Keyword fingerprints - first few unique keywords that identify a language */\nconst KEYWORD_FINGERPRINTS: Array<[RegExp, string]> = [\n // Rust - distinctive keywords\n [/\\b(fn|impl|trait|pub\\s+fn|let\\s+mut|&mut|->)\\b/, 'rust'],\n\n // Go - distinctive keywords\n [/\\b(func|package\\s+\\w+|import\\s+\\(|go\\s+func|chan\\s+\\w+)\\b/, 'go'],\n\n // Python - distinctive patterns\n [/\\b(def\\s+\\w+\\s*\\(|import\\s+\\w+|from\\s+\\w+\\s+import|class\\s+\\w+:)\\b/, 'python'],\n\n // TypeScript - distinctive type annotations\n [/:\\s*(string|number|boolean|void)\\b|\\binterface\\s+\\w+\\s*\\{/, 'typescript'],\n\n // JavaScript - distinctive patterns (after TS check)\n [/\\b(const|let|var)\\s+\\w+\\s*=|function\\s+\\w+\\s*\\(|=>\\s*\\{/, 'javascript'],\n\n // Ruby - distinctive keywords\n [/\\b(def\\s+\\w+|end\\b|do\\s*\\|.*\\||puts\\s+|require\\s+['\"])\\b/, 'ruby'],\n\n // Java - distinctive patterns\n [/\\b(public\\s+class|private\\s+\\w+|System\\.out\\.println)\\b/, 'java'],\n\n // C++ - distinctive patterns\n [/\\b(#include\\s*<|std::|template\\s*<|nullptr|cout\\s*<<)\\b/, 'cpp'],\n\n // C - distinctive patterns (after C++ check)\n [/\\b(#include\\s*[<\"]|printf\\s*\\(|int\\s+main\\s*\\(|void\\s+\\w+\\s*\\()\\b/, 'c'],\n\n // C# - distinctive patterns\n [/\\b(namespace\\s+\\w+|using\\s+System|public\\s+static\\s+void)\\b/, 'c-sharp'],\n\n // PHP - distinctive patterns\n [/<\\?php|\\$\\w+\\s*=/, 'php'],\n\n // Swift - distinctive patterns\n [/\\b(func\\s+\\w+|var\\s+\\w+:\\s*\\w+|let\\s+\\w+:\\s*\\w+|@objc)\\b/, 'swift'],\n\n // Kotlin - distinctive patterns\n [/\\b(fun\\s+\\w+|val\\s+\\w+|var\\s+\\w+:|data\\s+class)\\b/, 'kotlin'],\n\n // Scala - distinctive patterns\n [/\\b(def\\s+\\w+|val\\s+\\w+|var\\s+\\w+|object\\s+\\w+|case\\s+class)\\b/, 'scala'],\n\n // Haskell - distinctive patterns\n [/\\b(module\\s+\\w+|import\\s+qualified|data\\s+\\w+\\s*=|::\\s*\\w+\\s*->)\\b/, 'haskell'],\n\n // Elixir - distinctive patterns\n [/\\b(defmodule\\s+\\w+|def\\s+\\w+|defp\\s+\\w+|\\|>)\\b/, 'elixir'],\n\n // Lua - distinctive patterns\n [/\\b(local\\s+\\w+\\s*=|function\\s+\\w+\\.\\w+|require\\s*\\()\\b/, 'lua'],\n\n // SQL - distinctive patterns\n [/\\b(SELECT\\s+.*\\s+FROM|INSERT\\s+INTO|CREATE\\s+TABLE|ALTER\\s+TABLE)\\b/i, 'sql'],\n\n // Shell/Bash - distinctive patterns\n [/\\b(if\\s+\\[\\s*|then\\b|fi\\b|echo\\s+[\"']|export\\s+\\w+=)\\b/, 'bash'],\n\n // YAML - distinctive patterns\n [/^\\s*[\\w-]+:\\s*[\\w\\-\"'[{]|^---\\s*$/, 'yaml'],\n\n // JSON - distinctive patterns\n [/^\\s*\\{[\\s\\S]*\"[\\w-]+\":\\s*/, 'json'],\n\n // TOML - distinctive patterns\n [/^\\s*\\[[\\w.-]+\\]\\s*$|^\\s*\\w+\\s*=\\s*[\"'\\d\\[]/, 'toml'],\n\n // HTML - distinctive patterns\n [/<(!DOCTYPE|html|head|body|div|span|p|a\\s)/i, 'html'],\n\n // CSS - distinctive patterns\n [/^\\s*[\\w.#@][\\w\\s,#.:>+~-]*\\{[^}]*\\}|@media\\s|@import\\s/, 'css'],\n\n // Markdown - distinctive patterns\n [/^#{1,6}\\s+\\w|^\\s*[-*+]\\s+\\w|^\\s*\\d+\\.\\s+\\w|```\\w*\\n/, 'markdown'],\n\n // XML - distinctive patterns\n [/<\\?xml|<[\\w:-]+\\s+xmlns/, 'xml'],\n\n // Dockerfile\n [/^FROM\\s+\\w+|^RUN\\s+|^COPY\\s+|^ENTRYPOINT\\s+/m, 'dockerfile'],\n\n // Nginx config\n [/\\b(server\\s*\\{|location\\s+[\\/~]|proxy_pass\\s+)\\b/, 'nginx'],\n\n // Zig\n [/\\b(pub\\s+fn|const\\s+\\w+\\s*=|@import\\(|comptime)\\b/, 'zig'],\n];\n\n/**\n * Detect the language of a code snippet.\n * Returns null if detection fails.\n */\nexport function detectLanguage(source: string): string | null {\n // Check shebang first (most reliable)\n const firstLine = source.split('\\n')[0];\n for (const [pattern, language] of SHEBANG_PATTERNS) {\n if (pattern.test(firstLine)) {\n return language;\n }\n }\n\n // Check keyword fingerprints\n for (const [pattern, language] of KEYWORD_FINGERPRINTS) {\n if (pattern.test(source)) {\n return language;\n }\n }\n\n return null;\n}\n\n/**\n * Extract language from class name.\n * Supports multiple patterns:\n * - \"language-rust\" -> \"rust\" (standard)\n * - \"lang-rust\" -> \"rust\" (common alternative)\n * - \"rust\" -> \"rust\" (docs.rs style, bare language name)\n */\nexport function extractLanguageFromClass(className: string): string | null {\n // Try \"language-*\" pattern first (most specific)\n const langMatch = className.match(/\\blanguage-(\\w+)\\b/);\n if (langMatch) return langMatch[1];\n\n // Try \"lang-*\" pattern\n const shortMatch = className.match(/\\blang-(\\w+)\\b/);\n if (shortMatch) return shortMatch[1];\n\n // Try bare language names (for docs.rs compatibility)\n // Only match known language names to avoid false positives\n const knownLanguages = new Set([\n 'rust', 'javascript', 'typescript', 'python', 'ruby', 'go', 'java',\n 'c', 'cpp', 'csharp', 'php', 'swift', 'kotlin', 'scala', 'haskell',\n 'elixir', 'lua', 'sql', 'bash', 'shell', 'yaml', 'json', 'toml',\n 'html', 'css', 'xml', 'markdown', 'dockerfile', 'nginx', 'zig',\n 'text', 'plaintext', 'console', 'sh',\n ]);\n\n for (const cls of className.split(/\\s+/)) {\n if (knownLanguages.has(cls.toLowerCase())) {\n return cls.toLowerCase();\n }\n }\n\n return null;\n}\n\n/**\n * Normalize language identifier (handle aliases)\n */\nexport function normalizeLanguage(lang: string): string {\n const aliases: Record<string, string> = {\n js: 'javascript',\n ts: 'typescript',\n py: 'python',\n rb: 'ruby',\n rs: 'rust',\n sh: 'bash',\n shell: 'bash',\n yml: 'yaml',\n cs: 'c-sharp',\n csharp: 'c-sharp',\n 'c++': 'cpp',\n 'c#': 'c-sharp',\n 'f#': 'fsharp',\n dockerfile: 'dockerfile',\n docker: 'dockerfile',\n makefile: 'make',\n plaintext: 'text',\n plain: 'text',\n txt: 'text',\n };\n\n const lower = lang.toLowerCase();\n return aliases[lower] || lower;\n}\n"],"names":["pluginVersion","availableLanguages","highlights","escapeHtml","text","defaultConfig","baseUrl","path","hostModule","hostLoadPromise","globalConfig","grammarCache","grammarLoadPromises","knownLanguages","localManifest","localManifestPromise","ensureLocalManifest","config","response","getGrammarBaseUrl","language","entry","e","cdn","version","loadGrammarPlugin","cached","inFlight","loadPromise","loadGrammarPluginInner","detail","module","wasm","loadedId","injectionLanguages","plugin","session","result","handleToPlugin","nextHandle","setupHostInterface","handle","p","getHostUrl","versionSuffix","loadHost","hostUrl","jsUrl","wasmUrl","highlight","source","configOverrides","getConfig","host","loadGrammar","overrides","setConfig","newConfig","SHEBANG_PATTERNS","KEYWORD_FINGERPRINTS","detectLanguage","firstLine","pattern","extractLanguageFromClass","className","langMatch","shortMatch","cls","normalizeLanguage","lang","aliases","lower"],"mappings":"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"}
|
package/dist/arborium_host.js
CHANGED
|
@@ -355,7 +355,7 @@ function __wbg_get_imports() {
|
|
|
355
355
|
const ret = Reflect.get(arg0, arg1);
|
|
356
356
|
return ret;
|
|
357
357
|
}, arguments) };
|
|
358
|
-
imports.wbg.
|
|
358
|
+
imports.wbg.__wbg_isLanguageAvailable_c5007111a6e4a3ef = function(arg0, arg1) {
|
|
359
359
|
const ret = arboriumHost.isLanguageAvailable(getStringFromWasm0(arg0, arg1));
|
|
360
360
|
return ret;
|
|
361
361
|
};
|
|
@@ -363,7 +363,7 @@ function __wbg_get_imports() {
|
|
|
363
363
|
const ret = arg0.length;
|
|
364
364
|
return ret;
|
|
365
365
|
};
|
|
366
|
-
imports.wbg.
|
|
366
|
+
imports.wbg.__wbg_loadGrammar_ac8f4603fa67f0ea = function() { return handleError(function (arg0, arg1) {
|
|
367
367
|
const ret = arboriumHost.loadGrammar(getStringFromWasm0(arg0, arg1));
|
|
368
368
|
return ret;
|
|
369
369
|
}, arguments) };
|
|
@@ -389,7 +389,7 @@ function __wbg_get_imports() {
|
|
|
389
389
|
const ret = new Function(getStringFromWasm0(arg0, arg1));
|
|
390
390
|
return ret;
|
|
391
391
|
};
|
|
392
|
-
imports.wbg.
|
|
392
|
+
imports.wbg.__wbg_parse_693d1af5fab02b56 = function(arg0, arg1, arg2) {
|
|
393
393
|
const ret = arboriumHost.parse(arg0 >>> 0, getStringFromWasm0(arg1, arg2));
|
|
394
394
|
return ret;
|
|
395
395
|
};
|
|
Binary file
|
package/dist/loader.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { ArboriumConfig, Grammar } from './types.js';
|
|
2
|
-
export { spansToHtml } from './utils.js';
|
|
3
2
|
export declare const defaultConfig: Required<ArboriumConfig>;
|
|
4
3
|
/** Highlight source code */
|
|
5
4
|
export declare function highlight(language: string, source: string, configOverrides?: ArboriumConfig): Promise<string>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Highlight } from './types.js';
|
|
2
2
|
/** Version of plugin packages (all @arborium/* packages share this version) */
|
|
3
|
-
export declare const pluginVersion = "2.
|
|
3
|
+
export declare const pluginVersion = "2.11.0";
|
|
4
4
|
/** All available languages */
|
|
5
5
|
export declare const availableLanguages: string[];
|
|
6
6
|
/** All possible highlights and their short tags */
|
package/dist/types.d.ts
CHANGED
|
@@ -1,11 +1,59 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* A span of highlighted text.
|
|
2
|
+
* A span of highlighted text with UTF-8 byte offsets.
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
4
|
+
* This is the native format from tree-sitter. Use this when working with
|
|
5
|
+
* Rust code that needs to slice strings with `&source[start..end]`.
|
|
6
|
+
*
|
|
7
|
+
* For JavaScript string operations, use {@link Utf16Span} instead.
|
|
8
|
+
*
|
|
9
|
+
* @internal
|
|
10
|
+
*/
|
|
11
|
+
export interface Utf8Span {
|
|
12
|
+
/** UTF-8 byte offset where the span starts (inclusive) */
|
|
13
|
+
start: number;
|
|
14
|
+
/** UTF-8 byte offset where the span ends (exclusive) */
|
|
15
|
+
end: number;
|
|
16
|
+
/** The capture name (e.g., "keyword", "string", "comment") */
|
|
17
|
+
capture: string;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* A language injection with UTF-8 byte offsets.
|
|
21
|
+
*
|
|
22
|
+
* @internal
|
|
23
|
+
*/
|
|
24
|
+
export interface Utf8Injection {
|
|
25
|
+
/** UTF-8 byte offset where the injection starts (inclusive) */
|
|
26
|
+
start: number;
|
|
27
|
+
/** UTF-8 byte offset where the injection ends (exclusive) */
|
|
28
|
+
end: number;
|
|
29
|
+
language: string;
|
|
30
|
+
includeChildren: boolean;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Result of parsing source code, with UTF-8 byte offsets.
|
|
34
|
+
*
|
|
35
|
+
* @internal
|
|
7
36
|
*/
|
|
8
|
-
export interface
|
|
37
|
+
export interface Utf8ParseResult {
|
|
38
|
+
spans: Utf8Span[];
|
|
39
|
+
injections: Utf8Injection[];
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* A span of highlighted text with UTF-16 code unit indices.
|
|
43
|
+
*
|
|
44
|
+
* The `start` and `end` fields are compatible with JavaScript string APIs
|
|
45
|
+
* like `String.prototype.slice()`, `substring()`, and DOM `Range`.
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```ts
|
|
49
|
+
* const result = grammar.parse(source);
|
|
50
|
+
* for (const span of result.spans) {
|
|
51
|
+
* const text = source.slice(span.start, span.end);
|
|
52
|
+
* console.log(`${span.capture}: ${text}`);
|
|
53
|
+
* }
|
|
54
|
+
* ```
|
|
55
|
+
*/
|
|
56
|
+
export interface Utf16Span {
|
|
9
57
|
/** UTF-16 code unit index where the span starts (inclusive) */
|
|
10
58
|
start: number;
|
|
11
59
|
/** UTF-16 code unit index where the span ends (exclusive) */
|
|
@@ -14,9 +62,9 @@ export interface Span {
|
|
|
14
62
|
capture: string;
|
|
15
63
|
}
|
|
16
64
|
/**
|
|
17
|
-
* A language injection (e.g., JS inside HTML).
|
|
65
|
+
* A language injection (e.g., JS inside HTML) with UTF-16 code unit indices.
|
|
18
66
|
*/
|
|
19
|
-
export interface
|
|
67
|
+
export interface Utf16Injection {
|
|
20
68
|
/** UTF-16 code unit index where the injection starts (inclusive) */
|
|
21
69
|
start: number;
|
|
22
70
|
/** UTF-16 code unit index where the injection ends (exclusive) */
|
|
@@ -24,11 +72,28 @@ export interface Injection {
|
|
|
24
72
|
language: string;
|
|
25
73
|
includeChildren: boolean;
|
|
26
74
|
}
|
|
27
|
-
/**
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
75
|
+
/**
|
|
76
|
+
* Result of parsing source code, with UTF-16 code unit indices.
|
|
77
|
+
*
|
|
78
|
+
* This is the format returned by the public API (`grammar.parse()`,
|
|
79
|
+
* `session.parse()`). Offsets are compatible with JavaScript string operations.
|
|
80
|
+
*/
|
|
81
|
+
export interface Utf16ParseResult {
|
|
82
|
+
spans: Utf16Span[];
|
|
83
|
+
injections: Utf16Injection[];
|
|
31
84
|
}
|
|
85
|
+
/**
|
|
86
|
+
* @deprecated Use {@link Utf16Span} for JavaScript or {@link Utf8Span} for Rust interop.
|
|
87
|
+
*/
|
|
88
|
+
export type Span = Utf16Span;
|
|
89
|
+
/**
|
|
90
|
+
* @deprecated Use {@link Utf16Injection} for JavaScript or {@link Utf8Injection} for Rust interop.
|
|
91
|
+
*/
|
|
92
|
+
export type Injection = Utf16Injection;
|
|
93
|
+
/**
|
|
94
|
+
* @deprecated Use {@link Utf16ParseResult} for JavaScript or {@link Utf8ParseResult} for Rust interop.
|
|
95
|
+
*/
|
|
96
|
+
export type ParseResult = Utf16ParseResult;
|
|
32
97
|
/**
|
|
33
98
|
* A parsing session for incremental highlighting.
|
|
34
99
|
*
|
|
@@ -54,8 +119,8 @@ export interface ParseResult {
|
|
|
54
119
|
export interface Session {
|
|
55
120
|
/** Set the text to parse */
|
|
56
121
|
setText(text: string): void;
|
|
57
|
-
/** Parse the current text and return spans/injections */
|
|
58
|
-
parse():
|
|
122
|
+
/** Parse the current text and return spans/injections with UTF-16 offsets */
|
|
123
|
+
parse(): Utf16ParseResult;
|
|
59
124
|
/** Cancel any in-progress parsing */
|
|
60
125
|
cancel(): void;
|
|
61
126
|
/**
|
|
@@ -72,8 +137,8 @@ export interface Grammar {
|
|
|
72
137
|
injectionLanguages(): string[];
|
|
73
138
|
/** Highlight source code, returning HTML string */
|
|
74
139
|
highlight(source: string): string | Promise<string>;
|
|
75
|
-
/** Parse source code, returning
|
|
76
|
-
parse(source: string):
|
|
140
|
+
/** Parse source code, returning spans with UTF-16 offsets (creates a one-shot session internally) */
|
|
141
|
+
parse(source: string): Utf16ParseResult;
|
|
77
142
|
/** Create a session for incremental parsing */
|
|
78
143
|
createSession(): Session;
|
|
79
144
|
/** Dispose of resources */
|
package/dist/utils.d.ts
CHANGED
|
@@ -1,16 +1,2 @@
|
|
|
1
|
-
import { Span } from './types.js';
|
|
2
|
-
/**
|
|
3
|
-
* Get the UTF-8 byte length of a string.
|
|
4
|
-
*/
|
|
5
|
-
export declare function utf8ByteLength(str: string): number;
|
|
6
|
-
/**
|
|
7
|
-
* Convert a UTF-8 byte offset to a UTF-16 code unit index.
|
|
8
|
-
*
|
|
9
|
-
* This is needed because tree-sitter returns UTF-8 byte offsets,
|
|
10
|
-
* but JavaScript's String methods use UTF-16 code unit indices.
|
|
11
|
-
*/
|
|
12
|
-
export declare function utf8OffsetToUtf16(source: string, utf8Offset: number): number;
|
|
13
|
-
/** Convert spans to HTML */
|
|
14
|
-
export declare function spansToHtml(source: string, spans: Span[]): string;
|
|
15
1
|
/** Escape HTML special characters */
|
|
16
2
|
export declare function escapeHtml(text: string): string;
|
package/package.json
CHANGED
|
File without changes
|