diff --git a/dist/kasper.js b/dist/kasper.js index 66a5e2a..37e15b9 100644 --- a/dist/kasper.js +++ b/dist/kasper.js @@ -63,24 +63,41 @@ const ErrorTemplates = { "K007-1": (a) => a.message, "K007-2": (a) => a.message }; +function codeSnippet(source, line, col, context = 2) { + const lines = source.split("\n"); + const errorLine = line - 1; + const start = Math.max(0, errorLine - context); + const end = Math.min(lines.length - 1, errorLine + context); + const result = [""]; + for (let i = start; i <= end; i++) { + const indicator = i === errorLine ? ">" : " "; + result.push(` ${indicator} | ${lines[i]}`); + if (i === errorLine && col > 0) { + const pointer = " ".repeat(6 + col - 1) + "^"; + result.push(pointer); + } + } + return result.join("\n"); +} class KasperError extends Error { - constructor(code, args = {}, line, col, tagName) { + constructor(code, args = {}, options = {}) { + const { line, col, tag, source } = options; const isDev = typeof process !== "undefined" ? process.env.NODE_ENV !== "production" : true; const template = ErrorTemplates[code]; const message = template ? template(args) : typeof args === "string" ? args : "Unknown error"; - const location = line !== void 0 ? ` (${line}:${col})` : ""; - const tagInfo = tagName ? ` - at <${tagName}>` : ""; + const tagInfo = tag ? ` + at <${tag}>` : ""; + const snippet = line !== void 0 && source ? codeSnippet(source, line, col ?? 0) : ""; const link = isDev ? ` - -See: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(".", "")}` : ""; - super(`[${code}] ${message}${location}${tagInfo}${link}`); +See: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(".", "")} +` : ""; + super(`[${code}] ${message}${tagInfo}${snippet}${link}`); this.code = code; this.args = args; + this.name = "KasperError"; this.line = line; this.col = col; - this.tagName = tagName; - this.name = "KasperError"; + this.tagName = tag; } withTag(tagName) { if (!this.tagName) { @@ -91,6 +108,28 @@ See: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(".", "") return this; } } +let globalHandler = null; +function setErrorHandler(handler) { + globalHandler = handler ?? null; +} +function handleError(error, phase, component) { + const err = error instanceof Error ? error : new Error(String(error)); + if (component && typeof component.onError === "function") { + try { + component.onError(err, phase); + return; + } catch (e) { + } + } + if (globalHandler) { + try { + globalHandler(err, { component, phase }); + return; + } catch (_) { + } + } + console.error(`[Kasper] Error during ${phase}:`, err); +} let activeEffect = null; const effectStack = []; let batching = false; @@ -125,7 +164,7 @@ class Signal { try { watcher(newValue, oldValue); } catch (e) { - console.error("Watcher error:", e); + handleError(e, "watcher"); } } } @@ -230,7 +269,7 @@ function batch(fn) { try { watcher(); } catch (e) { - console.error("Watcher error:", e); + handleError(e, "watcher"); } } } @@ -746,9 +785,10 @@ const SelfClosingTags = [ "wbr" ]; class ExpressionParser { - parse(tokens) { + parse(tokens, source = "") { this.current = 0; this.tokens = tokens; + this.source = source; const expressions = []; while (!this.eof()) { expressions.push(this.expression()); @@ -793,7 +833,7 @@ class ExpressionParser { ); } error(code, token, args = {}) { - throw new KasperError(code, args, token.line, token.col); + throw new KasperError(code, args, { line: token.line, col: token.col, source: this.source }); } synchronize() { do { @@ -1506,7 +1546,7 @@ class Scanner { } } error(code, args = {}) { - throw new KasperError(code, args, this.line, this.col); + throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source }); } } class Scope { @@ -1580,7 +1620,7 @@ class Interpreter { }; } error(code, args = {}, line, col) { - throw new KasperError(code, args, line, col); + throw new KasperError(code, args, { line, col }); } visitVariableExpr(expr) { return this.scope.get(expr.name.lexeme); @@ -1642,7 +1682,7 @@ class Interpreter { } templateParse(source) { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); let result = ""; for (const expression of expressions) { result += this.evaluate(expression).toString(); @@ -1957,7 +1997,7 @@ class TemplateParser { return this.current > this.source.length; } error(code, args = {}) { - throw new KasperError(code, args, this.line, this.col); + throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source }); } node() { this.whitespace(); @@ -2225,7 +2265,7 @@ function flush() { instance.onRender(); } } catch (e) { - console.error("[Kasper] Error during component update:", e); + handleError(e, "render", instance); } } queue.clear(); @@ -2234,7 +2274,7 @@ function flush() { try { cb(); } catch (e) { - console.error("[Kasper] Error in nextTick callback:", e); + handleError(e, "render"); } } } @@ -2252,6 +2292,9 @@ function queueUpdate(instance, task) { queueMicrotask(flush); } } +function isBatching() { + return batchingEnabled; +} function flushSync(fn) { const prev = batchingEnabled; batchingEnabled = false; @@ -2388,6 +2431,13 @@ class Transpiler { this.interpreter.scope = scope; try { fn(); + } catch (e) { + if (isBatching()) { + const instance = this.interpreter.scope.get("$instance"); + handleError(e, "render", instance); + } else { + throw e; + } } finally { this.interpreter.scope = prev; } @@ -2410,7 +2460,7 @@ class Transpiler { // evaluates expressions and returns the result of the first evaluation execute(source, overrideScope) { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); const restoreScope = this.interpreter.scope; if (overrideScope) { this.interpreter.scope = overrideScope; @@ -2997,7 +3047,7 @@ class Transpiler { } evaluateExpression(source) { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); let result = ""; for (const expression of expressions) { result += `${this.interpreter.evaluate(expression)}`; @@ -3119,7 +3169,7 @@ class Transpiler { const cleanMessage = args.includes("Runtime Error") ? args.replace("Runtime Error: ", "") : args; finalArgs = { message: cleanMessage }; } - throw new KasperError(code, finalArgs, void 0, void 0, tagName); + throw new KasperError(code, finalArgs, { tag: tagName }); } } function lazy(importer) { @@ -3172,6 +3222,9 @@ function bootstrap(config) { { tag: entryTag } ); } + if (config.onError) { + setErrorHandler(config.onError); + } const transpiler = new Transpiler({ registry: config.registry }); if (config.mode) { transpiler.mode = config.mode; @@ -3208,4 +3261,4 @@ export { transpile, watch }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"kasper.js","sources":["../src/types/error.ts","../src/signal.ts","../src/component.ts","../src/types/expressions.ts","../src/types/token.ts","../src/expression-parser.ts","../src/utils.ts","../src/scanner.ts","../src/scope.ts","../src/interpreter.ts","../src/types/nodes.ts","../src/template-parser.ts","../src/router.ts","../src/boundary.ts","../src/scheduler.ts","../src/transpiler.ts","../src/kasper.ts"],"sourcesContent":["export const KErrorCode = {\n  // Bootstrap\n  ROOT_ELEMENT_NOT_FOUND: \"K001-1\",\n  ENTRY_COMPONENT_NOT_FOUND: \"K001-2\",\n\n  // Scanner\n  UNTERMINATED_COMMENT: \"K002-1\",\n  UNTERMINATED_STRING: \"K002-2\",\n  UNEXPECTED_CHARACTER: \"K002-3\",\n\n  // Template Parser\n  UNEXPECTED_EOF: \"K003-1\",\n  UNEXPECTED_CLOSING_TAG: \"K003-2\",\n  EXPECTED_TAG_NAME: \"K003-3\",\n  EXPECTED_CLOSING_BRACKET: \"K003-4\",\n  EXPECTED_CLOSING_TAG: \"K003-5\",\n  BLANK_ATTRIBUTE_NAME: \"K003-6\",\n  MISPLACED_CONDITIONAL: \"K003-7\",\n  DUPLICATE_IF: \"K003-8\",\n  MULTIPLE_STRUCTURAL_DIRECTIVES: \"K003-9\",\n\n  // Expression Parser\n  UNEXPECTED_TOKEN: \"K004-1\",\n  INVALID_LVALUE: \"K004-2\",\n  EXPECTED_EXPRESSION: \"K004-3\",\n  INVALID_DICTIONARY_KEY: \"K004-4\",\n\n  // Interpreter\n  INVALID_POSTFIX_LVALUE: \"K005-1\",\n  UNKNOWN_BINARY_OPERATOR: \"K005-2\",\n  INVALID_PREFIX_RVALUE: \"K005-3\",\n  UNKNOWN_UNARY_OPERATOR: \"K005-4\",\n  NOT_A_FUNCTION: \"K005-5\",\n  NOT_A_CLASS: \"K005-6\",\n\n  // Signals\n  CIRCULAR_COMPUTED: \"K006-1\",\n\n  // Transpiler\n  RUNTIME_ERROR: \"K007-1\",\n  MISSING_REQUIRED_ATTR: \"K007-2\",\n} as const;\n\nexport type KErrorCodeType = (typeof KErrorCode)[keyof typeof KErrorCode];\n\nexport const ErrorTemplates: Record<string, (args: any) => string> = {\n  \"K001-1\": (a) => `Root element not found: ${a.root}`,\n  \"K001-2\": (a) => `Entry component <${a.tag}> not found in registry.`,\n  \n  \"K002-1\": () => 'Unterminated comment, expecting closing \"*/\"',\n  \"K002-2\": (a) => `Unterminated string, expecting closing ${a.quote}`,\n  \"K002-3\": (a) => `Unexpected character '${a.char}'`,\n\n  \"K003-1\": (a) => `Unexpected end of file. ${a.eofError}`,\n  \"K003-2\": () => \"Unexpected closing tag\",\n  \"K003-3\": () => \"Expected a tag name\",\n  \"K003-4\": () => \"Expected closing tag >\",\n  \"K003-5\": (a) => `Expected </${a.name}>`,\n  \"K003-6\": () => \"Blank attribute name\",\n  \"K003-7\": (a) => `@${a.name} must be preceded by an @if or @elseif block.`,\n  \"K003-8\": () => \"Multiple conditional directives (@if, @elseif, @else) on the same element are not allowed.\",\n  \"K003-9\": () => \"Multiple structural directives (@if, @each) on the same element are not allowed. Nest them or use <void> instead.\",\n\n  \"K004-1\": (a) => `${a.message}, unexpected token \"${a.token}\"`,\n  \"K004-2\": () => \"Invalid l-value, is not an assigning target.\",\n  \"K004-3\": (a) => `Expected expression, unexpected token \"${a.token}\"`,\n  \"K004-4\": (a) => `String, Number or Identifier expected as a Key of Dictionary {, unexpected token ${a.token}`,\n\n  \"K005-1\": (a) => `Invalid left-hand side in postfix operation: ${a.entity}`,\n  \"K005-2\": (a) => `Unknown binary operator ${a.operator}`,\n  \"K005-3\": (a) => `Invalid right-hand side expression in prefix operation: ${a.right}`,\n  \"K005-4\": (a) => `Unknown unary operator ${a.operator}`,\n  \"K005-5\": (a) => `${a.callee} is not a function`,\n  \"K005-6\": (a) => `'${a.clazz}' is not a class. 'new' statement must be used with classes.`,\n\n  \"K006-1\": () => \"Circular dependency detected in computed signal\",\n\n  \"K007-1\": (a) => a.message,\n  \"K007-2\": (a) => a.message,\n};\n\nexport class KasperError extends Error {\n  constructor(\n    public code: KErrorCodeType,\n    public args: any = {},\n    public line?: number,\n    public col?: number,\n    public tagName?: string\n  ) {\n    // Detect environment\n    const isDev =\n      typeof process !== \"undefined\"\n        ? process.env.NODE_ENV !== \"production\"\n        : (import.meta as any).env?.MODE !== \"production\";\n\n    const template = ErrorTemplates[code];\n    const message = template \n      ? template(args) \n      : (typeof args === 'string' ? args : \"Unknown error\");\n    \n    const location = line !== undefined ? ` (${line}:${col})` : \"\";\n    const tagInfo = tagName ? `\\n  at <${tagName}>` : \"\";\n    const link = isDev\n      ? `\\n\\nSee: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(\".\", \"\")}`\n      : \"\";\n\n    super(`[${code}] ${message}${location}${tagInfo}${link}`);\n    this.name = \"KasperError\";\n  }\n\n  public withTag(tagName: string): this {\n    if (!this.tagName) {\n      this.tagName = tagName;\n      this.message += `\\n  at <${tagName}>`;\n    }\n    return this;\n  }\n}\n","import { KasperError, KErrorCode } from \"./types/error\";\n\ntype Listener = () => void;\n\nlet activeEffect: { fn: Listener; deps: Set<any> } | null = null;\nconst effectStack: any[] = [];\n\nlet batching = false;\nconst pendingSubscribers = new Set<Listener>();\nconst pendingWatchers: Array<() => void> = [];\n\ntype Watcher<T> = (newValue: T, oldValue: T) => void;\n\nexport interface SignalOptions {\n  signal?: AbortSignal;\n}\n\nexport class Signal<T> {\n  protected _value: T;\n  private subscribers = new Set<Listener>();\n  private watchers = new Set<Watcher<T>>();\n\n  constructor(initialValue: T) {\n    this._value = initialValue;\n  }\n\n  get value(): T {\n    if (activeEffect) {\n      this.subscribers.add(activeEffect.fn);\n      activeEffect.deps.add(this);\n    }\n    return this._value;\n  }\n\n  set value(newValue: T) {\n    if (this._value !== newValue) {\n      const oldValue = this._value;\n      this._value = newValue;\n      if (batching) {\n        for (const sub of this.subscribers) pendingSubscribers.add(sub);\n        for (const watcher of this.watchers) pendingWatchers.push(() => watcher(newValue, oldValue));\n      } else {\n        const subs = Array.from(this.subscribers);\n        for (const sub of subs) {\n          sub();\n        }\n        for (const watcher of this.watchers) {\n          try { watcher(newValue, oldValue); } catch (e) { console.error(\"Watcher error:\", e); }\n        }\n      }\n    }\n  }\n\n  onChange(fn: Watcher<T>, options?: SignalOptions): () => void {\n    if (options?.signal?.aborted) return () => {};\n    this.watchers.add(fn);\n    const stop = () => this.watchers.delete(fn);\n    if (options?.signal) {\n      options.signal.addEventListener(\"abort\", stop, { once: true });\n    }\n    return stop;\n  }\n\n  unsubscribe(fn: Listener) {\n    this.subscribers.delete(fn);\n  }\n\n  toString() { return String(this.value); }\n  peek() { return this._value; }\n}\n\nclass ComputedSignal<T> extends Signal<T> {\n  private fn: () => T;\n  private computing = false;\n\n  constructor(fn: () => T, options?: SignalOptions) {\n    super(undefined as any);\n    this.fn = fn;\n\n    const stop = effect(() => {\n      if (this.computing) {\n        throw new KasperError(KErrorCode.CIRCULAR_COMPUTED);\n      }\n\n      this.computing = true;\n      try {\n        // Eagerly update the value so subscribers are notified immediately\n        super.value = this.fn();\n      } finally {\n        this.computing = false;\n      }\n    }, options);\n\n    if (options?.signal) {\n      options.signal.addEventListener(\"abort\", stop, { once: true });\n    }\n  }\n\n  get value(): T {\n    return super.value;\n  }\n\n  set value(_v: T) {\n    // Computed signals are read-only from outside\n  }\n}\n\nexport function effect(fn: Listener, options?: SignalOptions) {\n  if (options?.signal?.aborted) return () => {};\n  const effectObj = {\n    fn: () => {\n      effectObj.deps.forEach(sig => sig.unsubscribe(effectObj.fn));\n      effectObj.deps.clear();\n\n      effectStack.push(effectObj);\n      activeEffect = effectObj;\n      try {\n        fn();\n      } finally {\n        effectStack.pop();\n        activeEffect = effectStack[effectStack.length - 1] || null;\n      }\n    },\n    deps: new Set<Signal<any>>()\n  };\n\n  effectObj.fn();\n  const stop: any = () => {\n    effectObj.deps.forEach(sig => sig.unsubscribe(effectObj.fn));\n    effectObj.deps.clear();\n  };\n  stop.run = effectObj.fn;\n\n  if (options?.signal) {\n    options.signal.addEventListener(\"abort\", stop, { once: true });\n  }\n\n  return stop as (() => void) & { run: () => void };\n}\n\nexport function signal<T>(initialValue: T): Signal<T> {\n  return new Signal(initialValue);\n}\n\n/**\n * Functional alias for Signal.onChange()\n */\nexport function watch<T>(sig: Signal<T>, fn: Watcher<T>, options?: SignalOptions): () => void {\n  return sig.onChange(fn, options);\n}\n\nexport function batch(fn: () => void): void {\n  batching = true;\n  try {\n    fn();\n  } finally {\n    batching = false;\n    const subs = Array.from(pendingSubscribers);\n    pendingSubscribers.clear();\n    const watchers = pendingWatchers.splice(0);\n    for (const sub of subs) {\n      sub();\n    }\n    for (const watcher of watchers) {\n      try { watcher(); } catch (e) { console.error(\"Watcher error:\", e); }\n    }\n  }\n}\n\nexport function computed<T>(fn: () => T, options?: SignalOptions): Signal<T> {\n  return new ComputedSignal(fn, options);\n}\n","import { Signal, effect as rawEffect, computed as rawComputed } from \"./signal\";\nimport { Transpiler } from \"./transpiler\";\nimport { KNode } from \"./types/nodes\";\n\ntype Watcher<T> = (newValue: T, oldValue: T) => void;\n\ninterface ComponentArgs<TArgs extends Record<string, any> = Record<string, any>> {\n  args: TArgs;\n  ref?: Node;\n  transpiler?: Transpiler;\n}\n\nexport class Component<TArgs extends Record<string, any> = Record<string, any>> {\n  static template?: string;\n  args: TArgs = {} as TArgs;\n  ref?: Node;\n  transpiler?: Transpiler;\n  $abortController = new AbortController();\n  $render?: () => void;\n\n  constructor(props?: ComponentArgs<TArgs>) {\n    if (!props) {\n      this.args = {} as TArgs;\n      return;\n    }\n    if (props.args) {\n      this.args = props.args;\n    }\n    if (props.ref) {\n      this.ref = props.ref;\n    }\n    if (props.transpiler) {\n      this.transpiler = props.transpiler;\n    }\n  }\n\n  /**\n   * Creates a reactive effect tied to the component's lifecycle.\n   * Runs immediately and re-runs when any signal dependency changes.\n   */\n  effect(fn: () => void): void {\n    rawEffect(fn, { signal: this.$abortController.signal });\n  }\n\n  /**\n   * Watches a specific signal for changes.\n   * Does NOT run immediately.\n   */\n  watch<T>(sig: Signal<T>, fn: Watcher<T>): void {\n    sig.onChange(fn, { signal: this.$abortController.signal });\n  }\n\n  /**\n   * Creates a computed signal tied to the component's lifecycle.\n   * The internal effect is automatically cleaned up when the component is destroyed.\n   */\n  computed<T>(fn: () => T): Signal<T> {\n    return rawComputed(fn, { signal: this.$abortController.signal });\n  }\n\n  onMount() { }\n  onRender() { }\n  onChanges() { }\n  onDestroy() { }\n\n  render() {\n    this.$render?.();\n  }\n}\n\nexport type KasperEntity = Component | Record<string, any> | null | undefined;\n\nexport type ComponentClass = { new(args?: ComponentArgs<any>): Component };\nexport interface ComponentRegistry {\n  [tagName: string]: {\n    component: ComponentClass | (() => Promise<ComponentClass>);\n    nodes?: KNode[];\n    lazy?: boolean;\n    fallback?: ComponentClass;\n  };\n}\n","import { Token, TokenType } from 'token';\n\nexport abstract class Expr {\n  public result: any;\n  public line: number;\n  // tslint:disable-next-line\n  constructor() { }\n  public abstract accept<R>(visitor: ExprVisitor<R>): R;\n}\n\n// tslint:disable-next-line\nexport interface ExprVisitor<R> {\n    visitArrowFunctionExpr(expr: ArrowFunction): R;\n    visitAssignExpr(expr: Assign): R;\n    visitBinaryExpr(expr: Binary): R;\n    visitCallExpr(expr: Call): R;\n    visitDebugExpr(expr: Debug): R;\n    visitDictionaryExpr(expr: Dictionary): R;\n    visitEachExpr(expr: Each): R;\n    visitGetExpr(expr: Get): R;\n    visitGroupingExpr(expr: Grouping): R;\n    visitKeyExpr(expr: Key): R;\n    visitLogicalExpr(expr: Logical): R;\n    visitListExpr(expr: List): R;\n    visitLiteralExpr(expr: Literal): R;\n    visitNewExpr(expr: New): R;\n    visitNullCoalescingExpr(expr: NullCoalescing): R;\n    visitPostfixExpr(expr: Postfix): R;\n    visitSetExpr(expr: Set): R;\n    visitPipelineExpr(expr: Pipeline): R;\n    visitSpreadExpr(expr: Spread): R;\n    visitTemplateExpr(expr: Template): R;\n    visitTernaryExpr(expr: Ternary): R;\n    visitTypeofExpr(expr: Typeof): R;\n    visitUnaryExpr(expr: Unary): R;\n    visitVariableExpr(expr: Variable): R;\n    visitVoidExpr(expr: Void): R;\n}\n\nexport class ArrowFunction extends Expr {\n    public params: Token[];\n    public body: Expr;\n\n    constructor(params: Token[], body: Expr, line: number) {\n        super();\n        this.params = params;\n        this.body = body;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitArrowFunctionExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.ArrowFunction';\n  }\n}\n\nexport class Assign extends Expr {\n    public name: Token;\n    public value: Expr;\n\n    constructor(name: Token, value: Expr, line: number) {\n        super();\n        this.name = name;\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitAssignExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Assign';\n  }\n}\n\nexport class Binary extends Expr {\n    public left: Expr;\n    public operator: Token;\n    public right: Expr;\n\n    constructor(left: Expr, operator: Token, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitBinaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Binary';\n  }\n}\n\nexport class Call extends Expr {\n    public callee: Expr;\n    public paren: Token;\n    public args: Expr[];\n    public optional: boolean;\n\n    constructor(callee: Expr, paren: Token, args: Expr[], line: number, optional = false) {\n        super();\n        this.callee = callee;\n        this.paren = paren;\n        this.args = args;\n        this.line = line;\n        this.optional = optional;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitCallExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Call';\n  }\n}\n\nexport class Debug extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitDebugExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Debug';\n  }\n}\n\nexport class Dictionary extends Expr {\n    public properties: Expr[];\n\n    constructor(properties: Expr[], line: number) {\n        super();\n        this.properties = properties;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitDictionaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Dictionary';\n  }\n}\n\nexport class Each extends Expr {\n    public name: Token;\n    public key: Token;\n    public iterable: Expr;\n\n    constructor(name: Token, key: Token, iterable: Expr, line: number) {\n        super();\n        this.name = name;\n        this.key = key;\n        this.iterable = iterable;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitEachExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Each';\n  }\n}\n\nexport class Get extends Expr {\n    public entity: Expr;\n    public key: Expr;\n    public type: TokenType;\n\n    constructor(entity: Expr, key: Expr, type: TokenType, line: number) {\n        super();\n        this.entity = entity;\n        this.key = key;\n        this.type = type;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitGetExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Get';\n  }\n}\n\nexport class Grouping extends Expr {\n    public expression: Expr;\n\n    constructor(expression: Expr, line: number) {\n        super();\n        this.expression = expression;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitGroupingExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Grouping';\n  }\n}\n\nexport class Key extends Expr {\n    public name: Token;\n\n    constructor(name: Token, line: number) {\n        super();\n        this.name = name;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitKeyExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Key';\n  }\n}\n\nexport class Logical extends Expr {\n    public left: Expr;\n    public operator: Token;\n    public right: Expr;\n\n    constructor(left: Expr, operator: Token, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitLogicalExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Logical';\n  }\n}\n\nexport class List extends Expr {\n    public value: Expr[];\n\n    constructor(value: Expr[], line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitListExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.List';\n  }\n}\n\nexport class Literal extends Expr {\n    public value: any;\n\n    constructor(value: any, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitLiteralExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Literal';\n  }\n}\n\nexport class New extends Expr {\n    public clazz: Expr;\n    public args: Expr[];\n\n    constructor(clazz: Expr, args: Expr[], line: number) {\n        super();\n        this.clazz = clazz;\n        this.args = args;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitNewExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.New';\n  }\n}\n\nexport class NullCoalescing extends Expr {\n    public left: Expr;\n    public right: Expr;\n\n    constructor(left: Expr, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitNullCoalescingExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.NullCoalescing';\n  }\n}\n\nexport class Postfix extends Expr {\n    public entity: Expr;\n    public increment: number;\n\n    constructor(entity: Expr, increment: number, line: number) {\n        super();\n        this.entity = entity;\n        this.increment = increment;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitPostfixExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Postfix';\n  }\n}\n\nexport class Set extends Expr {\n    public entity: Expr;\n    public key: Expr;\n    public value: Expr;\n\n    constructor(entity: Expr, key: Expr, value: Expr, line: number) {\n        super();\n        this.entity = entity;\n        this.key = key;\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitSetExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Set';\n  }\n}\n\nexport class Pipeline extends Expr {\n    public left: Expr;\n    public right: Expr;\n\n    constructor(left: Expr, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitPipelineExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Pipeline';\n  }\n}\n\nexport class Spread extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitSpreadExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Spread';\n  }\n}\n\nexport class Template extends Expr {\n    public value: string;\n\n    constructor(value: string, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTemplateExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Template';\n  }\n}\n\nexport class Ternary extends Expr {\n    public condition: Expr;\n    public thenExpr: Expr;\n    public elseExpr: Expr;\n\n    constructor(condition: Expr, thenExpr: Expr, elseExpr: Expr, line: number) {\n        super();\n        this.condition = condition;\n        this.thenExpr = thenExpr;\n        this.elseExpr = elseExpr;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTernaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Ternary';\n  }\n}\n\nexport class Typeof extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTypeofExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Typeof';\n  }\n}\n\nexport class Unary extends Expr {\n    public operator: Token;\n    public right: Expr;\n\n    constructor(operator: Token, right: Expr, line: number) {\n        super();\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitUnaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Unary';\n  }\n}\n\nexport class Variable extends Expr {\n    public name: Token;\n\n    constructor(name: Token, line: number) {\n        super();\n        this.name = name;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitVariableExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Variable';\n  }\n}\n\nexport class Void extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitVoidExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Void';\n  }\n}\n\n","export enum TokenType {\r\n  // Parser Tokens\r\n  Eof,\r\n  Panic,\r\n\r\n  // Single Character Tokens\r\n  Ampersand,\r\n  AtSign,\r\n  Caret,\r\n  Comma,\r\n  Dollar,\r\n  Dot,\r\n  Hash,\r\n  LeftBrace,\r\n  LeftBracket,\r\n  LeftParen,\r\n  Percent,\r\n  Pipe,\r\n  RightBrace,\r\n  RightBracket,\r\n  RightParen,\r\n  Semicolon,\r\n  Slash,\r\n  Star,\r\n\r\n  // One Or Two Character Tokens\r\n  Arrow,\r\n  Bang,\r\n  BangEqual,\r\n  BangEqualEqual,\r\n  Colon,\r\n  Equal,\r\n  EqualEqual,\r\n  EqualEqualEqual,\r\n  Greater,\r\n  GreaterEqual,\r\n  Less,\r\n  LessEqual,\r\n  Minus,\r\n  MinusEqual,\r\n  MinusMinus,\r\n  PercentEqual,\r\n  Plus,\r\n  PlusEqual,\r\n  PlusPlus,\r\n  Question,\r\n  QuestionDot,\r\n  QuestionQuestion,\r\n  SlashEqual,\r\n  StarEqual,\r\n  DotDot,\r\n  DotDotDot,\r\n  LessEqualGreater,\r\n\r\n  // Literals\r\n  Identifier,\r\n  Template,\r\n  String,\r\n  Number,\r\n\r\n  // One Or Two Character Tokens (bitwise shifts)\r\n  LeftShift,\r\n  RightShift,\r\n  Pipeline,\r\n  Tilde,\r\n\r\n  // Keywords\r\n  And,\r\n  Const,\r\n  Debug,\r\n  False,\r\n  In,\r\n  Instanceof,\r\n  New,\r\n  Null,\r\n  Undefined,\r\n  Of,\r\n  Or,\r\n  True,\r\n  Typeof,\r\n  Void,\r\n  With,\r\n}\r\n\r\nexport class Token {\r\n  public name: string;\r\n  public line: number;\r\n  public col: number;\r\n  public type: TokenType;\r\n  public literal: any;\r\n  public lexeme: string;\r\n\r\n  constructor(\r\n    type: TokenType,\r\n    lexeme: string,\r\n    literal: any,\r\n    line: number,\r\n    col: number\r\n  ) {\r\n    this.name = TokenType[type];\r\n    this.type = type;\r\n    this.lexeme = lexeme;\r\n    this.literal = literal;\r\n    this.line = line;\r\n    this.col = col;\r\n  }\r\n\r\n  public toString() {\r\n    return `[(${this.line}):\"${this.lexeme}\"]`;\r\n  }\r\n}\r\n\r\nexport const WhiteSpaces = [\" \", \"\\n\", \"\\t\", \"\\r\"] as const;\r\n\r\nexport const SelfClosingTags = [\r\n  \"area\",\r\n  \"base\",\r\n  \"br\",\r\n  \"col\",\r\n  \"embed\",\r\n  \"hr\",\r\n  \"img\",\r\n  \"input\",\r\n  \"link\",\r\n  \"meta\",\r\n  \"param\",\r\n  \"source\",\r\n  \"track\",\r\n  \"wbr\",\r\n];\r\n","import { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport * as Expr from \"./types/expressions\";\nimport { Token, TokenType } from \"./types/token\";\n\nexport class ExpressionParser {\n  private current: number;\n  private tokens: Token[];\n\n  public parse(tokens: Token[]): Expr.Expr[] {\n    this.current = 0;\n    this.tokens = tokens;\n    const expressions: Expr.Expr[] = [];\n    while (!this.eof()) {\n      expressions.push(this.expression());\n    }\n    return expressions;\n  }\n\n  private match(...types: TokenType[]): boolean {\n    for (const type of types) {\n      if (this.check(type)) {\n        this.advance();\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private advance(): Token {\n    if (!this.eof()) {\n      this.current++;\n    }\n    return this.previous();\n  }\n\n  private peek(): Token {\n    return this.tokens[this.current];\n  }\n\n  private previous(): Token {\n    return this.tokens[this.current - 1];\n  }\n\n  private check(type: TokenType): boolean {\n    return this.peek().type === type;\n  }\n\n  private eof(): boolean {\n    return this.check(TokenType.Eof);\n  }\n\n  private consume(type: TokenType, message: string): Token {\n    if (this.check(type)) {\n      return this.advance();\n    }\n\n    return this.error(\n      KErrorCode.UNEXPECTED_TOKEN,\n      this.peek(),\n      { message: message, token: this.peek().lexeme }\n    );\n  }\n\n  private error(code: KErrorCodeType, token: Token, args: any = {}): any {\n    throw new KasperError(code, args, token.line, token.col);\n  }\n\n  private synchronize(): void {\n    do {\n      if (this.check(TokenType.Semicolon) || this.check(TokenType.RightBrace)) {\n        this.advance();\n        return;\n      }\n      this.advance();\n    } while (!this.eof());\n  }\n\n  public foreach(tokens: Token[]): Expr.Expr {\n    this.current = 0;\n    this.tokens = tokens;\n\n    const name = this.consume(\n      TokenType.Identifier,\n      `Expected an identifier inside \"each\" statement`\n    );\n\n    let key: Token = null;\n    if (this.match(TokenType.With)) {\n      key = this.consume(\n        TokenType.Identifier,\n        `Expected a \"key\" identifier after \"with\" keyword in foreach statement`\n      );\n    }\n\n    this.consume(\n      TokenType.Of,\n      `Expected \"of\" keyword inside foreach statement`\n    );\n    const iterable = this.expression();\n\n    return new Expr.Each(name, key, iterable, name.line);\n  }\n\n  private expression(): Expr.Expr {\n    const expression: Expr.Expr = this.assignment();\n    if (this.match(TokenType.Semicolon)) {\n      // consume all semicolons\n      // tslint:disable-next-line\n      while (this.match(TokenType.Semicolon)) { /* consume semicolons */ }\n    }\n    return expression;\n  }\n\n  private assignment(): Expr.Expr {\n    const expr: Expr.Expr = this.pipeline();\n    if (\n      this.match(\n        TokenType.Equal,\n        TokenType.PlusEqual,\n        TokenType.MinusEqual,\n        TokenType.StarEqual,\n        TokenType.SlashEqual\n      )\n    ) {\n      const operator: Token = this.previous();\n      let value: Expr.Expr = this.assignment();\n      if (expr instanceof Expr.Variable) {\n        const name: Token = expr.name;\n        if (operator.type !== TokenType.Equal) {\n          value = new Expr.Binary(\n            new Expr.Variable(name, name.line),\n            operator,\n            value,\n            operator.line\n          );\n        }\n        return new Expr.Assign(name, value, name.line);\n      } else if (expr instanceof Expr.Get) {\n        if (operator.type !== TokenType.Equal) {\n          value = new Expr.Binary(\n            new Expr.Get(expr.entity, expr.key, expr.type, expr.line),\n            operator,\n            value,\n            operator.line\n          );\n        }\n        return new Expr.Set(expr.entity, expr.key, value, expr.line);\n      }\n      this.error(KErrorCode.INVALID_LVALUE, operator);\n    }\n    return expr;\n  }\n\n  private pipeline(): Expr.Expr {\n    let expr = this.ternary();\n    while (this.match(TokenType.Pipeline)) {\n      const right = this.ternary();\n      expr = new Expr.Pipeline(expr, right, expr.line);\n    }\n    return expr;\n  }\n\n  private ternary(): Expr.Expr {\n    const expr = this.nullCoalescing();\n    if (this.match(TokenType.Question)) {\n      const thenExpr: Expr.Expr = this.ternary();\n      this.consume(TokenType.Colon, `Expected \":\" after ternary ? expression`);\n      const elseExpr: Expr.Expr = this.ternary();\n      return new Expr.Ternary(expr, thenExpr, elseExpr, expr.line);\n    }\n    return expr;\n  }\n\n  private nullCoalescing(): Expr.Expr {\n    const expr = this.logicalOr();\n    if (this.match(TokenType.QuestionQuestion)) {\n      const rightExpr: Expr.Expr = this.nullCoalescing();\n      return new Expr.NullCoalescing(expr, rightExpr, expr.line);\n    }\n    return expr;\n  }\n\n  private logicalOr(): Expr.Expr {\n    let expr = this.logicalAnd();\n    while (this.match(TokenType.Or)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.logicalAnd();\n      expr = new Expr.Logical(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private logicalAnd(): Expr.Expr {\n    let expr = this.equality();\n    while (this.match(TokenType.And)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.equality();\n      expr = new Expr.Logical(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private equality(): Expr.Expr {\n    let expr: Expr.Expr = this.shift();\n    while (\n      this.match(\n        TokenType.BangEqual,\n        TokenType.BangEqualEqual,\n        TokenType.EqualEqual,\n        TokenType.EqualEqualEqual,\n        TokenType.Greater,\n        TokenType.GreaterEqual,\n        TokenType.Less,\n        TokenType.LessEqual,\n        TokenType.Instanceof,\n        TokenType.In,\n      )\n    ) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.shift();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private shift(): Expr.Expr {\n    let expr: Expr.Expr = this.addition();\n    while (this.match(TokenType.LeftShift, TokenType.RightShift)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.addition();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private addition(): Expr.Expr {\n    let expr: Expr.Expr = this.modulus();\n    while (this.match(TokenType.Minus, TokenType.Plus)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.modulus();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private modulus(): Expr.Expr {\n    let expr: Expr.Expr = this.multiplication();\n    while (this.match(TokenType.Percent)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.multiplication();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private multiplication(): Expr.Expr {\n    let expr: Expr.Expr = this.typeof();\n    while (this.match(TokenType.Slash, TokenType.Star)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.typeof();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private typeof(): Expr.Expr {\n    if (this.match(TokenType.Typeof)) {\n      const operator: Token = this.previous();\n      const value: Expr.Expr = this.typeof();\n      return new Expr.Typeof(value, operator.line);\n    }\n    return this.unary();\n  }\n\n  private unary(): Expr.Expr {\n    if (\n      this.match(\n        TokenType.Minus,\n        TokenType.Bang,\n        TokenType.Tilde,\n        TokenType.Dollar,\n        TokenType.PlusPlus,\n        TokenType.MinusMinus\n      )\n    ) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.unary();\n      return new Expr.Unary(operator, right, operator.line);\n    }\n    return this.newKeyword();\n  }\n\n  private newKeyword(): Expr.Expr {\n    if (this.match(TokenType.New)) {\n      const keyword = this.previous();\n      const construct: Expr.Expr = this.call();\n      if (construct instanceof Expr.Call) {\n        return new Expr.New(construct.callee, construct.args, keyword.line);\n      }\n      return new Expr.New(construct, [], keyword.line);\n    }\n    return this.postfix();\n  }\n\n  private postfix(): Expr.Expr {\n    const expr = this.call();\n    if (this.match(TokenType.PlusPlus)) {\n      return new Expr.Postfix(expr, 1, expr.line);\n    }\n    if (this.match(TokenType.MinusMinus)) {\n      return new Expr.Postfix(expr, -1, expr.line);\n    }\n    return expr;\n  }\n\n  private call(): Expr.Expr {\n    let expr: Expr.Expr = this.primary();\n    let consumed: boolean;\n    do {\n      consumed = false;\n      if (this.match(TokenType.LeftParen)) {\n        consumed = true;\n        do {\n          expr = this.finishCall(expr, this.previous(), false);\n        } while (this.match(TokenType.LeftParen));\n      }\n      if (this.match(TokenType.Dot, TokenType.QuestionDot)) {\n        consumed = true;\n        const operator = this.previous();\n        if (operator.type === TokenType.QuestionDot && this.match(TokenType.LeftBracket)) {\n          expr = this.bracketGet(expr, operator);\n        } else if (operator.type === TokenType.QuestionDot && this.match(TokenType.LeftParen)) {\n          expr = this.finishCall(expr, this.previous(), true);\n        } else {\n          expr = this.dotGet(expr, operator);\n        }\n      }\n      if (this.match(TokenType.LeftBracket)) {\n        consumed = true;\n        expr = this.bracketGet(expr, this.previous());\n      }\n    } while (consumed);\n    return expr;\n  }\n\n  private tokenAt(offset: number): TokenType {\n    return this.tokens[this.current + offset]?.type;\n  }\n\n  private isArrowParams(): boolean {\n    let i = this.current + 1; // skip (\n    if (this.tokens[i]?.type === TokenType.RightParen) {\n      return this.tokens[i + 1]?.type === TokenType.Arrow;\n    }\n    while (i < this.tokens.length) {\n      if (this.tokens[i]?.type !== TokenType.Identifier) return false;\n      i++;\n      if (this.tokens[i]?.type === TokenType.RightParen) {\n        return this.tokens[i + 1]?.type === TokenType.Arrow;\n      }\n      if (this.tokens[i]?.type !== TokenType.Comma) return false;\n      i++;\n    }\n    return false;\n  }\n\n  private finishCall(callee: Expr.Expr, paren: Token, optional: boolean): Expr.Expr {\n    const args: Expr.Expr[] = [];\n    if (!this.check(TokenType.RightParen)) {\n      do {\n        if (this.match(TokenType.DotDotDot)) {\n          args.push(new Expr.Spread(this.expression(), this.previous().line));\n        } else {\n          args.push(this.expression());\n        }\n      } while (this.match(TokenType.Comma));\n    }\n    const closeParen = this.consume(TokenType.RightParen, `Expected \")\" after arguments`);\n    return new Expr.Call(callee, closeParen, args, closeParen.line, optional);\n  }\n\n  private dotGet(expr: Expr.Expr, operator: Token): Expr.Expr {\n    const name: Token = this.consume(\n      TokenType.Identifier,\n      `Expect property name after '.'`\n    );\n    const key: Expr.Key = new Expr.Key(name, name.line);\n    return new Expr.Get(expr, key, operator.type, name.line);\n  }\n\n  private bracketGet(expr: Expr.Expr, operator: Token): Expr.Expr {\n    let key: Expr.Expr = null;\n\n    if (!this.check(TokenType.RightBracket)) {\n      key = this.expression();\n    }\n\n    this.consume(TokenType.RightBracket, `Expected \"]\" after an index`);\n    return new Expr.Get(expr, key, operator.type, operator.line);\n  }\n\n  private primary(): Expr.Expr {\n    if (this.match(TokenType.False)) {\n      return new Expr.Literal(false, this.previous().line);\n    }\n    if (this.match(TokenType.True)) {\n      return new Expr.Literal(true, this.previous().line);\n    }\n    if (this.match(TokenType.Null)) {\n      return new Expr.Literal(null, this.previous().line);\n    }\n    if (this.match(TokenType.Undefined)) {\n      return new Expr.Literal(undefined, this.previous().line);\n    }\n    if (this.match(TokenType.Number) || this.match(TokenType.String)) {\n      return new Expr.Literal(this.previous().literal, this.previous().line);\n    }\n    if (this.match(TokenType.Template)) {\n      return new Expr.Template(this.previous().literal, this.previous().line);\n    }\n    if (this.check(TokenType.Identifier) && this.tokenAt(1) === TokenType.Arrow) {\n      const param = this.advance();\n      this.advance(); // consume =>\n      const body = this.expression();\n      return new Expr.ArrowFunction([param], body, param.line);\n    }\n    if (this.match(TokenType.Identifier)) {\n      const identifier = this.previous();\n      return new Expr.Variable(identifier, identifier.line);\n    }\n    if (this.check(TokenType.LeftParen) && this.isArrowParams()) {\n      this.advance(); // consume (\n      const params: Token[] = [];\n      if (!this.check(TokenType.RightParen)) {\n        do {\n          params.push(this.consume(TokenType.Identifier, \"Expected parameter name\"));\n        } while (this.match(TokenType.Comma));\n      }\n      this.consume(TokenType.RightParen, `Expected \")\"`);\n      this.consume(TokenType.Arrow, `Expected \"=>\"`);\n      const body = this.expression();\n      return new Expr.ArrowFunction(params, body, this.previous().line);\n    }\n    if (this.match(TokenType.LeftParen)) {\n      const expr: Expr.Expr = this.expression();\n      this.consume(TokenType.RightParen, `Expected \")\" after expression`);\n      return new Expr.Grouping(expr, expr.line);\n    }\n    if (this.match(TokenType.LeftBrace)) {\n      return this.dictionary();\n    }\n    if (this.match(TokenType.LeftBracket)) {\n      return this.list();\n    }\n    if (this.match(TokenType.Void)) {\n      const expr: Expr.Expr = this.expression();\n      return new Expr.Void(expr, this.previous().line);\n    }\n    if (this.match(TokenType.Debug)) {\n      const expr: Expr.Expr = this.expression();\n      return new Expr.Debug(expr, this.previous().line);\n    }\n\n    throw this.error(\n      KErrorCode.EXPECTED_EXPRESSION,\n      this.peek(),\n      { token: this.peek().lexeme }\n    );\n    // unreacheable code\n    return new Expr.Literal(null, 0);\n  }\n\n  public dictionary(): Expr.Expr {\n    const leftBrace = this.previous();\n    if (this.match(TokenType.RightBrace)) {\n      return new Expr.Dictionary([], this.previous().line);\n    }\n    const properties: Expr.Expr[] = [];\n    do {\n      if (this.match(TokenType.DotDotDot)) {\n        properties.push(new Expr.Spread(this.expression(), this.previous().line));\n      } else if (\n        this.match(TokenType.String, TokenType.Identifier, TokenType.Number)\n      ) {\n        const key: Token = this.previous();\n        if (this.match(TokenType.Colon)) {\n          const value = this.expression();\n          properties.push(\n            new Expr.Set(null, new Expr.Key(key, key.line), value, key.line)\n          );\n        } else {\n          const value = new Expr.Variable(key, key.line);\n          properties.push(\n            new Expr.Set(null, new Expr.Key(key, key.line), value, key.line)\n          );\n        }\n      } else {\n        this.error(\n          KErrorCode.INVALID_DICTIONARY_KEY,\n          this.peek(),\n          { token: this.peek().lexeme }\n        );\n      }\n    } while (this.match(TokenType.Comma));\n    this.consume(TokenType.RightBrace, `Expected \"}\" after object literal`);\n\n    return new Expr.Dictionary(properties, leftBrace.line);\n  }\n\n  private list(): Expr.Expr {\n    const values: Expr.Expr[] = [];\n    const leftBracket = this.previous();\n\n    if (this.match(TokenType.RightBracket)) {\n      return new Expr.List([], this.previous().line);\n    }\n    do {\n      if (this.match(TokenType.DotDotDot)) {\n        values.push(new Expr.Spread(this.expression(), this.previous().line));\n      } else {\n        values.push(this.expression());\n      }\n    } while (this.match(TokenType.Comma));\n\n    this.consume(\n      TokenType.RightBracket,\n      `Expected \"]\" after array declaration`\n    );\n    return new Expr.List(values, leftBracket.line);\n  }\n}\n","import { TokenType } from \"./types/token\";\n\nexport function isDigit(char: string): boolean {\n  return char >= \"0\" && char <= \"9\";\n}\n\nexport function isAlpha(char: string): boolean {\n  return (\n    (char >= \"a\" && char <= \"z\") || (char >= \"A\" && char <= \"Z\") || char === \"$\" || char === \"_\"\n  );\n}\n\nexport function isAlphaNumeric(char: string): boolean {\n  return isAlpha(char) || isDigit(char);\n}\n\nexport function capitalize(word: string): string {\n  return word.charAt(0).toUpperCase() + word.substring(1).toLowerCase();\n}\n\nexport function isKeyword(word: keyof typeof TokenType): boolean {\n  return TokenType[word] >= TokenType.And;\n}\n","import * as Utils from \"./utils\";\nimport { Token, TokenType } from \"./types/token\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\n\nexport class Scanner {\n  /** scripts source code */\n  public source: string;\n  /** contains the source code represented as list of tokens */\n  public tokens: Token[];\n  /** points to the current character being tokenized */\n  private current: number;\n  /** points to the start of the token  */\n  private start: number;\n  /** current line of source code being tokenized */\n  private line: number;\n  /** current column of the character being tokenized */\n  private col: number;\n\n  public scan(source: string): Token[] {\n    this.source = source;\n    this.tokens = [];\n    this.current = 0;\n    this.start = 0;\n    this.line = 1;\n    this.col = 1;\n\n    while (!this.eof()) {\n      this.start = this.current;\n      this.getToken();\n    }\n    this.tokens.push(new Token(TokenType.Eof, \"\", null, this.line, 0));\n    return this.tokens;\n  }\n\n  private eof(): boolean {\n    return this.current >= this.source.length;\n  }\n\n  private advance(): string {\n    if (this.peek() === \"\\n\") {\n      this.line++;\n      this.col = 0;\n    }\n    this.current++;\n    this.col++;\n    return this.source.charAt(this.current - 1);\n  }\n\n  private addToken(tokenType: TokenType, literal: any): void {\n    const text = this.source.substring(this.start, this.current);\n    this.tokens.push(new Token(tokenType, text, literal, this.line, this.col));\n  }\n\n  private match(expected: string): boolean {\n    if (this.eof()) {\n      return false;\n    }\n\n    if (this.source.charAt(this.current) !== expected) {\n      return false;\n    }\n\n    this.current++;\n    return true;\n  }\n\n  private peek(): string {\n    if (this.eof()) {\n      return \"\\0\";\n    }\n    return this.source.charAt(this.current);\n  }\n\n  private peekNext(): string {\n    if (this.current + 1 >= this.source.length) {\n      return \"\\0\";\n    }\n    return this.source.charAt(this.current + 1);\n  }\n\n  private comment(): void {\n    while (this.peek() !== \"\\n\" && !this.eof()) {\n      this.advance();\n    }\n  }\n\n  private multilineComment(): void {\n    while (!this.eof() && !(this.peek() === \"*\" && this.peekNext() === \"/\")) {\n      this.advance();\n    }\n    if (this.eof()) {\n      this.error(KErrorCode.UNTERMINATED_COMMENT);\n    } else {\n      // the closing slash '*/'\n      this.advance();\n      this.advance();\n    }\n  }\n\n  private string(quote: string): void {\n    while (this.peek() !== quote && !this.eof()) {\n      this.advance();\n    }\n\n    // Unterminated string.\n    if (this.eof()) {\n      this.error(KErrorCode.UNTERMINATED_STRING, { quote: quote });\n      return;\n    }\n\n    // The closing \".\n    this.advance();\n\n    // Trim the surrounding quotes.\n    const value = this.source.substring(this.start + 1, this.current - 1);\n    this.addToken(quote !== \"`\" ? TokenType.String : TokenType.Template, value);\n  }\n\n  private number(): void {\n    // gets integer part\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    // checks for fraction\n    if (this.peek() === \".\" && Utils.isDigit(this.peekNext())) {\n      this.advance();\n    }\n\n    // gets fraction part\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    // checks for exponent\n    if (this.peek().toLowerCase() === \"e\") {\n      this.advance();\n      if (this.peek() === \"-\" || this.peek() === \"+\") {\n        this.advance();\n      }\n    }\n\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    const value = this.source.substring(this.start, this.current);\n    this.addToken(TokenType.Number, Number(value));\n  }\n\n  private identifier(): void {\n    while (Utils.isAlphaNumeric(this.peek())) {\n      this.advance();\n    }\n\n    const value = this.source.substring(this.start, this.current);\n    const capitalized = Utils.capitalize(value) as keyof typeof TokenType;\n    if (Utils.isKeyword(capitalized)) {\n      this.addToken(TokenType[capitalized], value);\n    } else {\n      this.addToken(TokenType.Identifier, value);\n    }\n  }\n\n  private getToken(): void {\n    const char = this.advance();\n    switch (char) {\n      case \"(\":\n        this.addToken(TokenType.LeftParen, null);\n        break;\n      case \")\":\n        this.addToken(TokenType.RightParen, null);\n        break;\n      case \"[\":\n        this.addToken(TokenType.LeftBracket, null);\n        break;\n      case \"]\":\n        this.addToken(TokenType.RightBracket, null);\n        break;\n      case \"{\":\n        this.addToken(TokenType.LeftBrace, null);\n        break;\n      case \"}\":\n        this.addToken(TokenType.RightBrace, null);\n        break;\n      case \",\":\n        this.addToken(TokenType.Comma, null);\n        break;\n      case \";\":\n        this.addToken(TokenType.Semicolon, null);\n        break;\n      case \"~\":\n        this.addToken(TokenType.Tilde, null);\n        break;\n      case \"^\":\n        this.addToken(TokenType.Caret, null);\n        break;\n      case \"#\":\n        this.addToken(TokenType.Hash, null);\n        break;\n      case \":\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.Arrow : TokenType.Colon,\n          null\n        );\n        break;\n      case \"*\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.StarEqual : TokenType.Star,\n          null\n        );\n        break;\n      case \"%\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.PercentEqual : TokenType.Percent,\n          null\n        );\n        break;\n      case \"|\":\n        this.addToken(\n          this.match(\"|\") ? TokenType.Or :\n          this.match(\">\") ? TokenType.Pipeline :\n          TokenType.Pipe,\n          null\n        );\n        break;\n      case \"&\":\n        this.addToken(\n          this.match(\"&\") ? TokenType.And : TokenType.Ampersand,\n          null\n        );\n        break;\n      case \">\":\n        this.addToken(\n          this.match(\">\") ? TokenType.RightShift :\n          this.match(\"=\") ? TokenType.GreaterEqual : TokenType.Greater,\n          null\n        );\n        break;\n      case \"!\":\n        this.addToken(\n          this.match(\"=\")\n            ? this.match(\"=\") ? TokenType.BangEqualEqual : TokenType.BangEqual\n            : TokenType.Bang,\n          null\n        );\n        break;\n      case \"?\":\n        this.addToken(\n          this.match(\"?\")\n            ? TokenType.QuestionQuestion\n            : this.match(\".\")\n            ? TokenType.QuestionDot\n            : TokenType.Question,\n          null\n        );\n        break;\n      case \"=\":\n        if (this.match(\"=\")) {\n          this.addToken(\n            this.match(\"=\") ? TokenType.EqualEqualEqual : TokenType.EqualEqual,\n            null\n          );\n          break;\n        }\n        this.addToken(\n          this.match(\">\") ? TokenType.Arrow : TokenType.Equal,\n          null\n        );\n        break;\n      case \"+\":\n        this.addToken(\n          this.match(\"+\")\n            ? TokenType.PlusPlus\n            : this.match(\"=\")\n            ? TokenType.PlusEqual\n            : TokenType.Plus,\n          null\n        );\n        break;\n      case \"-\":\n        this.addToken(\n          this.match(\"-\")\n            ? TokenType.MinusMinus\n            : this.match(\"=\")\n            ? TokenType.MinusEqual\n            : TokenType.Minus,\n          null\n        );\n        break;\n      case \"<\":\n        this.addToken(\n          this.match(\"<\") ? TokenType.LeftShift :\n          this.match(\"=\")\n            ? this.match(\">\")\n              ? TokenType.LessEqualGreater\n              : TokenType.LessEqual\n            : TokenType.Less,\n          null\n        );\n        break;\n      case \".\":\n        if (this.match(\".\")) {\n          if (this.match(\".\")) {\n            this.addToken(TokenType.DotDotDot, null);\n          } else {\n            this.addToken(TokenType.DotDot, null);\n          }\n        } else {\n          this.addToken(TokenType.Dot, null);\n        }\n        break;\n      case \"/\":\n        if (this.match(\"/\")) {\n          this.comment();\n        } else if (this.match(\"*\")) {\n          this.multilineComment();\n        } else {\n          this.addToken(\n            this.match(\"=\") ? TokenType.SlashEqual : TokenType.Slash,\n            null\n          );\n        }\n        break;\n      case `'`:\n      case `\"`:\n      case \"`\":\n        this.string(char);\n        break;\n      // ignore cases\n      case \"\\n\":\n      case \" \":\n      case \"\\r\":\n      case \"\\t\":\n        break;\n      // complex cases\n      default:\n        if (Utils.isDigit(char)) {\n          this.number();\n        } else if (Utils.isAlpha(char)) {\n          this.identifier();\n        } else {\n          this.error(KErrorCode.UNEXPECTED_CHARACTER, { char: char });\n        }\n        break;\n    }\n  }\n\n  private error(code: KErrorCodeType, args: any = {}): void {\n    throw new KasperError(code, args, this.line, this.col);\n  }\n}\n","export class Scope {\n  public values: Record<string, any>;\n  public parent: Scope;\n\n  constructor(parent?: Scope, entity?: Record<string, any>) {\n    this.parent = parent ? parent : null;\n    this.values = entity ? entity : {};\n  }\n\n  public init(entity?: Record<string, any>): void {\n    this.values = entity ? entity : {};\n  }\n\n  public set(name: string, value: any) {\n    this.values[name] = value;\n  }\n\n  public get(key: string): any {\n    if (typeof this.values[key] !== \"undefined\") {\n      return this.values[key];\n    }\n\n    const $imports = (this.values?.constructor as any)?.$imports;\n    if ($imports && typeof $imports[key] !== \"undefined\") {\n      return $imports[key];\n    }\n\n    if (this.parent !== null) {\n      return this.parent.get(key);\n    }\n\n    return window[key as keyof typeof window];\n  }\n}\n","import * as Expr from \"./types/expressions\";\nimport { Scanner } from \"./scanner\";\nimport { ExpressionParser as Parser } from \"./expression-parser\";\nimport { Scope } from \"./scope\";\nimport { TokenType } from \"./types/token\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\n\nexport class Interpreter implements Expr.ExprVisitor<any> {\n  public scope = new Scope();\n  private scanner = new Scanner();\n  private parser = new Parser();\n\n  public evaluate(expr: Expr.Expr): any {\n    return (expr.result = expr.accept(this));\n  }\n\n  public visitPipelineExpr(expr: Expr.Pipeline): any {\n    const value = this.evaluate(expr.left);\n\n    if (expr.right instanceof Expr.Call) {\n      const callee = this.evaluate(expr.right.callee);\n      const args = [value];\n      for (const arg of expr.right.args) {\n        if (arg instanceof Expr.Spread) {\n          args.push(...this.evaluate((arg as Expr.Spread).value));\n        } else {\n          args.push(this.evaluate(arg));\n        }\n      }\n      if (expr.right.callee instanceof Expr.Get) {\n        return callee.apply(expr.right.callee.entity.result, args);\n      }\n      return callee(...args);\n    }\n\n    const fn = this.evaluate(expr.right);\n    return fn(value);\n  }\n\n  public visitArrowFunctionExpr(expr: Expr.ArrowFunction): any {\n    const capturedScope = this.scope;\n    return (...args: any[]) => {\n      const prev = this.scope;\n      this.scope = new Scope(capturedScope);\n      for (let i = 0; i < expr.params.length; i++) {\n        this.scope.set(expr.params[i].lexeme, args[i]);\n      }\n      try {\n        return this.evaluate(expr.body);\n      } finally {\n        this.scope = prev;\n      }\n    };\n  }\n\n  public error(code: KErrorCodeType, args: any = {}, line?: number, col?: number): void {\n    throw new KasperError(code, args, line, col);\n  }\n\n  public visitVariableExpr(expr: Expr.Variable): any {\n    return this.scope.get(expr.name.lexeme);\n  }\n\n  public visitAssignExpr(expr: Expr.Assign): any {\n    const value = this.evaluate(expr.value);\n    this.scope.set(expr.name.lexeme, value);\n    return value;\n  }\n\n  public visitKeyExpr(expr: Expr.Key): any {\n    return expr.name.literal;\n  }\n\n  public visitGetExpr(expr: Expr.Get): any {\n    const entity = this.evaluate(expr.entity);\n    const key = this.evaluate(expr.key);\n    if (!entity && expr.type === TokenType.QuestionDot) {\n      return undefined;\n    }\n    return entity[key];\n  }\n\n  public visitSetExpr(expr: Expr.Set): any {\n    const entity = this.evaluate(expr.entity);\n    const key = this.evaluate(expr.key);\n    const value = this.evaluate(expr.value);\n    entity[key] = value;\n    return value;\n  }\n\n  public visitPostfixExpr(expr: Expr.Postfix): any {\n    const value = this.evaluate(expr.entity);\n    const newValue = value + expr.increment;\n\n    if (expr.entity instanceof Expr.Variable) {\n      this.scope.set(expr.entity.name.lexeme, newValue);\n    } else if (expr.entity instanceof Expr.Get) {\n      const assign = new Expr.Set(\n        expr.entity.entity,\n        expr.entity.key,\n        new Expr.Literal(newValue, expr.line),\n        expr.line\n      );\n      this.evaluate(assign);\n    } else {\n      this.error(KErrorCode.INVALID_POSTFIX_LVALUE, { entity: expr.entity }, expr.line);\n    }\n\n    return value;\n  }\n\n  public visitListExpr(expr: Expr.List): any {\n    const values: any[] = [];\n    for (const expression of expr.value) {\n      if (expression instanceof Expr.Spread) {\n        values.push(...this.evaluate((expression as Expr.Spread).value));\n      } else {\n        values.push(this.evaluate(expression));\n      }\n    }\n    return values;\n  }\n\n  public visitSpreadExpr(expr: Expr.Spread): any {\n    return this.evaluate(expr.value);\n  }\n\n  private templateParse(source: string): string {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens);\n    let result = \"\";\n    for (const expression of expressions) {\n      result += this.evaluate(expression).toString();\n    }\n    return result;\n  }\n\n  public visitTemplateExpr(expr: Expr.Template): any {\n    const result = expr.value.replace(\n      /\\{\\{([\\s\\S]+?)\\}\\}/g,\n      (m, placeholder) => {\n        return this.templateParse(placeholder);\n      }\n    );\n    return result;\n  }\n\n  public visitBinaryExpr(expr: Expr.Binary): any {\n    const left = this.evaluate(expr.left);\n    const right = this.evaluate(expr.right);\n\n    switch (expr.operator.type) {\n      case TokenType.Minus:\n      case TokenType.MinusEqual:\n        return left - right;\n      case TokenType.Slash:\n      case TokenType.SlashEqual:\n        return left / right;\n      case TokenType.Star:\n      case TokenType.StarEqual:\n        return left * right;\n      case TokenType.Percent:\n      case TokenType.PercentEqual:\n        return left % right;\n      case TokenType.Plus:\n      case TokenType.PlusEqual:\n        return left + right;\n      case TokenType.Pipe:\n        return left | right;\n      case TokenType.Caret:\n        return left ^ right;\n      case TokenType.Greater:\n        return left > right;\n      case TokenType.GreaterEqual:\n        return left >= right;\n      case TokenType.Less:\n        return left < right;\n      case TokenType.LessEqual:\n        return left <= right;\n      case TokenType.EqualEqual:\n      case TokenType.EqualEqualEqual:\n        return left === right;\n      case TokenType.BangEqual:\n      case TokenType.BangEqualEqual:\n        return left !== right;\n      case TokenType.Instanceof:\n        return left instanceof right;\n      case TokenType.In:\n        return left in right;\n      case TokenType.LeftShift:\n        return left << right;\n      case TokenType.RightShift:\n        return left >> right;\n      default:\n        this.error(KErrorCode.UNKNOWN_BINARY_OPERATOR, { operator: expr.operator }, expr.line);\n        return null; // unreachable\n    }\n  }\n\n  public visitLogicalExpr(expr: Expr.Logical): any {\n    const left = this.evaluate(expr.left);\n\n    if (expr.operator.type === TokenType.Or) {\n      if (left) {\n        return left;\n      }\n    } else {\n      if (!left) {\n        return left;\n      }\n    }\n\n    return this.evaluate(expr.right);\n  }\n\n  public visitTernaryExpr(expr: Expr.Ternary): any {\n    return this.evaluate(expr.condition)\n      ? this.evaluate(expr.thenExpr)\n      : this.evaluate(expr.elseExpr);\n  }\n\n  public visitNullCoalescingExpr(expr: Expr.NullCoalescing): any {\n    const left = this.evaluate(expr.left);\n    if (left == null) {\n      return this.evaluate(expr.right);\n    }\n    return left;\n  }\n\n  public visitGroupingExpr(expr: Expr.Grouping): any {\n    return this.evaluate(expr.expression);\n  }\n\n  public visitLiteralExpr(expr: Expr.Literal): any {\n    return expr.value;\n  }\n\n  public visitUnaryExpr(expr: Expr.Unary): any {\n    const right = this.evaluate(expr.right);\n    switch (expr.operator.type) {\n      case TokenType.Minus:\n        return -right;\n      case TokenType.Bang:\n        return !right;\n      case TokenType.Tilde:\n        return ~right;\n      case TokenType.PlusPlus:\n      case TokenType.MinusMinus: {\n        const newValue =\n          Number(right) + (expr.operator.type === TokenType.PlusPlus ? 1 : -1);\n        if (expr.right instanceof Expr.Variable) {\n          this.scope.set(expr.right.name.lexeme, newValue);\n        } else if (expr.right instanceof Expr.Get) {\n          const assign = new Expr.Set(\n            expr.right.entity,\n            expr.right.key,\n            new Expr.Literal(newValue, expr.line),\n            expr.line\n          );\n          this.evaluate(assign);\n        } else {\n          this.error(\n            KErrorCode.INVALID_PREFIX_RVALUE,\n            { right: expr.right },\n            expr.line\n          );\n        }\n        return newValue;\n      }\n      default:\n        this.error(KErrorCode.UNKNOWN_UNARY_OPERATOR, { operator: expr.operator }, expr.line);\n        return null; // should be unreachable\n    }\n  }\n\n  public visitCallExpr(expr: Expr.Call): any {\n    // verify callee is a function\n    const callee = this.evaluate(expr.callee);\n    if (callee == null && expr.optional) return undefined;\n    if (typeof callee !== \"function\") {\n      this.error(KErrorCode.NOT_A_FUNCTION, { callee: callee }, expr.line);\n    }\n    // evaluate function arguments\n    const args = [];\n    for (const argument of expr.args) {\n      if (argument instanceof Expr.Spread) {\n        args.push(...this.evaluate((argument as Expr.Spread).value));\n      } else {\n        args.push(this.evaluate(argument));\n      }\n    }\n    // execute function — preserve `this` for method calls\n    if (expr.callee instanceof Expr.Get) {\n      return callee.apply(expr.callee.entity.result, args);\n    } else {\n      return callee(...args);\n    }\n  }\n\n  public visitNewExpr(expr: Expr.New): any {\n    const clazz = this.evaluate(expr.clazz);\n\n    if (typeof clazz !== \"function\") {\n      this.error(\n        KErrorCode.NOT_A_CLASS,\n        { clazz: clazz },\n        expr.line\n      );\n    }\n\n    const args: any[] = [];\n    for (const arg of expr.args) {\n      args.push(this.evaluate(arg));\n    }\n    return new clazz(...args);\n  }\n\n  public visitDictionaryExpr(expr: Expr.Dictionary): any {\n    const dict: any = {};\n    for (const property of expr.properties) {\n      if (property instanceof Expr.Spread) {\n        Object.assign(dict, this.evaluate((property as Expr.Spread).value));\n      } else {\n        const key = this.evaluate((property as Expr.Set).key);\n        const value = this.evaluate((property as Expr.Set).value);\n        dict[key] = value;\n      }\n    }\n    return dict;\n  }\n\n  public visitTypeofExpr(expr: Expr.Typeof): any {\n    return typeof this.evaluate(expr.value);\n  }\n\n  public visitEachExpr(expr: Expr.Each): any {\n    return [\n      expr.name.lexeme,\n      expr.key ? expr.key.lexeme : null,\n      this.evaluate(expr.iterable),\n    ];\n  }\n\n  visitVoidExpr(expr: Expr.Void): any {\n    this.evaluate(expr.value);\n    return \"\";\n  }\n\n  visitDebugExpr(expr: Expr.Void): any {\n    const result = this.evaluate(expr.value);\n    console.log(result);\n    return \"\";\n  }\n}\n","export abstract class KNode {\n    public line: number;\n    public type: string;\n    public abstract accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R;\n}\n\nexport interface KNodeVisitor<R> {\n    visitElementKNode(knode: Element, parent?: Node): R;\n    visitAttributeKNode(knode: Attribute, parent?: Node): R;\n    visitTextKNode(knode: Text, parent?: Node): R;\n    visitCommentKNode(knode: Comment, parent?: Node): R;\n    visitDoctypeKNode(knode: Doctype, parent?: Node): R;\n}\n\nexport class Element extends KNode {\n    public name: string;\n    public attributes: KNode[];\n    public children: KNode[];\n    public self: boolean;\n\n    constructor(name: string, attributes: KNode[], children: KNode[], self: boolean, line: number = 0) {\n        super();\n        this.type = 'element';\n        this.name = name;\n        this.attributes = attributes;\n        this.children = children;\n        this.self = self;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitElementKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Element';\n    }\n}\n\nexport class Attribute extends KNode {\n    public name: string;\n    public value: string;\n\n    constructor(name: string, value: string, line: number = 0) {\n        super();\n        this.type = 'attribute';\n        this.name = name;\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitAttributeKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Attribute';\n    }\n}\n\nexport class Text extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'text';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitTextKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Text';\n    }\n}\n\nexport class Comment extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'comment';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitCommentKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Comment';\n    }\n}\n\nexport class Doctype extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'doctype';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitDoctypeKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Doctype';\n    }\n}\n\n","import { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport * as Node from \"./types/nodes\";\nimport { SelfClosingTags, WhiteSpaces } from \"./types/token\";\n\nexport class TemplateParser {\n  public current: number;\n  public line: number;\n  public col: number;\n  public source: string;\n  public nodes: Node.KNode[];\n\n  public parse(source: string): Node.KNode[] {\n    this.current = 0;\n    this.line = 1;\n    this.col = 1;\n    this.source = source;\n    this.nodes = [];\n\n    while (!this.eof()) {\n      const node = this.node();\n      if (node === null) {\n        continue;\n      }\n      this.nodes.push(node);\n    }\n    this.source = \"\";\n    return this.nodes;\n  }\n\n  private match(...chars: string[]): boolean {\n    for (const char of chars) {\n      if (this.check(char)) {\n        this.current += char.length;\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private advance(eofError: string = \"\"): void {\n    if (!this.eof()) {\n      if (this.check(\"\\n\")) {\n        this.line += 1;\n        this.col = 0;\n      }\n      if (!this.eof()) {\n        this.current++;\n      } else {\n        this.error(KErrorCode.UNEXPECTED_EOF, { eofError: eofError });\n      }\n    }\n  }\n\n  private peek(...chars: string[]): boolean {\n    for (const char of chars) {\n      if (this.check(char)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private check(char: string): boolean {\n    return this.source.slice(this.current, this.current + char.length) === char;\n  }\n\n  private eof(): boolean {\n    return this.current > this.source.length;\n  }\n\n  private error(code: KErrorCodeType, args: any = {}): any {\n    throw new KasperError(code, args, this.line, this.col);\n  }\n\n  private node(): Node.KNode {\n    this.whitespace();\n    let node: Node.KNode;\n\n    if (this.match(\"</\")) {\n      this.error(KErrorCode.UNEXPECTED_CLOSING_TAG);\n    }\n\n    if (this.match(\"<!--\")) {\n      node = this.comment();\n    } else if (this.match(\"<!doctype\") || this.match(\"<!DOCTYPE\")) {\n      node = this.doctype();\n    } else if (this.match(\"<\")) {\n      node = this.element();\n    } else {\n      node = this.text();\n    }\n\n    this.whitespace();\n    return node;\n  }\n\n  private comment(): null {\n    do {\n      this.advance(\"Expected comment closing '-->'\");\n    } while (!this.match(`-->`));\n    return null;\n  }\n\n  private doctype(): Node.KNode {\n    const start = this.current;\n    do {\n      this.advance(\"Expected closing doctype\");\n    } while (!this.match(`>`));\n    const doctype = this.source.slice(start, this.current - 1).trim();\n    return new Node.Doctype(doctype, this.line);\n  }\n\n  private element(): Node.KNode {\n    const line = this.line;\n    const name = this.identifier(\"/\", \">\");\n    if (!name) {\n      this.error(KErrorCode.EXPECTED_TAG_NAME);\n    }\n\n    const attributes = this.attributes();\n\n    if (\n      this.match(\"/>\") ||\n      (SelfClosingTags.includes(name) && this.match(\">\"))\n    ) {\n      return new Node.Element(name, attributes, [], true, this.line);\n    }\n\n    if (!this.match(\">\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_BRACKET);\n    }\n\n    let children: Node.KNode[] = [];\n    this.whitespace();\n    if (!this.peek(\"</\")) {\n      children = this.children(name);\n    }\n\n    this.close(name);\n    return new Node.Element(name, attributes, children, false, line);\n  }\n\n  private close(name: string): void {\n    if (!this.match(\"</\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n    if (!this.match(`${name}`)) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n    this.whitespace();\n    if (!this.match(\">\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n  }\n\n  private children(parent: string): Node.KNode[] {\n    const children: Node.KNode[] = [];\n    do {\n      if (this.eof()) {\n        this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: parent });\n      }\n      const node = this.node();\n      if (node === null) {\n        continue;\n      }\n      children.push(node);\n    } while (!this.peek(`</`));\n\n    return children;\n  }\n\n  private attributes(): Node.Attribute[] {\n    const attributes: Node.Attribute[] = [];\n    while (!this.peek(\">\", \"/>\") && !this.eof()) {\n      this.whitespace();\n      const line = this.line;\n      const name = this.identifier(\"=\", \">\", \"/>\");\n      if (!name) {\n        this.error(KErrorCode.BLANK_ATTRIBUTE_NAME);\n      }\n      this.whitespace();\n      let value = \"\";\n      if (this.match(\"=\")) {\n        this.whitespace();\n        if (this.match(\"'\")) {\n          value = this.decodeEntities(this.string(\"'\"));\n        } else if (this.match('\"')) {\n          value = this.decodeEntities(this.string('\"'));\n        } else {\n          value = this.decodeEntities(this.identifier(\">\", \"/>\"));\n        }\n      }\n      this.whitespace();\n      attributes.push(new Node.Attribute(name, value, line));\n    }\n    return attributes;\n  }\n\n  private text(): Node.KNode {\n    const start = this.current;\n    const line = this.line;\n    let depth = 0;\n    while (!this.eof()) {\n      if (this.match(\"{{\")) { depth++; continue; }\n      if (depth > 0 && this.match(\"}}\")) { depth--; continue; }\n      if (depth === 0 && this.peek(\"<\")) { break; }\n      this.advance();\n    }\n    const raw = this.source.slice(start, this.current).trim();\n    if (!raw) {\n      return null;\n    }\n    return new Node.Text(this.decodeEntities(raw), line);\n  }\n\n  private decodeEntities(text: string): string {\n    return text\n      .replace(/&nbsp;/g, \"\\u00a0\")\n      .replace(/&lt;/g, \"<\")\n      .replace(/&gt;/g, \">\")\n      .replace(/&quot;/g, '\"')\n      .replace(/&apos;/g, \"'\")\n      .replace(/&amp;/g, \"&\"); // must be last to avoid double-decoding\n  }\n\n  private whitespace(): number {\n    let count = 0;\n    while (this.peek(...WhiteSpaces) && !this.eof()) {\n      count += 1;\n      this.advance();\n    }\n    return count;\n  }\n\n  private identifier(...closing: string[]): string {\n    this.whitespace();\n    const start = this.current;\n    while (!this.peek(...WhiteSpaces, ...closing)) {\n      this.advance(`Expected closing ${closing}`);\n    }\n    const end = this.current;\n    this.whitespace();\n    return this.source.slice(start, end).trim();\n  }\n\n  private string(closing: string): string {\n    const start = this.current;\n    while (!this.match(closing)) {\n      this.advance(`Expected closing ${closing}`);\n    }\n    return this.source.slice(start, this.current - 1);\n  }\n}\n","import { Component, ComponentClass } from \"./component\";\n\nexport interface RouteConfig {\n  path: string;\n  component: ComponentClass;\n  guard?: () => Promise<boolean>;\n}\n\nexport function navigate(path: string): void {\n  history.pushState(null, \"\", path);\n  window.dispatchEvent(new PopStateEvent(\"popstate\"));\n}\n\nexport function matchPath(pattern: string, pathname: string): Record<string, string> | null {\n  if (pattern === \"*\") return {};\n  const patternParts = pattern.split(\"/\").filter(Boolean);\n  const pathParts = pathname.split(\"/\").filter(Boolean);\n  if (patternParts.length !== pathParts.length) return null;\n  const params: Record<string, string> = {};\n  for (let i = 0; i < patternParts.length; i++) {\n    if (patternParts[i].startsWith(\":\")) {\n      params[patternParts[i].slice(1)] = pathParts[i];\n    } else if (patternParts[i] !== pathParts[i]) {\n      return null;\n    }\n  }\n  return params;\n}\n\nexport class Router extends Component {\n  private routes: RouteConfig[] = [];\n\n  setRoutes(routes: RouteConfig[]): void {\n    this.routes = routes;\n  }\n\n  onMount(): void {\n    window.addEventListener(\"popstate\", () => this._navigate(), {\n      signal: this.$abortController.signal,\n    });\n    this._navigate();\n  }\n\n  private async _navigate(): Promise<void> {\n    const pathname = window.location.pathname;\n    for (const route of this.routes) {\n      const params = matchPath(route.path, pathname);\n      if (params === null) continue;\n      if (route.guard) {\n        const allowed = await route.guard();\n        if (!allowed) return;\n      }\n      this._mount(route.component, params);\n      return;\n    }\n  }\n\n  private _mount(ComponentClass: ComponentClass, params: Record<string, string>): void {\n    const element = this.ref as HTMLElement;\n    if (!element || !this.transpiler) return;\n    this.transpiler.mountComponent(ComponentClass, element, params);\n  }\n}\n","export class Boundary {\n  private start: Comment;\n  private end: Comment;\n\n  constructor(parent: Node, label: string = \"boundary\") {\n    this.start = document.createComment(`${label}-start`);\n    this.end = document.createComment(`${label}-end`);\n    if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n      (parent as any).insert(this.start);\n      (parent as any).insert(this.end);\n    } else {\n      parent.appendChild(this.start);\n      parent.appendChild(this.end);\n    }\n  }\n\n  public clear(): void {\n    let current = this.start.nextSibling;\n    while (current && current !== this.end) {\n      const toRemove = current;\n      current = current.nextSibling;\n      toRemove.parentNode?.removeChild(toRemove);\n    }\n  }\n\n  public insert(node: Node): void {\n    this.end.parentNode?.insertBefore(node, this.end);\n  }\n\n  public nodes(): Node[] {\n    const result: Node[] = [];\n    let current = this.start.nextSibling;\n    while (current && current !== this.end) {\n      result.push(current);\n      current = current.nextSibling;\n    }\n    return result;\n  }\n\n  public get parent(): Node | null {\n    return this.start.parentNode;\n  }\n}\n","import { Component } from \"./component\";\n\ntype Task = () => void;\n\nconst queue = new Map<Component, Task[]>();\nconst nextTickCallbacks: Task[] = [];\nlet isScheduled = false;\nlet batchingEnabled = true;\n\nfunction flush() {\n  isScheduled = false;\n\n  // 1. Process component updates\n  for (const [instance, tasks] of queue.entries()) {\n    try {\n      // Call pre-update hook (only for reactive updates, not first mount)\n      if (typeof instance.onChanges === \"function\") {\n        instance.onChanges();\n      }\n\n      // Run all surgical DOM updates for this component\n      for (const task of tasks) {\n        task();\n      }\n\n      // Call post-update hook\n      if (typeof instance.onRender === \"function\") {\n        instance.onRender();\n      }\n    } catch (e) {\n      console.error(\"[Kasper] Error during component update:\", e);\n    }\n  }\n  queue.clear();\n\n  // 2. Process nextTick callbacks\n  const callbacks = nextTickCallbacks.splice(0);\n  for (const cb of callbacks) {\n    try {\n      cb();\n    } catch (e) {\n      console.error(\"[Kasper] Error in nextTick callback:\", e);\n    }\n  }\n}\n\nexport function queueUpdate(instance: Component, task: Task) {\n  if (!batchingEnabled) {\n    task();\n    // During sync mount, we don't call onChanges or onRender here.\n    // onRender is called manually at the end of transpile/bootstrap.\n    return;\n  }\n\n  if (!queue.has(instance)) {\n    queue.set(instance, []);\n  }\n  queue.get(instance)!.push(task);\n\n  if (!isScheduled) {\n    isScheduled = true;\n    queueMicrotask(flush);\n  }\n}\n\n/**\n * Executes a function with batching disabled. \n * Used for initial mount and manual renders.\n */\nexport function flushSync(fn: () => void) {\n  const prev = batchingEnabled;\n  batchingEnabled = false;\n  try {\n    fn();\n  } finally {\n    batchingEnabled = prev;\n  }\n}\n\n/**\n * Returns a promise that resolves after the next framework update cycle.\n */\nexport function nextTick(): Promise<void>;\nexport function nextTick(cb: Task): void;\nexport function nextTick(cb?: Task): Promise<void> | void {\n  if (cb) {\n    nextTickCallbacks.push(cb);\n    if (!isScheduled) {\n      isScheduled = true;\n      queueMicrotask(flush);\n    }\n    return;\n  }\n\n  return new Promise((resolve) => {\n    nextTickCallbacks.push(resolve);\n    if (!isScheduled) {\n      isScheduled = true;\n      queueMicrotask(flush);\n    }\n  });\n}\n","import { ComponentClass, ComponentRegistry } from \"./component\";\nimport { ExpressionParser } from \"./expression-parser\";\nimport { Interpreter } from \"./interpreter\";\nimport { Router, RouteConfig } from \"./router\";\nimport { Scanner } from \"./scanner\";\nimport { Scope } from \"./scope\";\nimport { effect } from \"./signal\";\nimport { Boundary } from \"./boundary\";\nimport { TemplateParser } from \"./template-parser\";\nimport { queueUpdate, flushSync } from \"./scheduler\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport * as KNode from \"./types/nodes\";\n\nconst KEY_MAP: Record<string, string[]> = {\n  esc: [\"Escape\", \"Esc\"],\n  escape: [\"Escape\", \"Esc\"],\n  space: [\" \", \"Spacebar\"],\n  up: [\"ArrowUp\", \"Up\"],\n  down: [\"ArrowDown\", \"Down\"],\n  left: [\"ArrowLeft\", \"Left\"],\n  right: [\"ArrowRight\", \"Right\"],\n  del: [\"Delete\", \"Del\"],\n  delete: [\"Delete\", \"Del\"],\n  ins: [\"Insert\"],\n  dot: [\".\"],\n  comma: [\",\"],\n  slash: [\"/\"],\n  backslash: [\"\\\\\"],\n  plus: [\"+\"],\n  minus: [\"-\"],\n  equal: [\"=\"],\n};\n\ntype IfElseNode = [KNode.Element, KNode.Attribute];\n\nexport class Transpiler implements KNode.KNodeVisitor<void> {\n  private scanner = new Scanner();\n  private parser = new ExpressionParser();\n  private templateParser = new TemplateParser();\n  private interpreter = new Interpreter();\n  public registry: ComponentRegistry = {};\n  public mode: \"development\" | \"production\" = \"development\";\n  private isRendering = false;\n\n  constructor(options?: { registry: ComponentRegistry }) {\n    this.registry[\"router\"] = { component: Router };\n    if (!options) return;\n    if (options.registry) {\n      this.registry = { ...this.registry, ...options.registry };\n    }\n  }\n\n  private renderComponentInstance(\n    instance: any,\n    nodes: KNode.KNode[],\n    element: HTMLElement,\n    restoreScope: Scope,\n    slots?: Record<string, any>\n  ): void {\n    if (slots) instance.$slots = slots;\n\n    instance.$render = () => {\n      this.isRendering = true;\n      try {\n        this.destroy(element);\n        element.innerHTML = \"\";\n        const scope = new Scope(restoreScope, instance);\n        scope.set(\"$instance\", instance);\n        if (slots) instance.$slots = slots;\n        const prevScope = this.interpreter.scope;\n        this.interpreter.scope = scope;\n        flushSync(() => {\n          this.createSiblings(nodes, element);\n          if (typeof instance.onRender === \"function\") instance.onRender();\n        });\n        this.interpreter.scope = prevScope;\n      } finally {\n        this.isRendering = false;\n      }\n    };\n\n    if (typeof instance.onMount === \"function\") instance.onMount();\n\n    const scope = new Scope(restoreScope, instance);\n    scope.set(\"$instance\", instance);\n    this.interpreter.scope = scope;\n    flushSync(() => {\n      this.createSiblings(nodes, element);\n      if (typeof instance.onRender === \"function\") instance.onRender();\n    });\n    this.interpreter.scope = restoreScope;\n  }\n\n  public resolveNodes(tag: string): KNode.KNode[] {\n    const entry = this.registry[tag];\n    if (entry.nodes !== undefined) return entry.nodes;\n    const source = (entry.component as any).template;\n    if (!source) {\n      entry.nodes = [];\n      return entry.nodes;\n    }\n    entry.nodes = this.templateParser.parse(source);\n    return entry.nodes;\n  }\n\n  private evaluate(node: KNode.KNode, parent?: Node): void {\n    if (node.type === \"element\") {\n      const el = node as KNode.Element;\n      const misplaced = this.findAttr(el, [\"@elseif\", \"@else\"]);\n      if (misplaced) {\n        // These are handled by doIf, if we reach them here it's an error\n        const name = misplaced.name.startsWith(\"@\") ? misplaced.name.slice(1) : misplaced.name;\n        this.error(KErrorCode.MISPLACED_CONDITIONAL, { name: name }, el.name);\n      }\n    }\n    node.accept(this, parent);\n  }\n\n  private bindMethods(entity: any): void {\n    if (!entity || typeof entity !== \"object\") return;\n\n    let proto = Object.getPrototypeOf(entity);\n    while (proto && proto !== Object.prototype) {\n      for (const key of Object.getOwnPropertyNames(proto)) {\n        if (Object.getOwnPropertyDescriptor(proto, key)?.get) continue;\n        if (\n          typeof entity[key] === \"function\" &&\n          key !== \"constructor\" &&\n          !Object.prototype.hasOwnProperty.call(entity, key)\n        ) {\n          entity[key] = entity[key].bind(entity);\n        }\n      }\n      proto = Object.getPrototypeOf(proto);\n    }\n  }\n\n  // Creates an effect that restores the current scope on every re-run,\n  // so effects set up inside @each always evaluate in their item scope.\n  private scopedEffect(fn: () => void): () => void {\n    const scope = this.interpreter.scope;\n    return effect(() => {\n      const prev = this.interpreter.scope;\n      this.interpreter.scope = scope;\n      try {\n        fn();\n      } finally {\n        this.interpreter.scope = prev;\n      }\n    });\n  }\n\n  // Wraps a refresh function so it restores the correct scope when called\n  // directly by triggerRefresh (outside of the signal effect machinery).\n  private scopedRefresh(fn: () => void): () => void {\n    const scope = this.interpreter.scope;\n    return () => {\n      const prev = this.interpreter.scope;\n      this.interpreter.scope = scope;\n      try {\n        fn();\n      } finally {\n        this.interpreter.scope = prev;\n      }\n    };\n  }\n\n  // evaluates expressions and returns the result of the first evaluation\n  private execute(source: string, overrideScope?: Scope): any {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens);\n\n    const restoreScope = this.interpreter.scope;\n    if (overrideScope) {\n      this.interpreter.scope = overrideScope;\n    }\n    const result = expressions.map((expression) =>\n      this.interpreter.evaluate(expression)\n    );\n    this.interpreter.scope = restoreScope;\n    return result && result.length ? result[result.length - 1] : undefined;\n  }\n\n  public transpile(\n    nodes: KNode.KNode[],\n    entity: any,\n    container: Element\n  ): Node {\n    this.isRendering = true;\n    try {\n      this.destroy(container);\n      container.innerHTML = \"\";\n      this.bindMethods(entity);\n      this.interpreter.scope.init(entity);\n      this.interpreter.scope.set(\"$instance\", entity);\n\n      flushSync(() => {\n        this.createSiblings(nodes, container);\n        this.triggerRender();\n      });\n\n      return container;\n    } finally {\n      this.isRendering = false;\n    }\n  }\n\n  public visitElementKNode(node: KNode.Element, parent?: Node): void {\n    this.createElement(node, parent);\n  }\n\n  public visitTextKNode(node: KNode.Text, parent?: Node): void {\n    const text = document.createTextNode(\"\");\n    if (parent) {\n      if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n        (parent as any).insert(text);\n      } else {\n        parent.appendChild(text);\n      }\n    }\n\n    const stop = this.scopedEffect(() => {\n      const newValue = this.evaluateTemplateString(node.value);\n      const instance = this.interpreter.scope.get(\"$instance\");\n      if (instance) {\n        queueUpdate(instance, () => {\n          text.textContent = newValue;\n        });\n      } else {\n        text.textContent = newValue;\n      }\n    });\n    this.trackEffect(text, stop);\n  }\n\n  public visitAttributeKNode(node: KNode.Attribute, parent?: Node): void {\n    const attr = document.createAttribute(node.name);\n\n    const stop = this.scopedEffect(() => {\n      attr.value = this.evaluateTemplateString(node.value);\n    });\n    this.trackEffect(attr, stop);\n\n    if (parent) {\n      (parent as HTMLElement).setAttributeNode(attr);\n    }\n  }\n\n  public visitCommentKNode(_node: KNode.Comment, _parent?: Node): void {\n    // template comments are stripped from DOM output\n  }\n\n  private trackEffect(target: any, stop: any) {\n    if (!target.$kasperEffects) target.$kasperEffects = [];\n    target.$kasperEffects.push(stop);\n  }\n\n  private findAttr(\n    node: KNode.Element,\n    name: string[]\n  ): KNode.Attribute | null {\n    if (!node || !node.attributes || !node.attributes.length) {\n      return null;\n    }\n\n    const attrib = node.attributes.find((attr) =>\n      name.includes((attr as KNode.Attribute).name)\n    );\n    if (attrib) {\n      return attrib as KNode.Attribute;\n    }\n    return null;\n  }\n\n  private doIf(expressions: IfElseNode[], parent: Node): void {\n    const boundary = new Boundary(parent, \"if\");\n\n    const run = () => {\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      const trackingScope = instance ? new Scope(this.interpreter.scope) : this.interpreter.scope;\n      const prevScope = this.interpreter.scope;\n      this.interpreter.scope = trackingScope;\n\n      // Evaluate conditions synchronously to ensure signal tracking\n      const results: boolean[] = [];\n      results.push(!!this.execute((expressions[0][1] as KNode.Attribute).value));\n\n      if (!results[0]) {\n        for (const expression of expressions.slice(1)) {\n          if (this.findAttr(expression[0] as KNode.Element, [\"@elseif\"])) {\n            const val = !!this.execute((expression[1] as KNode.Attribute).value);\n            results.push(val);\n            if (val) break;\n          } else if (this.findAttr(expression[0] as KNode.Element, [\"@else\"])) {\n            results.push(true);\n            break;\n          }\n        }\n      }\n      this.interpreter.scope = prevScope;\n\n      const task = () => {\n        boundary.nodes().forEach((n) => this.destroyNode(n));\n        boundary.clear();\n\n        const restoreScope = this.interpreter.scope;\n        this.interpreter.scope = trackingScope;\n        try {\n          if (results[0]) {\n            expressions[0][0].accept(this, boundary as any);\n            return;\n          }\n\n          for (let i = 1; i < results.length; i++) {\n            if (results[i]) {\n              expressions[i][0].accept(this, boundary as any);\n              return;\n            }\n          }\n        } finally {\n          this.interpreter.scope = restoreScope;\n        }\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n  private doEach(each: KNode.Attribute, node: KNode.Element, parent: Node) {\n    const keyAttr = this.findAttr(node, [\"@key\"]);\n    if (keyAttr) {\n      this.doEachKeyed(each, node, parent, keyAttr);\n    } else {\n      this.doEachUnkeyed(each, node, parent);\n    }\n  }\n\n  private doEachUnkeyed(each: KNode.Attribute, node: KNode.Element, parent: Node) {\n    const boundary = new Boundary(parent, \"each\");\n    const originalScope = this.interpreter.scope;\n\n    const run = () => {\n      const tokens = this.scanner.scan(each.value);\n      const [name, key, iterable] = this.interpreter.evaluate(\n        this.parser.foreach(tokens)\n      );\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      const task = () => {\n        boundary.nodes().forEach((n) => this.destroyNode(n));\n        boundary.clear();\n\n        let index = 0;\n        for (const item of iterable) {\n          const scopeValues: any = { [name]: item };\n          if (key) scopeValues[key] = index;\n\n          this.interpreter.scope = new Scope(originalScope, scopeValues);\n          this.createElement(node, boundary as any);\n          index += 1;\n        }\n        this.interpreter.scope = originalScope;\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n  private triggerRefresh(node: Node): void {\n    // 1. Re-run structural logic (if/each/while)\n    if ((node as any).$kasperRefresh) {\n      (node as any).$kasperRefresh();\n    }\n\n    // 2. Re-run all surgical effects (text interpolation, attributes, etc.)\n    if ((node as any).$kasperEffects) {\n      (node as any).$kasperEffects.forEach((stop: any) => {\n        if (typeof stop.run === \"function\") {\n          stop.run();\n        }\n      });\n    }\n\n    // 3. Recurse\n    node.childNodes?.forEach((child) => this.triggerRefresh(child));\n  }\n\n  private doEachKeyed(each: KNode.Attribute, node: KNode.Element, parent: Node, keyAttr: KNode.Attribute) {\n    const boundary = new Boundary(parent, \"each\");\n    const originalScope = this.interpreter.scope;\n    const keyedNodes = new Map<any, Node>();\n\n    const run = () => {\n      const tokens = this.scanner.scan(each.value);\n      const [name, indexKey, iterable] = this.interpreter.evaluate(\n        this.parser.foreach(tokens)\n      );\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      // Compute new items and their keys immediately\n      const newItems: Array<{ item: any; idx: number; key: any }> = [];\n      const seenKeys = new Set();\n      let index = 0;\n      for (const item of iterable) {\n        const scopeValues: any = { [name]: item };\n        if (indexKey) scopeValues[indexKey] = index;\n        this.interpreter.scope = new Scope(originalScope, scopeValues);\n        const key = this.execute(keyAttr.value);\n\n        if (this.mode === \"development\" && seenKeys.has(key)) {\n          console.warn(`[Kasper] Duplicate key detected in @each: \"${key}\". Keys must be unique to ensure correct reconciliation.`);\n        }\n        seenKeys.add(key);\n\n        newItems.push({ item: item, idx: index, key: key });\n        index++;\n      }\n\n      const task = () => {\n        // Destroy nodes whose keys are no longer present\n        const newKeySet = new Set(newItems.map((i) => i.key));\n        for (const [key, domNode] of keyedNodes) {\n          if (!newKeySet.has(key)) {\n            this.destroyNode(domNode);\n            domNode.parentNode?.removeChild(domNode);\n            keyedNodes.delete(key);\n          }\n        }\n\n        // Insert/reuse nodes in new order using a cursor to avoid unnecessary moves\n        const parent = (boundary as any).end.parentNode as Node;\n        let lastInserted: Node = (boundary as any).start;\n\n        for (const { item, idx, key } of newItems) {\n          const scopeValues: any = { [name]: item };\n          if (indexKey) scopeValues[indexKey] = idx;\n          this.interpreter.scope = new Scope(originalScope, scopeValues);\n\n          if (keyedNodes.has(key)) {\n            const domNode = keyedNodes.get(key)!;\n\n            // Only move the node if it's not already in the correct position\n            if (lastInserted.nextSibling !== domNode) {\n              parent.insertBefore(domNode, lastInserted.nextSibling);\n            }\n            lastInserted = domNode;\n\n            // Update scope and trigger re-render of nested structural directives\n            const nodeScope = (domNode as any).$kasperScope;\n            if (nodeScope) {\n              nodeScope.set(name, item);\n              if (indexKey) nodeScope.set(indexKey, idx);\n\n              // If it has its own render logic (nested each/if), trigger it recursively\n              this.triggerRefresh(domNode);\n            }\n          } else {\n            const created = this.createElement(node, boundary as any);\n            if (created) {\n              // createElement inserts before end; move to correct position if needed\n              if (lastInserted.nextSibling !== created) {\n                parent.insertBefore(created, lastInserted.nextSibling);\n              }\n              lastInserted = created;\n              keyedNodes.set(key, created);\n              // Store the scope on the DOM node so we can update it later\n              (created as any).$kasperScope = this.interpreter.scope;\n            }\n          }\n        }\n        this.interpreter.scope = originalScope;\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n\n  private createSiblings(nodes: KNode.KNode[], parent?: Node): void {\n    let current = 0;\n    const initialScope = this.interpreter.scope;\n    let groupScope: Scope | null = null;\n\n    while (current < nodes.length) {\n      const node = nodes[current++];\n      if (node.type === \"element\") {\n        const el = node as KNode.Element;\n\n        // 1. Process @let (leaks to siblings and available to other directives on this node)\n        const $let = this.findAttr(el, [\"@let\"]);\n        if ($let) {\n          if (!groupScope) {\n            groupScope = new Scope(initialScope);\n            this.interpreter.scope = groupScope;\n          }\n          this.execute($let.value);\n        }\n\n        // 2. Validation: Structural directives are mutually exclusive\n        const ifAttr = this.findAttr(el, [\"@if\"]);\n        const elseifAttr = this.findAttr(el, [\"@elseif\"]);\n        const elseAttr = this.findAttr(el, [\"@else\"]);\n        const $each = this.findAttr(el, [\"@each\"]);\n\n        if (this.mode === \"development\") {\n          const structuralCount = [ifAttr, elseifAttr, elseAttr, $each].filter(a => a).length;\n          if (structuralCount > 1) {\n            this.error(KErrorCode.MULTIPLE_STRUCTURAL_DIRECTIVES, {}, el.name);\n          }\n        }\n\n        // 3. Process structural directives (one will match and continue)\n        if ($each) {\n          this.doEach($each, el, parent!);\n          continue;\n        }\n\n        if (ifAttr) {\n          const expressions: IfElseNode[] = [[el, ifAttr]];\n\n          while (current < nodes.length) {\n            const next = nodes[current];\n            if (next.type !== \"element\") break;\n            const attr = this.findAttr(next as KNode.Element, [\n              \"@else\",\n              \"@elseif\",\n            ]);\n            if (attr) {\n              expressions.push([next as KNode.Element, attr]);\n              current += 1;\n            } else {\n              break;\n            }\n          }\n\n          this.doIf(expressions, parent!);\n          continue;\n        }\n      }\n\n      this.evaluate(node, parent);\n    }\n\n    this.interpreter.scope = initialScope;\n  }\n\n  private createElement(node: KNode.Element, parent?: Node): Node | undefined {\n    try {\n      if (node.name === \"slot\") {\n        const nameAttr = this.findAttr(node, [\"@name\"]);\n        const name = nameAttr ? nameAttr.value : \"default\";\n        const slots = this.interpreter.scope.get(\"$slots\");\n        if (slots && slots[name]) {\n          const prev = this.interpreter.scope;\n          // Restore the scope where the slot content was defined (Lexical Scoping).\n          // We store the scope reference directly on the Array instance to avoid changing signatures.\n          if (slots[name].scope) this.interpreter.scope = slots[name].scope;\n          this.createSiblings(slots[name], parent);\n          this.interpreter.scope = prev;\n        }\n        return undefined;\n      }\n\n      const isVoid = node.name === \"void\";\n      const isComponent = !!this.registry[node.name];\n\n      const element = isVoid ? parent : document.createElement(node.name);\n      const restoreScope = this.interpreter.scope;\n\n      if (element && element !== parent) {\n        this.interpreter.scope.set(\"$ref\", element);\n      }\n\n      if (isComponent) {\n        // create a new instance of the component and set it as the current scope\n        let component: any = {};\n        const argsAttr = node.attributes.filter((attr) =>\n          (attr as KNode.Attribute).name.startsWith(\"@:\")\n        );\n        const args = this.createComponentArgs(argsAttr as KNode.Attribute[]);\n\n        // Capture children for slots. \n        // We use a plain object keyed by slot name. Each value is an Array of KNodes.\n        // To support lexical scoping, we attach the current scope to the Array instance.\n        const slots: Record<string, any> = { default: [] };\n        slots.default.scope = this.interpreter.scope;\n        for (const child of node.children) {\n          if (child.type === \"element\") {\n            const slotAttr = this.findAttr(child as KNode.Element, [\"@slot\"]);\n            if (slotAttr) {\n              const name = slotAttr.value;\n              if (!slots[name]) {\n                slots[name] = [];\n                slots[name].scope = this.interpreter.scope;\n              }\n              slots[name].push(child);\n              continue;\n            }\n          }\n          slots.default.push(child);\n        }\n\n        if (this.registry[node.name]?.lazy) {\n          const entry = this.registry[node.name];\n\n          if (entry.fallback) {\n            const fallbackNodes = this.templateParser.parse((entry.fallback as any).template ?? \"\");\n            const fallbackInstance: any = new entry.fallback({ args: {}, ref: element, transpiler: this });\n            this.bindMethods(fallbackInstance);\n            (element as any).$kasperInstance = fallbackInstance;\n            this.renderComponentInstance(fallbackInstance, fallbackNodes, element as HTMLElement, restoreScope);\n          }\n\n          if (!(entry as any)._promise) {\n            (entry as any)._promise = (entry.component as () => Promise<ComponentClass>)().then((cls) => {\n              entry.nodes = this.templateParser.parse((cls as any).template ?? \"\");\n              entry.component = cls;\n              delete entry.lazy;\n              delete (entry as any)._promise;\n            });\n          }\n\n          (entry as any)._promise.then(() => {\n            this.destroy(element as HTMLElement);\n            (element as HTMLElement).innerHTML = \"\";\n            const cls = entry.component as ComponentClass;\n            const instance: any = new cls({ args: args, ref: element, transpiler: this });\n            this.bindMethods(instance);\n            (element as any).$kasperInstance = instance;\n            this.renderComponentInstance(instance, entry.nodes!, element as HTMLElement, restoreScope, slots);\n          });\n\n          if (parent) {\n            if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n              (parent as any).insert(element);\n            } else {\n              parent.appendChild(element);\n            }\n          }\n          return element;\n        }\n\n        if (this.registry[node.name]?.component) {\n          component = new (this.registry[node.name].component as ComponentClass)({\n            args: args,\n            ref: element,\n            transpiler: this,\n          });\n\n          this.bindMethods(component);\n          (element as any).$kasperInstance = component;\n\n          if (node.name === \"router\" && component instanceof Router) {\n            const routeScope = new Scope(restoreScope, component);\n            component.setRoutes(this.extractRoutes(node.children, undefined, routeScope));\n          }\n\n          this.renderComponentInstance(component, this.resolveNodes(node.name), element as HTMLElement, restoreScope, slots);\n        }\n        if (parent) {\n          if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n            (parent as any).insert(element);\n          } else {\n            parent.appendChild(element);\n          }\n        }\n        return element;\n      }\n\n      if (!isVoid) {\n        // event binding\n        const events = node.attributes.filter((attr) =>\n          (attr as KNode.Attribute).name.startsWith(\"@on:\")\n        );\n\n        for (const event of events) {\n          this.createEventListener(element, event as KNode.Attribute);\n        }\n\n        // regular attributes (processed first)\n        const attributes = node.attributes.filter(\n          (attr) => !(attr as KNode.Attribute).name.startsWith(\"@\")\n        );\n\n        for (const attr of attributes) {\n          this.evaluate(attr, element);\n        }\n\n        // shorthand attributes (processed second, allows merging)\n        const shorthandAttributes = node.attributes.filter((attr) => {\n          const name = (attr as KNode.Attribute).name;\n          return (\n            name.startsWith(\"@\") &&\n            ![\"@if\", \"@elseif\", \"@else\", \"@each\", \"@let\", \"@key\", \"@ref\"].includes(\n              name\n            ) &&\n            !name.startsWith(\"@on:\") &&\n            !name.startsWith(\"@:\")\n          );\n        });\n\n        for (const attr of shorthandAttributes) {\n          const realName = (attr as KNode.Attribute).name.slice(1);\n\n          if (realName === \"class\") {\n            const stop = this.scopedEffect(() => {\n              const value = this.execute((attr as KNode.Attribute).value);\n              const instance = this.interpreter.scope.get(\"$instance\");\n              const task = () => {\n                (element as HTMLElement).setAttribute(\"class\", value);\n              };\n\n              if (instance) {\n                queueUpdate(instance, task);\n              } else {\n                task();\n              }\n            });\n            this.trackEffect(element, stop);\n          } else {\n            const stop = this.scopedEffect(() => {\n              const value = this.execute((attr as KNode.Attribute).value);\n              const instance = this.interpreter.scope.get(\"$instance\");\n              const task = () => {\n                if (value === false || value === null || value === undefined) {\n                  if (realName !== \"style\") {\n                    (element as HTMLElement).removeAttribute(realName);\n                  }\n                } else {\n                  if (realName === \"style\") {\n                    const existing = (element as HTMLElement).getAttribute(\"style\");\n                    const newValue = existing && !existing.includes(value)\n                      ? `${existing.endsWith(\";\") ? existing : existing + \";\"} ${value}`\n                      : value;\n                    (element as HTMLElement).setAttribute(\"style\", newValue);\n                  } else {\n                    (element as HTMLElement).setAttribute(realName, value);\n                  }\n                }\n              };\n\n              if (instance) {\n                queueUpdate(instance, task);\n              } else {\n                task();\n              }\n            });\n            this.trackEffect(element, stop);\n          }\n        }\n      }\n\n      if (parent && !isVoid) {\n        if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n          (parent as any).insert(element);\n        } else {\n          parent.appendChild(element);\n        }\n      }\n\n      const refAttr = this.findAttr(node, [\"@ref\"]);\n      if (refAttr && !isVoid) {\n        const propName = refAttr.value.trim();\n        const instance = this.interpreter.scope.get(\"$instance\");\n        if (instance) {\n          instance[propName] = element;\n        } else {\n          this.interpreter.scope.set(propName, element);\n        }\n      }\n\n      if (node.self) {\n        return element;\n      }\n\n      this.createSiblings(node.children, element);\n      this.interpreter.scope = restoreScope;\n\n      return element;\n    } catch (e: any) {\n      if (e instanceof KasperError) throw e.withTag(node.name);\n      this.error(KErrorCode.RUNTIME_ERROR, { message: e.message || `${e}` }, node.name);\n    }\n  }\n\n  private createComponentArgs(args: KNode.Attribute[]): Record<string, any> {\n    if (!args.length) {\n      return {};\n    }\n    const result: Record<string, any> = {};\n    for (const arg of args) {\n      const key = arg.name.split(\":\")[1];\n      if (this.mode === \"development\" && key.toLowerCase().startsWith(\"on\")) {\n        const trimmed = arg.value.trim();\n        const isCallExpr = /^[\\w$.][\\w$.]*\\s*\\(.*\\)\\s*$/.test(trimmed) && !trimmed.includes(\"=>\");\n        if (isCallExpr) {\n          console.warn(\n            `[Kasper] @:${key}=\"${arg.value}\" — the expression is called during render and its return value is passed as the prop. ` +\n            `If it returns a function, that function becomes the handler (factory pattern). ` +\n            `If it returns undefined, the prop receives undefined. ` +\n            `If the function has reactive side effects, ensure it does not both read and write the same signal.`\n          );\n        }\n      }\n      result[key] = this.execute(arg.value);\n    }\n    return result;\n  }\n\n  private createEventListener(element: Node, attr: KNode.Attribute): void {\n    const [eventName, ...modifiers] = attr.name.split(\":\")[1].split(\".\");\n    const listenerScope = new Scope(this.interpreter.scope);\n    const instance = this.interpreter.scope.get(\"$instance\");\n\n    const options: any = {};\n    if (instance && instance.$abortController) {\n      options.signal = instance.$abortController.signal;\n    }\n    if (modifiers.includes(\"once\")) options.once = true;\n    if (modifiers.includes(\"passive\")) options.passive = true;\n    if (modifiers.includes(\"capture\")) options.capture = true;\n\n    // Anything not in this list is treated as a potential key modifier\n    const controlModifiers = [\"prevent\", \"stop\", \"once\", \"passive\", \"capture\", \"ctrl\", \"shift\", \"alt\", \"meta\"];\n    const potentialKeyModifiers = modifiers.filter((m) => !controlModifiers.includes(m.toLowerCase()));\n\n    element.addEventListener(\n      eventName,\n      (event: any) => {\n        if (potentialKeyModifiers.length > 0) {\n          const matched = potentialKeyModifiers.some((m) => {\n            const lowerM = m.toLowerCase();\n            if (KEY_MAP[lowerM] && KEY_MAP[lowerM].includes(event.key)) return true;\n            if (lowerM === event.key?.toLowerCase()) return true;\n            return false;\n          });\n          if (!matched) {\n            return;\n          }\n        }\n\n        if (modifiers.includes(\"ctrl\") && !event.ctrlKey) return;\n        if (modifiers.includes(\"shift\") && !event.shiftKey) return;\n        if (modifiers.includes(\"alt\") && !event.altKey) return;\n        if (modifiers.includes(\"meta\") && !event.metaKey) return;\n\n        if (modifiers.includes(\"prevent\")) event.preventDefault();\n        if (modifiers.includes(\"stop\")) event.stopPropagation();\n        listenerScope.set(\"$event\", event);\n        this.execute(attr.value, listenerScope);\n      },\n      options\n    );\n  }\n\n  private evaluateTemplateString(text: string): string {\n    if (!text) {\n      return text;\n    }\n    const regex = /\\{\\{.+\\}\\}/ms;\n    if (regex.test(text)) {\n      return text.replace(/\\{\\{([\\s\\S]+?)\\}\\}/g, (m, placeholder) => {\n        return this.evaluateExpression(placeholder);\n      });\n    }\n    return text;\n  }\n\n  private evaluateExpression(source: string): string {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens);\n\n    let result = \"\";\n    for (const expression of expressions) {\n      result += `${this.interpreter.evaluate(expression)}`;\n    }\n    return result;\n  }\n\n  private destroyNode(node: any): void {\n    // 1. Cleanup component instance\n    if (node.$kasperInstance) {\n      const instance = node.$kasperInstance;\n      if (instance.onDestroy) {\n        instance.onDestroy();\n      }\n      if (instance.$abortController) instance.$abortController.abort();\n    }\n\n    // 2. Cleanup effects attached to the node\n    if (node.$kasperEffects) {\n      node.$kasperEffects.forEach((stop: () => void) => stop());\n      node.$kasperEffects = [];\n    }\n\n    // 3. Cleanup effects on attributes\n    if (node.attributes) {\n      for (let i = 0; i < node.attributes.length; i++) {\n        const attr = node.attributes[i];\n        if (attr.$kasperEffects) {\n          attr.$kasperEffects.forEach((stop: () => void) => stop());\n          attr.$kasperEffects = [];\n        }\n      }\n    }\n\n    // 4. Recurse\n    node.childNodes?.forEach((child: any) => this.destroyNode(child));\n  }\n\n  public destroy(container: Element): void {\n    container.childNodes.forEach((child) => this.destroyNode(child));\n  }\n\n  public mountComponent(ComponentClass: ComponentClass, container: HTMLElement, params: Record<string, string> = {}): void {\n    this.destroy(container);\n    container.innerHTML = \"\";\n\n    const template = (ComponentClass as any).template;\n    if (!template) return;\n\n    const nodes = this.templateParser.parse(template);\n    const host = document.createElement(\"div\");\n    container.appendChild(host);\n\n    const component = new ComponentClass({ args: { params: params }, ref: host, transpiler: this });\n    this.bindMethods(component);\n    (host as any).$kasperInstance = component;\n\n    const componentNodes = nodes;\n    component.$render = () => {\n      this.isRendering = true;\n      try {\n        this.destroy(host);\n        host.innerHTML = \"\";\n        const scope = new Scope(null, component);\n        scope.set(\"$instance\", component);\n        const prev = this.interpreter.scope;\n        this.interpreter.scope = scope;\n\n        flushSync(() => {\n          this.createSiblings(componentNodes, host);\n          if (typeof component.onRender === \"function\") component.onRender();\n        });\n\n        this.interpreter.scope = prev;\n      } finally {\n        this.isRendering = false;\n      }\n    };\n\n    const scope = new Scope(null, component);\n    scope.set(\"$instance\", component);\n    const prev = this.interpreter.scope;\n    this.interpreter.scope = scope;\n\n    flushSync(() => {\n      this.createSiblings(nodes, host);\n    });\n\n    this.interpreter.scope = prev;\n\n    if (typeof component.onMount === \"function\") component.onMount();\n    if (typeof component.onRender === \"function\") component.onRender();\n  }\n\n  public extractRoutes(children: KNode.KNode[], parentGuard?: () => Promise<boolean>, scope?: Scope): RouteConfig[] {\n    const routes: RouteConfig[] = [];\n    const prevScope = scope ? this.interpreter.scope : undefined;\n    if (scope) this.interpreter.scope = scope;\n    for (const child of children) {\n      if (child.type !== \"element\") continue;\n      const el = child as KNode.Element;\n      if (el.name === \"route\") {\n        const pathAttr = this.findAttr(el, [\"@path\"]);\n        const componentAttr = this.findAttr(el, [\"@component\"]);\n        const guardAttr = this.findAttr(el, [\"@guard\"]);\n\n        if (!pathAttr || !componentAttr) {\n          this.error(KErrorCode.MISSING_REQUIRED_ATTR, { message: \"<route> requires @path and @component attributes.\" }, el.name);\n        }\n\n        const path = pathAttr!.value;\n        const component = this.execute(componentAttr!.value);\n        const guard = guardAttr ? this.execute(guardAttr.value) : parentGuard;\n        routes.push({ path: path, component: component, guard: guard });\n      } else if (el.name === \"guard\") {\n        const checkAttr = this.findAttr(el, [\"@check\"]);\n        if (!checkAttr) {\n          this.error(KErrorCode.MISSING_REQUIRED_ATTR, { message: \"<guard> requires @check attribute.\" }, el.name);\n        }\n\n        if (!checkAttr) continue;\n        const check = this.execute(checkAttr.value);\n        routes.push(...this.extractRoutes(el.children, check));\n      }\n    }\n    if (scope) this.interpreter.scope = prevScope;\n    return routes;\n  }\n\n  private triggerRender(): void {\n    if (this.isRendering) return;\n    const instance = this.interpreter.scope.get(\"$instance\");\n    if (instance && typeof instance.onRender === \"function\") {\n      instance.onRender();\n    }\n  }\n\n  public visitDoctypeKNode(_node: KNode.Doctype): void {\n    return;\n    // return document.implementation.createDocumentType(\"html\", \"\", \"\");\n  }\n\n  public error(code: KErrorCodeType, args: any, tagName?: string): void {\n    let finalArgs = args;\n    if (typeof args === \"string\") {\n      const cleanMessage = args.includes(\"Runtime Error\")\n        ? args.replace(\"Runtime Error: \", \"\")\n        : args;\n      finalArgs = { message: cleanMessage };\n    }\n\n    throw new KasperError(code, finalArgs, undefined, undefined, tagName);\n  }\n\n}\n","import { ComponentClass, ComponentRegistry } from \"./component\";\nimport { TemplateParser } from \"./template-parser\";\nimport { Transpiler } from \"./transpiler\";\nimport { KasperError, KErrorCode } from \"./types/error\";\n\nexport function lazy(\n  importer: () => Promise<Record<string, ComponentClass>>\n): { component: () => Promise<ComponentClass>; lazy: true } {\n  return {\n    lazy: true,\n    component: () => importer().then((m) => Object.values(m)[0]),\n  };\n}\n\nexport function execute(source: string): string {\n  const parser = new TemplateParser();\n  try {\n    const nodes = parser.parse(source);\n    return JSON.stringify(nodes);\n  } catch (e) {\n    return JSON.stringify([e instanceof Error ? e.message : String(e)]);\n  }\n}\n\nexport function transpile(\n  source: string,\n  entity?: { [key: string]: any },\n  container?: HTMLElement,\n  registry?: ComponentRegistry\n): Node {\n  const parser = new TemplateParser();\n  const nodes = parser.parse(source);\n  const transpiler = new Transpiler({ registry: registry || {} });\n  const result = transpiler.transpile(nodes, entity || {}, container);\n  return result;\n}\n\nexport interface KasperConfig {\n  root?: string | HTMLElement;\n  entry?: string;\n  registry: ComponentRegistry;\n  mode?: \"development\" | \"production\";\n}\n\nfunction createComponent(transpiler: Transpiler, tag: string) {\n  const element = document.createElement(tag);\n  const component = new (transpiler.registry[tag].component as ComponentClass)({\n    ref: element,\n    transpiler: transpiler,\n    args: {},\n  });\n\n  return {\n    node: element,\n    instance: component,\n    nodes: transpiler.resolveNodes(tag),\n  };\n}\n\nexport function bootstrap(config: KasperConfig) {\n  const root =\n    typeof config.root === \"string\"\n      ? document.querySelector(config.root)\n      : config.root;\n\n  if (!root) {\n    throw new KasperError(\n      KErrorCode.ROOT_ELEMENT_NOT_FOUND,\n      { root: config.root }\n    );\n  }\n\n  const entryTag = config.entry || \"kasper-app\";\n  if (!config.registry[entryTag]) {\n    throw new KasperError(\n      KErrorCode.ENTRY_COMPONENT_NOT_FOUND,\n      { tag: entryTag }\n    );\n  }\n\n  const transpiler = new Transpiler({ registry: config.registry });\n\n  if (config.mode) {\n    transpiler.mode = config.mode;\n  }\n\n  const { node, instance, nodes } = createComponent(transpiler, entryTag);\n\n  root.innerHTML = \"\";\n  root.appendChild(node);\n\n  if (typeof instance.onMount === \"function\") {\n    instance.onMount();\n  }\n\n  transpiler.transpile(nodes, instance, node as HTMLElement);\n\n  if (typeof instance.onRender === \"function\") {\n    instance.onRender();\n  }\n\n  return instance;\n}\n"],"names":["rawEffect","rawComputed","Set","TokenType","Expr.Each","Expr.Variable","Expr.Binary","Expr.Assign","Expr.Get","Expr.Set","Expr.Pipeline","Expr.Ternary","Expr.NullCoalescing","Expr.Logical","Expr.Typeof","Expr.Unary","Expr.Call","Expr.New","Expr.Postfix","Expr.Spread","Expr.Key","Expr.Literal","Expr.Template","Expr.ArrowFunction","Expr.Grouping","Expr.Void","Expr.Debug","Expr.Dictionary","Expr.List","Utils.isDigit","Utils.isAlphaNumeric","Utils.capitalize","Utils.isKeyword","Utils.isAlpha","Parser","Node.Doctype","Node.Element","Node.Attribute","Node.Text","ComponentClass","scope","parent","prev"],"mappings":"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"} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"kasper.js","sources":["../src/types/error.ts","../src/error-handler.ts","../src/signal.ts","../src/component.ts","../src/types/expressions.ts","../src/types/token.ts","../src/expression-parser.ts","../src/utils.ts","../src/scanner.ts","../src/scope.ts","../src/interpreter.ts","../src/types/nodes.ts","../src/template-parser.ts","../src/router.ts","../src/boundary.ts","../src/scheduler.ts","../src/transpiler.ts","../src/kasper.ts"],"sourcesContent":["export const KErrorCode = {\n  // Bootstrap\n  ROOT_ELEMENT_NOT_FOUND: \"K001-1\",\n  ENTRY_COMPONENT_NOT_FOUND: \"K001-2\",\n\n  // Scanner\n  UNTERMINATED_COMMENT: \"K002-1\",\n  UNTERMINATED_STRING: \"K002-2\",\n  UNEXPECTED_CHARACTER: \"K002-3\",\n\n  // Template Parser\n  UNEXPECTED_EOF: \"K003-1\",\n  UNEXPECTED_CLOSING_TAG: \"K003-2\",\n  EXPECTED_TAG_NAME: \"K003-3\",\n  EXPECTED_CLOSING_BRACKET: \"K003-4\",\n  EXPECTED_CLOSING_TAG: \"K003-5\",\n  BLANK_ATTRIBUTE_NAME: \"K003-6\",\n  MISPLACED_CONDITIONAL: \"K003-7\",\n  DUPLICATE_IF: \"K003-8\",\n  MULTIPLE_STRUCTURAL_DIRECTIVES: \"K003-9\",\n\n  // Expression Parser\n  UNEXPECTED_TOKEN: \"K004-1\",\n  INVALID_LVALUE: \"K004-2\",\n  EXPECTED_EXPRESSION: \"K004-3\",\n  INVALID_DICTIONARY_KEY: \"K004-4\",\n\n  // Interpreter\n  INVALID_POSTFIX_LVALUE: \"K005-1\",\n  UNKNOWN_BINARY_OPERATOR: \"K005-2\",\n  INVALID_PREFIX_RVALUE: \"K005-3\",\n  UNKNOWN_UNARY_OPERATOR: \"K005-4\",\n  NOT_A_FUNCTION: \"K005-5\",\n  NOT_A_CLASS: \"K005-6\",\n\n  // Signals\n  CIRCULAR_COMPUTED: \"K006-1\",\n\n  // Transpiler\n  RUNTIME_ERROR: \"K007-1\",\n  MISSING_REQUIRED_ATTR: \"K007-2\",\n} as const;\n\nexport type KErrorCodeType = (typeof KErrorCode)[keyof typeof KErrorCode];\n\nexport const ErrorTemplates: Record<string, (args: any) => string> = {\n  \"K001-1\": (a) => `Root element not found: ${a.root}`,\n  \"K001-2\": (a) => `Entry component <${a.tag}> not found in registry.`,\n\n  \"K002-1\": () => 'Unterminated comment, expecting closing \"*/\"',\n  \"K002-2\": (a) => `Unterminated string, expecting closing ${a.quote}`,\n  \"K002-3\": (a) => `Unexpected character '${a.char}'`,\n\n  \"K003-1\": (a) => `Unexpected end of file. ${a.eofError}`,\n  \"K003-2\": () => \"Unexpected closing tag\",\n  \"K003-3\": () => \"Expected a tag name\",\n  \"K003-4\": () => \"Expected closing tag >\",\n  \"K003-5\": (a) => `Expected </${a.name}>`,\n  \"K003-6\": () => \"Blank attribute name\",\n  \"K003-7\": (a) => `@${a.name} must be preceded by an @if or @elseif block.`,\n  \"K003-8\": () => \"Multiple conditional directives (@if, @elseif, @else) on the same element are not allowed.\",\n  \"K003-9\": () => \"Multiple structural directives (@if, @each) on the same element are not allowed. Nest them or use <void> instead.\",\n\n  \"K004-1\": (a) => `${a.message}, unexpected token \"${a.token}\"`,\n  \"K004-2\": () => \"Invalid l-value, is not an assigning target.\",\n  \"K004-3\": (a) => `Expected expression, unexpected token \"${a.token}\"`,\n  \"K004-4\": (a) => `String, Number or Identifier expected as a Key of Dictionary {, unexpected token ${a.token}`,\n\n  \"K005-1\": (a) => `Invalid left-hand side in postfix operation: ${a.entity}`,\n  \"K005-2\": (a) => `Unknown binary operator ${a.operator}`,\n  \"K005-3\": (a) => `Invalid right-hand side expression in prefix operation: ${a.right}`,\n  \"K005-4\": (a) => `Unknown unary operator ${a.operator}`,\n  \"K005-5\": (a) => `${a.callee} is not a function`,\n  \"K005-6\": (a) => `'${a.clazz}' is not a class. 'new' statement must be used with classes.`,\n\n  \"K006-1\": () => \"Circular dependency detected in computed signal\",\n\n  \"K007-1\": (a) => a.message,\n  \"K007-2\": (a) => a.message,\n};\n\nfunction codeSnippet(source: string, line: number, col: number, context = 2): string {\n  const lines = source.split(\"\\n\");\n  const errorLine = line - 1; // 0-indexed\n  const start = Math.max(0, errorLine - context);\n  const end = Math.min(lines.length - 1, errorLine + context);\n\n  const result: string[] = [\"\"];\n  for (let i = start; i <= end; i++) {\n    const indicator = i === errorLine ? \">\" : \" \";\n    result.push(`  ${indicator} | ${lines[i]}`);\n    if (i === errorLine && col > 0) {\n      // prefix: \"  > | \" (6) + (col - 1) spaces\n      const pointer = \" \".repeat(6 + col - 1) + \"^\";\n      result.push(pointer);\n    }\n  }\n  return result.join(\"\\n\");\n}\n\nexport interface KasperErrorOptions {\n  line?: number;\n  col?: number;\n  tag?: string;\n  source?: string;\n}\n\nexport class KasperError extends Error {\n  public line?: number;\n  public col?: number;\n  public tagName?: string;\n\n  constructor(\n    public code: KErrorCodeType,\n    public args: any = {},\n    options: KasperErrorOptions = {}\n  ) {\n    const { line, col, tag, source } = options;\n\n    // Detect environment\n    const isDev =\n      typeof process !== \"undefined\"\n        ? process.env.NODE_ENV !== \"production\"\n        : (import.meta as any).env?.MODE !== \"production\";\n\n    const template = ErrorTemplates[code];\n    const message = template\n      ? template(args)\n      : (typeof args === 'string' ? args : \"Unknown error\");\n\n    const tagInfo = tag ? `\\n  at <${tag}>` : \"\";\n    const snippet = line !== undefined && source ? codeSnippet(source, line, col ?? 0) : \"\";\n    const link = isDev\n      ? `\\nSee: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(\".\", \"\")}\\n`\n      : \"\";\n\n    super(`[${code}] ${message}${tagInfo}${snippet}${link}`);\n    this.name = \"KasperError\";\n    this.line = line;\n    this.col = col;\n    this.tagName = tag;\n  }\n\n  public withTag(tagName: string): this {\n    if (!this.tagName) {\n      this.tagName = tagName;\n      this.message += `\\n  at <${tagName}>`;\n    }\n    return this;\n  }\n}\n","export type ErrorPhase = 'render' | 'watcher';\n\nexport type ErrorHandlerFn = (\n  error: Error,\n  context: { component?: any; phase: ErrorPhase }\n) => void;\n\nlet globalHandler: ErrorHandlerFn | null = null;\n\nexport function setErrorHandler(handler: ErrorHandlerFn | undefined): void {\n  globalHandler = handler ?? null;\n}\n\nexport function handleError(error: unknown, phase: ErrorPhase, component?: any): void {\n  const err = error instanceof Error ? error : new Error(String(error));\n\n  // Try component-level onError first\n  if (component && typeof component.onError === 'function') {\n    try {\n      component.onError(err, phase);\n      return;\n    } catch (e) {\n      // onError itself threw — fall through with original error\n    }\n  }\n\n  // Try global handler\n  if (globalHandler) {\n    try {\n      globalHandler(err, { component, phase });\n      return;\n    } catch (_) {}\n  }\n\n  // Final fallback\n  console.error(`[Kasper] Error during ${phase}:`, err);\n}\n","import { KasperError, KErrorCode } from \"./types/error\";\n\ntype Listener = () => void;\n\nimport { handleError } from \"./error-handler\";\n\nlet activeEffect: { fn: Listener; deps: Set<any> } | null = null;\nconst effectStack: any[] = [];\n\nlet batching = false;\nconst pendingSubscribers = new Set<Listener>();\nconst pendingWatchers: Array<() => void> = [];\n\ntype Watcher<T> = (newValue: T, oldValue: T) => void;\n\nexport interface SignalOptions {\n  signal?: AbortSignal;\n}\n\nexport class Signal<T> {\n  protected _value: T;\n  private subscribers = new Set<Listener>();\n  private watchers = new Set<Watcher<T>>();\n\n  constructor(initialValue: T) {\n    this._value = initialValue;\n  }\n\n  get value(): T {\n    if (activeEffect) {\n      this.subscribers.add(activeEffect.fn);\n      activeEffect.deps.add(this);\n    }\n    return this._value;\n  }\n\n  set value(newValue: T) {\n    if (this._value !== newValue) {\n      const oldValue = this._value;\n      this._value = newValue;\n      if (batching) {\n        for (const sub of this.subscribers) pendingSubscribers.add(sub);\n        for (const watcher of this.watchers) pendingWatchers.push(() => watcher(newValue, oldValue));\n      } else {\n        const subs = Array.from(this.subscribers);\n        for (const sub of subs) {\n          sub();\n        }\n        for (const watcher of this.watchers) {\n          try { watcher(newValue, oldValue); } catch (e) { handleError(e, 'watcher'); }\n        }\n      }\n    }\n  }\n\n  onChange(fn: Watcher<T>, options?: SignalOptions): () => void {\n    if (options?.signal?.aborted) return () => {};\n    this.watchers.add(fn);\n    const stop = () => this.watchers.delete(fn);\n    if (options?.signal) {\n      options.signal.addEventListener(\"abort\", stop, { once: true });\n    }\n    return stop;\n  }\n\n  unsubscribe(fn: Listener) {\n    this.subscribers.delete(fn);\n  }\n\n  toString() { return String(this.value); }\n  peek() { return this._value; }\n}\n\nclass ComputedSignal<T> extends Signal<T> {\n  private fn: () => T;\n  private computing = false;\n\n  constructor(fn: () => T, options?: SignalOptions) {\n    super(undefined as any);\n    this.fn = fn;\n\n    const stop = effect(() => {\n      if (this.computing) {\n        throw new KasperError(KErrorCode.CIRCULAR_COMPUTED);\n      }\n\n      this.computing = true;\n      try {\n        // Eagerly update the value so subscribers are notified immediately\n        super.value = this.fn();\n      } finally {\n        this.computing = false;\n      }\n    }, options);\n\n    if (options?.signal) {\n      options.signal.addEventListener(\"abort\", stop, { once: true });\n    }\n  }\n\n  get value(): T {\n    return super.value;\n  }\n\n  set value(_v: T) {\n    // Computed signals are read-only from outside\n  }\n}\n\nexport function effect(fn: Listener, options?: SignalOptions) {\n  if (options?.signal?.aborted) return () => {};\n  const effectObj = {\n    fn: () => {\n      effectObj.deps.forEach(sig => sig.unsubscribe(effectObj.fn));\n      effectObj.deps.clear();\n\n      effectStack.push(effectObj);\n      activeEffect = effectObj;\n      try {\n        fn();\n      } finally {\n        effectStack.pop();\n        activeEffect = effectStack[effectStack.length - 1] || null;\n      }\n    },\n    deps: new Set<Signal<any>>()\n  };\n\n  effectObj.fn();\n  const stop: any = () => {\n    effectObj.deps.forEach(sig => sig.unsubscribe(effectObj.fn));\n    effectObj.deps.clear();\n  };\n  stop.run = effectObj.fn;\n\n  if (options?.signal) {\n    options.signal.addEventListener(\"abort\", stop, { once: true });\n  }\n\n  return stop as (() => void) & { run: () => void };\n}\n\nexport function signal<T>(initialValue: T): Signal<T> {\n  return new Signal(initialValue);\n}\n\n/**\n * Functional alias for Signal.onChange()\n */\nexport function watch<T>(sig: Signal<T>, fn: Watcher<T>, options?: SignalOptions): () => void {\n  return sig.onChange(fn, options);\n}\n\nexport function batch(fn: () => void): void {\n  batching = true;\n  try {\n    fn();\n  } finally {\n    batching = false;\n    const subs = Array.from(pendingSubscribers);\n    pendingSubscribers.clear();\n    const watchers = pendingWatchers.splice(0);\n    for (const sub of subs) {\n      sub();\n    }\n    for (const watcher of watchers) {\n      try { watcher(); } catch (e) { handleError(e, 'watcher'); }\n    }\n  }\n}\n\nexport function computed<T>(fn: () => T, options?: SignalOptions): Signal<T> {\n  return new ComputedSignal(fn, options);\n}\n","import { Signal, effect as rawEffect, computed as rawComputed } from \"./signal\";\nimport { Transpiler } from \"./transpiler\";\nimport { KNode } from \"./types/nodes\";\n\ntype Watcher<T> = (newValue: T, oldValue: T) => void;\n\ninterface ComponentArgs<TArgs extends Record<string, any> = Record<string, any>> {\n  args: TArgs;\n  ref?: Node;\n  transpiler?: Transpiler;\n}\n\nexport class Component<TArgs extends Record<string, any> = Record<string, any>> {\n  static template?: string;\n  args: TArgs = {} as TArgs;\n  ref?: Node;\n  transpiler?: Transpiler;\n  $abortController = new AbortController();\n  $render?: () => void;\n\n  constructor(props?: ComponentArgs<TArgs>) {\n    if (!props) {\n      this.args = {} as TArgs;\n      return;\n    }\n    if (props.args) {\n      this.args = props.args;\n    }\n    if (props.ref) {\n      this.ref = props.ref;\n    }\n    if (props.transpiler) {\n      this.transpiler = props.transpiler;\n    }\n  }\n\n  /**\n   * Creates a reactive effect tied to the component's lifecycle.\n   * Runs immediately and re-runs when any signal dependency changes.\n   */\n  effect(fn: () => void): void {\n    rawEffect(fn, { signal: this.$abortController.signal });\n  }\n\n  /**\n   * Watches a specific signal for changes.\n   * Does NOT run immediately.\n   */\n  watch<T>(sig: Signal<T>, fn: Watcher<T>): void {\n    sig.onChange(fn, { signal: this.$abortController.signal });\n  }\n\n  /**\n   * Creates a computed signal tied to the component's lifecycle.\n   * The internal effect is automatically cleaned up when the component is destroyed.\n   */\n  computed<T>(fn: () => T): Signal<T> {\n    return rawComputed(fn, { signal: this.$abortController.signal });\n  }\n\n  onMount() { }\n  onRender() { }\n  onChanges() { }\n  onDestroy() { }\n  onError?(error: Error, phase: string): void;\n\n  render() {\n    this.$render?.();\n  }\n}\n\nexport type KasperEntity = Component | Record<string, any> | null | undefined;\n\nexport type ComponentClass = { new(args?: ComponentArgs<any>): Component };\nexport interface ComponentRegistry {\n  [tagName: string]: {\n    component: ComponentClass | (() => Promise<ComponentClass>);\n    nodes?: KNode[];\n    lazy?: boolean;\n    fallback?: ComponentClass;\n  };\n}\n","import { Token, TokenType } from 'token';\n\nexport abstract class Expr {\n  public result: any;\n  public line: number;\n  // tslint:disable-next-line\n  constructor() { }\n  public abstract accept<R>(visitor: ExprVisitor<R>): R;\n}\n\n// tslint:disable-next-line\nexport interface ExprVisitor<R> {\n    visitArrowFunctionExpr(expr: ArrowFunction): R;\n    visitAssignExpr(expr: Assign): R;\n    visitBinaryExpr(expr: Binary): R;\n    visitCallExpr(expr: Call): R;\n    visitDebugExpr(expr: Debug): R;\n    visitDictionaryExpr(expr: Dictionary): R;\n    visitEachExpr(expr: Each): R;\n    visitGetExpr(expr: Get): R;\n    visitGroupingExpr(expr: Grouping): R;\n    visitKeyExpr(expr: Key): R;\n    visitLogicalExpr(expr: Logical): R;\n    visitListExpr(expr: List): R;\n    visitLiteralExpr(expr: Literal): R;\n    visitNewExpr(expr: New): R;\n    visitNullCoalescingExpr(expr: NullCoalescing): R;\n    visitPostfixExpr(expr: Postfix): R;\n    visitSetExpr(expr: Set): R;\n    visitPipelineExpr(expr: Pipeline): R;\n    visitSpreadExpr(expr: Spread): R;\n    visitTemplateExpr(expr: Template): R;\n    visitTernaryExpr(expr: Ternary): R;\n    visitTypeofExpr(expr: Typeof): R;\n    visitUnaryExpr(expr: Unary): R;\n    visitVariableExpr(expr: Variable): R;\n    visitVoidExpr(expr: Void): R;\n}\n\nexport class ArrowFunction extends Expr {\n    public params: Token[];\n    public body: Expr;\n\n    constructor(params: Token[], body: Expr, line: number) {\n        super();\n        this.params = params;\n        this.body = body;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitArrowFunctionExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.ArrowFunction';\n  }\n}\n\nexport class Assign extends Expr {\n    public name: Token;\n    public value: Expr;\n\n    constructor(name: Token, value: Expr, line: number) {\n        super();\n        this.name = name;\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitAssignExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Assign';\n  }\n}\n\nexport class Binary extends Expr {\n    public left: Expr;\n    public operator: Token;\n    public right: Expr;\n\n    constructor(left: Expr, operator: Token, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitBinaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Binary';\n  }\n}\n\nexport class Call extends Expr {\n    public callee: Expr;\n    public paren: Token;\n    public args: Expr[];\n    public optional: boolean;\n\n    constructor(callee: Expr, paren: Token, args: Expr[], line: number, optional = false) {\n        super();\n        this.callee = callee;\n        this.paren = paren;\n        this.args = args;\n        this.line = line;\n        this.optional = optional;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitCallExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Call';\n  }\n}\n\nexport class Debug extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitDebugExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Debug';\n  }\n}\n\nexport class Dictionary extends Expr {\n    public properties: Expr[];\n\n    constructor(properties: Expr[], line: number) {\n        super();\n        this.properties = properties;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitDictionaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Dictionary';\n  }\n}\n\nexport class Each extends Expr {\n    public name: Token;\n    public key: Token;\n    public iterable: Expr;\n\n    constructor(name: Token, key: Token, iterable: Expr, line: number) {\n        super();\n        this.name = name;\n        this.key = key;\n        this.iterable = iterable;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitEachExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Each';\n  }\n}\n\nexport class Get extends Expr {\n    public entity: Expr;\n    public key: Expr;\n    public type: TokenType;\n\n    constructor(entity: Expr, key: Expr, type: TokenType, line: number) {\n        super();\n        this.entity = entity;\n        this.key = key;\n        this.type = type;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitGetExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Get';\n  }\n}\n\nexport class Grouping extends Expr {\n    public expression: Expr;\n\n    constructor(expression: Expr, line: number) {\n        super();\n        this.expression = expression;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitGroupingExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Grouping';\n  }\n}\n\nexport class Key extends Expr {\n    public name: Token;\n\n    constructor(name: Token, line: number) {\n        super();\n        this.name = name;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitKeyExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Key';\n  }\n}\n\nexport class Logical extends Expr {\n    public left: Expr;\n    public operator: Token;\n    public right: Expr;\n\n    constructor(left: Expr, operator: Token, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitLogicalExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Logical';\n  }\n}\n\nexport class List extends Expr {\n    public value: Expr[];\n\n    constructor(value: Expr[], line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitListExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.List';\n  }\n}\n\nexport class Literal extends Expr {\n    public value: any;\n\n    constructor(value: any, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitLiteralExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Literal';\n  }\n}\n\nexport class New extends Expr {\n    public clazz: Expr;\n    public args: Expr[];\n\n    constructor(clazz: Expr, args: Expr[], line: number) {\n        super();\n        this.clazz = clazz;\n        this.args = args;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitNewExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.New';\n  }\n}\n\nexport class NullCoalescing extends Expr {\n    public left: Expr;\n    public right: Expr;\n\n    constructor(left: Expr, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitNullCoalescingExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.NullCoalescing';\n  }\n}\n\nexport class Postfix extends Expr {\n    public entity: Expr;\n    public increment: number;\n\n    constructor(entity: Expr, increment: number, line: number) {\n        super();\n        this.entity = entity;\n        this.increment = increment;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitPostfixExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Postfix';\n  }\n}\n\nexport class Set extends Expr {\n    public entity: Expr;\n    public key: Expr;\n    public value: Expr;\n\n    constructor(entity: Expr, key: Expr, value: Expr, line: number) {\n        super();\n        this.entity = entity;\n        this.key = key;\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitSetExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Set';\n  }\n}\n\nexport class Pipeline extends Expr {\n    public left: Expr;\n    public right: Expr;\n\n    constructor(left: Expr, right: Expr, line: number) {\n        super();\n        this.left = left;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitPipelineExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Pipeline';\n  }\n}\n\nexport class Spread extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitSpreadExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Spread';\n  }\n}\n\nexport class Template extends Expr {\n    public value: string;\n\n    constructor(value: string, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTemplateExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Template';\n  }\n}\n\nexport class Ternary extends Expr {\n    public condition: Expr;\n    public thenExpr: Expr;\n    public elseExpr: Expr;\n\n    constructor(condition: Expr, thenExpr: Expr, elseExpr: Expr, line: number) {\n        super();\n        this.condition = condition;\n        this.thenExpr = thenExpr;\n        this.elseExpr = elseExpr;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTernaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Ternary';\n  }\n}\n\nexport class Typeof extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitTypeofExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Typeof';\n  }\n}\n\nexport class Unary extends Expr {\n    public operator: Token;\n    public right: Expr;\n\n    constructor(operator: Token, right: Expr, line: number) {\n        super();\n        this.operator = operator;\n        this.right = right;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitUnaryExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Unary';\n  }\n}\n\nexport class Variable extends Expr {\n    public name: Token;\n\n    constructor(name: Token, line: number) {\n        super();\n        this.name = name;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitVariableExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Variable';\n  }\n}\n\nexport class Void extends Expr {\n    public value: Expr;\n\n    constructor(value: Expr, line: number) {\n        super();\n        this.value = value;\n        this.line = line;\n    }\n\n  public accept<R>(visitor: ExprVisitor<R>): R {\n      return visitor.visitVoidExpr(this);\n  }\n\n  public toString(): string {\n      return 'Expr.Void';\n  }\n}\n\n","export enum TokenType {\r\n  // Parser Tokens\r\n  Eof,\r\n  Panic,\r\n\r\n  // Single Character Tokens\r\n  Ampersand,\r\n  AtSign,\r\n  Caret,\r\n  Comma,\r\n  Dollar,\r\n  Dot,\r\n  Hash,\r\n  LeftBrace,\r\n  LeftBracket,\r\n  LeftParen,\r\n  Percent,\r\n  Pipe,\r\n  RightBrace,\r\n  RightBracket,\r\n  RightParen,\r\n  Semicolon,\r\n  Slash,\r\n  Star,\r\n\r\n  // One Or Two Character Tokens\r\n  Arrow,\r\n  Bang,\r\n  BangEqual,\r\n  BangEqualEqual,\r\n  Colon,\r\n  Equal,\r\n  EqualEqual,\r\n  EqualEqualEqual,\r\n  Greater,\r\n  GreaterEqual,\r\n  Less,\r\n  LessEqual,\r\n  Minus,\r\n  MinusEqual,\r\n  MinusMinus,\r\n  PercentEqual,\r\n  Plus,\r\n  PlusEqual,\r\n  PlusPlus,\r\n  Question,\r\n  QuestionDot,\r\n  QuestionQuestion,\r\n  SlashEqual,\r\n  StarEqual,\r\n  DotDot,\r\n  DotDotDot,\r\n  LessEqualGreater,\r\n\r\n  // Literals\r\n  Identifier,\r\n  Template,\r\n  String,\r\n  Number,\r\n\r\n  // One Or Two Character Tokens (bitwise shifts)\r\n  LeftShift,\r\n  RightShift,\r\n  Pipeline,\r\n  Tilde,\r\n\r\n  // Keywords\r\n  And,\r\n  Const,\r\n  Debug,\r\n  False,\r\n  In,\r\n  Instanceof,\r\n  New,\r\n  Null,\r\n  Undefined,\r\n  Of,\r\n  Or,\r\n  True,\r\n  Typeof,\r\n  Void,\r\n  With,\r\n}\r\n\r\nexport class Token {\r\n  public name: string;\r\n  public line: number;\r\n  public col: number;\r\n  public type: TokenType;\r\n  public literal: any;\r\n  public lexeme: string;\r\n\r\n  constructor(\r\n    type: TokenType,\r\n    lexeme: string,\r\n    literal: any,\r\n    line: number,\r\n    col: number\r\n  ) {\r\n    this.name = TokenType[type];\r\n    this.type = type;\r\n    this.lexeme = lexeme;\r\n    this.literal = literal;\r\n    this.line = line;\r\n    this.col = col;\r\n  }\r\n\r\n  public toString() {\r\n    return `[(${this.line}):\"${this.lexeme}\"]`;\r\n  }\r\n}\r\n\r\nexport const WhiteSpaces = [\" \", \"\\n\", \"\\t\", \"\\r\"] as const;\r\n\r\nexport const SelfClosingTags = [\r\n  \"area\",\r\n  \"base\",\r\n  \"br\",\r\n  \"col\",\r\n  \"embed\",\r\n  \"hr\",\r\n  \"img\",\r\n  \"input\",\r\n  \"link\",\r\n  \"meta\",\r\n  \"param\",\r\n  \"source\",\r\n  \"track\",\r\n  \"wbr\",\r\n];\r\n","import { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport * as Expr from \"./types/expressions\";\nimport { Token, TokenType } from \"./types/token\";\n\nexport class ExpressionParser {\n  private current: number;\n  private tokens: Token[];\n  private source: string;\n\n  public parse(tokens: Token[], source = \"\"): Expr.Expr[] {\n    this.current = 0;\n    this.tokens = tokens;\n    this.source = source;\n    const expressions: Expr.Expr[] = [];\n    while (!this.eof()) {\n      expressions.push(this.expression());\n    }\n    return expressions;\n  }\n\n  private match(...types: TokenType[]): boolean {\n    for (const type of types) {\n      if (this.check(type)) {\n        this.advance();\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private advance(): Token {\n    if (!this.eof()) {\n      this.current++;\n    }\n    return this.previous();\n  }\n\n  private peek(): Token {\n    return this.tokens[this.current];\n  }\n\n  private previous(): Token {\n    return this.tokens[this.current - 1];\n  }\n\n  private check(type: TokenType): boolean {\n    return this.peek().type === type;\n  }\n\n  private eof(): boolean {\n    return this.check(TokenType.Eof);\n  }\n\n  private consume(type: TokenType, message: string): Token {\n    if (this.check(type)) {\n      return this.advance();\n    }\n\n    return this.error(\n      KErrorCode.UNEXPECTED_TOKEN,\n      this.peek(),\n      { message: message, token: this.peek().lexeme }\n    );\n  }\n\n  private error(code: KErrorCodeType, token: Token, args: any = {}): any {\n    throw new KasperError(code, args, { line: token.line, col: token.col, source: this.source });\n  }\n\n  private synchronize(): void {\n    do {\n      if (this.check(TokenType.Semicolon) || this.check(TokenType.RightBrace)) {\n        this.advance();\n        return;\n      }\n      this.advance();\n    } while (!this.eof());\n  }\n\n  public foreach(tokens: Token[]): Expr.Expr {\n    this.current = 0;\n    this.tokens = tokens;\n\n    const name = this.consume(\n      TokenType.Identifier,\n      `Expected an identifier inside \"each\" statement`\n    );\n\n    let key: Token = null;\n    if (this.match(TokenType.With)) {\n      key = this.consume(\n        TokenType.Identifier,\n        `Expected a \"key\" identifier after \"with\" keyword in foreach statement`\n      );\n    }\n\n    this.consume(\n      TokenType.Of,\n      `Expected \"of\" keyword inside foreach statement`\n    );\n    const iterable = this.expression();\n\n    return new Expr.Each(name, key, iterable, name.line);\n  }\n\n  private expression(): Expr.Expr {\n    const expression: Expr.Expr = this.assignment();\n    if (this.match(TokenType.Semicolon)) {\n      // consume all semicolons\n      // tslint:disable-next-line\n      while (this.match(TokenType.Semicolon)) { /* consume semicolons */ }\n    }\n    return expression;\n  }\n\n  private assignment(): Expr.Expr {\n    const expr: Expr.Expr = this.pipeline();\n    if (\n      this.match(\n        TokenType.Equal,\n        TokenType.PlusEqual,\n        TokenType.MinusEqual,\n        TokenType.StarEqual,\n        TokenType.SlashEqual\n      )\n    ) {\n      const operator: Token = this.previous();\n      let value: Expr.Expr = this.assignment();\n      if (expr instanceof Expr.Variable) {\n        const name: Token = expr.name;\n        if (operator.type !== TokenType.Equal) {\n          value = new Expr.Binary(\n            new Expr.Variable(name, name.line),\n            operator,\n            value,\n            operator.line\n          );\n        }\n        return new Expr.Assign(name, value, name.line);\n      } else if (expr instanceof Expr.Get) {\n        if (operator.type !== TokenType.Equal) {\n          value = new Expr.Binary(\n            new Expr.Get(expr.entity, expr.key, expr.type, expr.line),\n            operator,\n            value,\n            operator.line\n          );\n        }\n        return new Expr.Set(expr.entity, expr.key, value, expr.line);\n      }\n      this.error(KErrorCode.INVALID_LVALUE, operator);\n    }\n    return expr;\n  }\n\n  private pipeline(): Expr.Expr {\n    let expr = this.ternary();\n    while (this.match(TokenType.Pipeline)) {\n      const right = this.ternary();\n      expr = new Expr.Pipeline(expr, right, expr.line);\n    }\n    return expr;\n  }\n\n  private ternary(): Expr.Expr {\n    const expr = this.nullCoalescing();\n    if (this.match(TokenType.Question)) {\n      const thenExpr: Expr.Expr = this.ternary();\n      this.consume(TokenType.Colon, `Expected \":\" after ternary ? expression`);\n      const elseExpr: Expr.Expr = this.ternary();\n      return new Expr.Ternary(expr, thenExpr, elseExpr, expr.line);\n    }\n    return expr;\n  }\n\n  private nullCoalescing(): Expr.Expr {\n    const expr = this.logicalOr();\n    if (this.match(TokenType.QuestionQuestion)) {\n      const rightExpr: Expr.Expr = this.nullCoalescing();\n      return new Expr.NullCoalescing(expr, rightExpr, expr.line);\n    }\n    return expr;\n  }\n\n  private logicalOr(): Expr.Expr {\n    let expr = this.logicalAnd();\n    while (this.match(TokenType.Or)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.logicalAnd();\n      expr = new Expr.Logical(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private logicalAnd(): Expr.Expr {\n    let expr = this.equality();\n    while (this.match(TokenType.And)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.equality();\n      expr = new Expr.Logical(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private equality(): Expr.Expr {\n    let expr: Expr.Expr = this.shift();\n    while (\n      this.match(\n        TokenType.BangEqual,\n        TokenType.BangEqualEqual,\n        TokenType.EqualEqual,\n        TokenType.EqualEqualEqual,\n        TokenType.Greater,\n        TokenType.GreaterEqual,\n        TokenType.Less,\n        TokenType.LessEqual,\n        TokenType.Instanceof,\n        TokenType.In,\n      )\n    ) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.shift();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private shift(): Expr.Expr {\n    let expr: Expr.Expr = this.addition();\n    while (this.match(TokenType.LeftShift, TokenType.RightShift)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.addition();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private addition(): Expr.Expr {\n    let expr: Expr.Expr = this.modulus();\n    while (this.match(TokenType.Minus, TokenType.Plus)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.modulus();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private modulus(): Expr.Expr {\n    let expr: Expr.Expr = this.multiplication();\n    while (this.match(TokenType.Percent)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.multiplication();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private multiplication(): Expr.Expr {\n    let expr: Expr.Expr = this.typeof();\n    while (this.match(TokenType.Slash, TokenType.Star)) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.typeof();\n      expr = new Expr.Binary(expr, operator, right, operator.line);\n    }\n    return expr;\n  }\n\n  private typeof(): Expr.Expr {\n    if (this.match(TokenType.Typeof)) {\n      const operator: Token = this.previous();\n      const value: Expr.Expr = this.typeof();\n      return new Expr.Typeof(value, operator.line);\n    }\n    return this.unary();\n  }\n\n  private unary(): Expr.Expr {\n    if (\n      this.match(\n        TokenType.Minus,\n        TokenType.Bang,\n        TokenType.Tilde,\n        TokenType.Dollar,\n        TokenType.PlusPlus,\n        TokenType.MinusMinus\n      )\n    ) {\n      const operator: Token = this.previous();\n      const right: Expr.Expr = this.unary();\n      return new Expr.Unary(operator, right, operator.line);\n    }\n    return this.newKeyword();\n  }\n\n  private newKeyword(): Expr.Expr {\n    if (this.match(TokenType.New)) {\n      const keyword = this.previous();\n      const construct: Expr.Expr = this.call();\n      if (construct instanceof Expr.Call) {\n        return new Expr.New(construct.callee, construct.args, keyword.line);\n      }\n      return new Expr.New(construct, [], keyword.line);\n    }\n    return this.postfix();\n  }\n\n  private postfix(): Expr.Expr {\n    const expr = this.call();\n    if (this.match(TokenType.PlusPlus)) {\n      return new Expr.Postfix(expr, 1, expr.line);\n    }\n    if (this.match(TokenType.MinusMinus)) {\n      return new Expr.Postfix(expr, -1, expr.line);\n    }\n    return expr;\n  }\n\n  private call(): Expr.Expr {\n    let expr: Expr.Expr = this.primary();\n    let consumed: boolean;\n    do {\n      consumed = false;\n      if (this.match(TokenType.LeftParen)) {\n        consumed = true;\n        do {\n          expr = this.finishCall(expr, this.previous(), false);\n        } while (this.match(TokenType.LeftParen));\n      }\n      if (this.match(TokenType.Dot, TokenType.QuestionDot)) {\n        consumed = true;\n        const operator = this.previous();\n        if (operator.type === TokenType.QuestionDot && this.match(TokenType.LeftBracket)) {\n          expr = this.bracketGet(expr, operator);\n        } else if (operator.type === TokenType.QuestionDot && this.match(TokenType.LeftParen)) {\n          expr = this.finishCall(expr, this.previous(), true);\n        } else {\n          expr = this.dotGet(expr, operator);\n        }\n      }\n      if (this.match(TokenType.LeftBracket)) {\n        consumed = true;\n        expr = this.bracketGet(expr, this.previous());\n      }\n    } while (consumed);\n    return expr;\n  }\n\n  private tokenAt(offset: number): TokenType {\n    return this.tokens[this.current + offset]?.type;\n  }\n\n  private isArrowParams(): boolean {\n    let i = this.current + 1; // skip (\n    if (this.tokens[i]?.type === TokenType.RightParen) {\n      return this.tokens[i + 1]?.type === TokenType.Arrow;\n    }\n    while (i < this.tokens.length) {\n      if (this.tokens[i]?.type !== TokenType.Identifier) return false;\n      i++;\n      if (this.tokens[i]?.type === TokenType.RightParen) {\n        return this.tokens[i + 1]?.type === TokenType.Arrow;\n      }\n      if (this.tokens[i]?.type !== TokenType.Comma) return false;\n      i++;\n    }\n    return false;\n  }\n\n  private finishCall(callee: Expr.Expr, paren: Token, optional: boolean): Expr.Expr {\n    const args: Expr.Expr[] = [];\n    if (!this.check(TokenType.RightParen)) {\n      do {\n        if (this.match(TokenType.DotDotDot)) {\n          args.push(new Expr.Spread(this.expression(), this.previous().line));\n        } else {\n          args.push(this.expression());\n        }\n      } while (this.match(TokenType.Comma));\n    }\n    const closeParen = this.consume(TokenType.RightParen, `Expected \")\" after arguments`);\n    return new Expr.Call(callee, closeParen, args, closeParen.line, optional);\n  }\n\n  private dotGet(expr: Expr.Expr, operator: Token): Expr.Expr {\n    const name: Token = this.consume(\n      TokenType.Identifier,\n      `Expect property name after '.'`\n    );\n    const key: Expr.Key = new Expr.Key(name, name.line);\n    return new Expr.Get(expr, key, operator.type, name.line);\n  }\n\n  private bracketGet(expr: Expr.Expr, operator: Token): Expr.Expr {\n    let key: Expr.Expr = null;\n\n    if (!this.check(TokenType.RightBracket)) {\n      key = this.expression();\n    }\n\n    this.consume(TokenType.RightBracket, `Expected \"]\" after an index`);\n    return new Expr.Get(expr, key, operator.type, operator.line);\n  }\n\n  private primary(): Expr.Expr {\n    if (this.match(TokenType.False)) {\n      return new Expr.Literal(false, this.previous().line);\n    }\n    if (this.match(TokenType.True)) {\n      return new Expr.Literal(true, this.previous().line);\n    }\n    if (this.match(TokenType.Null)) {\n      return new Expr.Literal(null, this.previous().line);\n    }\n    if (this.match(TokenType.Undefined)) {\n      return new Expr.Literal(undefined, this.previous().line);\n    }\n    if (this.match(TokenType.Number) || this.match(TokenType.String)) {\n      return new Expr.Literal(this.previous().literal, this.previous().line);\n    }\n    if (this.match(TokenType.Template)) {\n      return new Expr.Template(this.previous().literal, this.previous().line);\n    }\n    if (this.check(TokenType.Identifier) && this.tokenAt(1) === TokenType.Arrow) {\n      const param = this.advance();\n      this.advance(); // consume =>\n      const body = this.expression();\n      return new Expr.ArrowFunction([param], body, param.line);\n    }\n    if (this.match(TokenType.Identifier)) {\n      const identifier = this.previous();\n      return new Expr.Variable(identifier, identifier.line);\n    }\n    if (this.check(TokenType.LeftParen) && this.isArrowParams()) {\n      this.advance(); // consume (\n      const params: Token[] = [];\n      if (!this.check(TokenType.RightParen)) {\n        do {\n          params.push(this.consume(TokenType.Identifier, \"Expected parameter name\"));\n        } while (this.match(TokenType.Comma));\n      }\n      this.consume(TokenType.RightParen, `Expected \")\"`);\n      this.consume(TokenType.Arrow, `Expected \"=>\"`);\n      const body = this.expression();\n      return new Expr.ArrowFunction(params, body, this.previous().line);\n    }\n    if (this.match(TokenType.LeftParen)) {\n      const expr: Expr.Expr = this.expression();\n      this.consume(TokenType.RightParen, `Expected \")\" after expression`);\n      return new Expr.Grouping(expr, expr.line);\n    }\n    if (this.match(TokenType.LeftBrace)) {\n      return this.dictionary();\n    }\n    if (this.match(TokenType.LeftBracket)) {\n      return this.list();\n    }\n    if (this.match(TokenType.Void)) {\n      const expr: Expr.Expr = this.expression();\n      return new Expr.Void(expr, this.previous().line);\n    }\n    if (this.match(TokenType.Debug)) {\n      const expr: Expr.Expr = this.expression();\n      return new Expr.Debug(expr, this.previous().line);\n    }\n\n    throw this.error(\n      KErrorCode.EXPECTED_EXPRESSION,\n      this.peek(),\n      { token: this.peek().lexeme }\n    );\n    // unreacheable code\n    return new Expr.Literal(null, 0);\n  }\n\n  public dictionary(): Expr.Expr {\n    const leftBrace = this.previous();\n    if (this.match(TokenType.RightBrace)) {\n      return new Expr.Dictionary([], this.previous().line);\n    }\n    const properties: Expr.Expr[] = [];\n    do {\n      if (this.match(TokenType.DotDotDot)) {\n        properties.push(new Expr.Spread(this.expression(), this.previous().line));\n      } else if (\n        this.match(TokenType.String, TokenType.Identifier, TokenType.Number)\n      ) {\n        const key: Token = this.previous();\n        if (this.match(TokenType.Colon)) {\n          const value = this.expression();\n          properties.push(\n            new Expr.Set(null, new Expr.Key(key, key.line), value, key.line)\n          );\n        } else {\n          const value = new Expr.Variable(key, key.line);\n          properties.push(\n            new Expr.Set(null, new Expr.Key(key, key.line), value, key.line)\n          );\n        }\n      } else {\n        this.error(\n          KErrorCode.INVALID_DICTIONARY_KEY,\n          this.peek(),\n          { token: this.peek().lexeme }\n        );\n      }\n    } while (this.match(TokenType.Comma));\n    this.consume(TokenType.RightBrace, `Expected \"}\" after object literal`);\n\n    return new Expr.Dictionary(properties, leftBrace.line);\n  }\n\n  private list(): Expr.Expr {\n    const values: Expr.Expr[] = [];\n    const leftBracket = this.previous();\n\n    if (this.match(TokenType.RightBracket)) {\n      return new Expr.List([], this.previous().line);\n    }\n    do {\n      if (this.match(TokenType.DotDotDot)) {\n        values.push(new Expr.Spread(this.expression(), this.previous().line));\n      } else {\n        values.push(this.expression());\n      }\n    } while (this.match(TokenType.Comma));\n\n    this.consume(\n      TokenType.RightBracket,\n      `Expected \"]\" after array declaration`\n    );\n    return new Expr.List(values, leftBracket.line);\n  }\n}\n","import { TokenType } from \"./types/token\";\n\nexport function isDigit(char: string): boolean {\n  return char >= \"0\" && char <= \"9\";\n}\n\nexport function isAlpha(char: string): boolean {\n  return (\n    (char >= \"a\" && char <= \"z\") || (char >= \"A\" && char <= \"Z\") || char === \"$\" || char === \"_\"\n  );\n}\n\nexport function isAlphaNumeric(char: string): boolean {\n  return isAlpha(char) || isDigit(char);\n}\n\nexport function capitalize(word: string): string {\n  return word.charAt(0).toUpperCase() + word.substring(1).toLowerCase();\n}\n\nexport function isKeyword(word: keyof typeof TokenType): boolean {\n  return TokenType[word] >= TokenType.And;\n}\n","import * as Utils from \"./utils\";\nimport { Token, TokenType } from \"./types/token\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\n\nexport class Scanner {\n  /** scripts source code */\n  public source: string;\n  /** contains the source code represented as list of tokens */\n  public tokens: Token[];\n  /** points to the current character being tokenized */\n  private current: number;\n  /** points to the start of the token  */\n  private start: number;\n  /** current line of source code being tokenized */\n  private line: number;\n  /** current column of the character being tokenized */\n  private col: number;\n\n  public scan(source: string): Token[] {\n    this.source = source;\n    this.tokens = [];\n    this.current = 0;\n    this.start = 0;\n    this.line = 1;\n    this.col = 1;\n\n    while (!this.eof()) {\n      this.start = this.current;\n      this.getToken();\n    }\n    this.tokens.push(new Token(TokenType.Eof, \"\", null, this.line, 0));\n    return this.tokens;\n  }\n\n  private eof(): boolean {\n    return this.current >= this.source.length;\n  }\n\n  private advance(): string {\n    if (this.peek() === \"\\n\") {\n      this.line++;\n      this.col = 0;\n    }\n    this.current++;\n    this.col++;\n    return this.source.charAt(this.current - 1);\n  }\n\n  private addToken(tokenType: TokenType, literal: any): void {\n    const text = this.source.substring(this.start, this.current);\n    this.tokens.push(new Token(tokenType, text, literal, this.line, this.col));\n  }\n\n  private match(expected: string): boolean {\n    if (this.eof()) {\n      return false;\n    }\n\n    if (this.source.charAt(this.current) !== expected) {\n      return false;\n    }\n\n    this.current++;\n    return true;\n  }\n\n  private peek(): string {\n    if (this.eof()) {\n      return \"\\0\";\n    }\n    return this.source.charAt(this.current);\n  }\n\n  private peekNext(): string {\n    if (this.current + 1 >= this.source.length) {\n      return \"\\0\";\n    }\n    return this.source.charAt(this.current + 1);\n  }\n\n  private comment(): void {\n    while (this.peek() !== \"\\n\" && !this.eof()) {\n      this.advance();\n    }\n  }\n\n  private multilineComment(): void {\n    while (!this.eof() && !(this.peek() === \"*\" && this.peekNext() === \"/\")) {\n      this.advance();\n    }\n    if (this.eof()) {\n      this.error(KErrorCode.UNTERMINATED_COMMENT);\n    } else {\n      // the closing slash '*/'\n      this.advance();\n      this.advance();\n    }\n  }\n\n  private string(quote: string): void {\n    while (this.peek() !== quote && !this.eof()) {\n      this.advance();\n    }\n\n    // Unterminated string.\n    if (this.eof()) {\n      this.error(KErrorCode.UNTERMINATED_STRING, { quote: quote });\n      return;\n    }\n\n    // The closing \".\n    this.advance();\n\n    // Trim the surrounding quotes.\n    const value = this.source.substring(this.start + 1, this.current - 1);\n    this.addToken(quote !== \"`\" ? TokenType.String : TokenType.Template, value);\n  }\n\n  private number(): void {\n    // gets integer part\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    // checks for fraction\n    if (this.peek() === \".\" && Utils.isDigit(this.peekNext())) {\n      this.advance();\n    }\n\n    // gets fraction part\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    // checks for exponent\n    if (this.peek().toLowerCase() === \"e\") {\n      this.advance();\n      if (this.peek() === \"-\" || this.peek() === \"+\") {\n        this.advance();\n      }\n    }\n\n    while (Utils.isDigit(this.peek())) {\n      this.advance();\n    }\n\n    const value = this.source.substring(this.start, this.current);\n    this.addToken(TokenType.Number, Number(value));\n  }\n\n  private identifier(): void {\n    while (Utils.isAlphaNumeric(this.peek())) {\n      this.advance();\n    }\n\n    const value = this.source.substring(this.start, this.current);\n    const capitalized = Utils.capitalize(value) as keyof typeof TokenType;\n    if (Utils.isKeyword(capitalized)) {\n      this.addToken(TokenType[capitalized], value);\n    } else {\n      this.addToken(TokenType.Identifier, value);\n    }\n  }\n\n  private getToken(): void {\n    const char = this.advance();\n    switch (char) {\n      case \"(\":\n        this.addToken(TokenType.LeftParen, null);\n        break;\n      case \")\":\n        this.addToken(TokenType.RightParen, null);\n        break;\n      case \"[\":\n        this.addToken(TokenType.LeftBracket, null);\n        break;\n      case \"]\":\n        this.addToken(TokenType.RightBracket, null);\n        break;\n      case \"{\":\n        this.addToken(TokenType.LeftBrace, null);\n        break;\n      case \"}\":\n        this.addToken(TokenType.RightBrace, null);\n        break;\n      case \",\":\n        this.addToken(TokenType.Comma, null);\n        break;\n      case \";\":\n        this.addToken(TokenType.Semicolon, null);\n        break;\n      case \"~\":\n        this.addToken(TokenType.Tilde, null);\n        break;\n      case \"^\":\n        this.addToken(TokenType.Caret, null);\n        break;\n      case \"#\":\n        this.addToken(TokenType.Hash, null);\n        break;\n      case \":\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.Arrow : TokenType.Colon,\n          null\n        );\n        break;\n      case \"*\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.StarEqual : TokenType.Star,\n          null\n        );\n        break;\n      case \"%\":\n        this.addToken(\n          this.match(\"=\") ? TokenType.PercentEqual : TokenType.Percent,\n          null\n        );\n        break;\n      case \"|\":\n        this.addToken(\n          this.match(\"|\") ? TokenType.Or :\n          this.match(\">\") ? TokenType.Pipeline :\n          TokenType.Pipe,\n          null\n        );\n        break;\n      case \"&\":\n        this.addToken(\n          this.match(\"&\") ? TokenType.And : TokenType.Ampersand,\n          null\n        );\n        break;\n      case \">\":\n        this.addToken(\n          this.match(\">\") ? TokenType.RightShift :\n          this.match(\"=\") ? TokenType.GreaterEqual : TokenType.Greater,\n          null\n        );\n        break;\n      case \"!\":\n        this.addToken(\n          this.match(\"=\")\n            ? this.match(\"=\") ? TokenType.BangEqualEqual : TokenType.BangEqual\n            : TokenType.Bang,\n          null\n        );\n        break;\n      case \"?\":\n        this.addToken(\n          this.match(\"?\")\n            ? TokenType.QuestionQuestion\n            : this.match(\".\")\n            ? TokenType.QuestionDot\n            : TokenType.Question,\n          null\n        );\n        break;\n      case \"=\":\n        if (this.match(\"=\")) {\n          this.addToken(\n            this.match(\"=\") ? TokenType.EqualEqualEqual : TokenType.EqualEqual,\n            null\n          );\n          break;\n        }\n        this.addToken(\n          this.match(\">\") ? TokenType.Arrow : TokenType.Equal,\n          null\n        );\n        break;\n      case \"+\":\n        this.addToken(\n          this.match(\"+\")\n            ? TokenType.PlusPlus\n            : this.match(\"=\")\n            ? TokenType.PlusEqual\n            : TokenType.Plus,\n          null\n        );\n        break;\n      case \"-\":\n        this.addToken(\n          this.match(\"-\")\n            ? TokenType.MinusMinus\n            : this.match(\"=\")\n            ? TokenType.MinusEqual\n            : TokenType.Minus,\n          null\n        );\n        break;\n      case \"<\":\n        this.addToken(\n          this.match(\"<\") ? TokenType.LeftShift :\n          this.match(\"=\")\n            ? this.match(\">\")\n              ? TokenType.LessEqualGreater\n              : TokenType.LessEqual\n            : TokenType.Less,\n          null\n        );\n        break;\n      case \".\":\n        if (this.match(\".\")) {\n          if (this.match(\".\")) {\n            this.addToken(TokenType.DotDotDot, null);\n          } else {\n            this.addToken(TokenType.DotDot, null);\n          }\n        } else {\n          this.addToken(TokenType.Dot, null);\n        }\n        break;\n      case \"/\":\n        if (this.match(\"/\")) {\n          this.comment();\n        } else if (this.match(\"*\")) {\n          this.multilineComment();\n        } else {\n          this.addToken(\n            this.match(\"=\") ? TokenType.SlashEqual : TokenType.Slash,\n            null\n          );\n        }\n        break;\n      case `'`:\n      case `\"`:\n      case \"`\":\n        this.string(char);\n        break;\n      // ignore cases\n      case \"\\n\":\n      case \" \":\n      case \"\\r\":\n      case \"\\t\":\n        break;\n      // complex cases\n      default:\n        if (Utils.isDigit(char)) {\n          this.number();\n        } else if (Utils.isAlpha(char)) {\n          this.identifier();\n        } else {\n          this.error(KErrorCode.UNEXPECTED_CHARACTER, { char: char });\n        }\n        break;\n    }\n  }\n\n  private error(code: KErrorCodeType, args: any = {}): void {\n    throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source });\n  }\n}\n","export class Scope {\n  public values: Record<string, any>;\n  public parent: Scope;\n\n  constructor(parent?: Scope, entity?: Record<string, any>) {\n    this.parent = parent ? parent : null;\n    this.values = entity ? entity : {};\n  }\n\n  public init(entity?: Record<string, any>): void {\n    this.values = entity ? entity : {};\n  }\n\n  public set(name: string, value: any) {\n    this.values[name] = value;\n  }\n\n  public get(key: string): any {\n    if (typeof this.values[key] !== \"undefined\") {\n      return this.values[key];\n    }\n\n    const $imports = (this.values?.constructor as any)?.$imports;\n    if ($imports && typeof $imports[key] !== \"undefined\") {\n      return $imports[key];\n    }\n\n    if (this.parent !== null) {\n      return this.parent.get(key);\n    }\n\n    return window[key as keyof typeof window];\n  }\n}\n","import * as Expr from \"./types/expressions\";\nimport { Scanner } from \"./scanner\";\nimport { ExpressionParser as Parser } from \"./expression-parser\";\nimport { Scope } from \"./scope\";\nimport { TokenType } from \"./types/token\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\n\nexport class Interpreter implements Expr.ExprVisitor<any> {\n  public scope = new Scope();\n  private scanner = new Scanner();\n  private parser = new Parser();\n\n  public evaluate(expr: Expr.Expr): any {\n    return (expr.result = expr.accept(this));\n  }\n\n  public visitPipelineExpr(expr: Expr.Pipeline): any {\n    const value = this.evaluate(expr.left);\n\n    if (expr.right instanceof Expr.Call) {\n      const callee = this.evaluate(expr.right.callee);\n      const args = [value];\n      for (const arg of expr.right.args) {\n        if (arg instanceof Expr.Spread) {\n          args.push(...this.evaluate((arg as Expr.Spread).value));\n        } else {\n          args.push(this.evaluate(arg));\n        }\n      }\n      if (expr.right.callee instanceof Expr.Get) {\n        return callee.apply(expr.right.callee.entity.result, args);\n      }\n      return callee(...args);\n    }\n\n    const fn = this.evaluate(expr.right);\n    return fn(value);\n  }\n\n  public visitArrowFunctionExpr(expr: Expr.ArrowFunction): any {\n    const capturedScope = this.scope;\n    return (...args: any[]) => {\n      const prev = this.scope;\n      this.scope = new Scope(capturedScope);\n      for (let i = 0; i < expr.params.length; i++) {\n        this.scope.set(expr.params[i].lexeme, args[i]);\n      }\n      try {\n        return this.evaluate(expr.body);\n      } finally {\n        this.scope = prev;\n      }\n    };\n  }\n\n  public error(code: KErrorCodeType, args: any = {}, line?: number, col?: number): void {\n    throw new KasperError(code, args, { line, col });\n  }\n\n  public visitVariableExpr(expr: Expr.Variable): any {\n    return this.scope.get(expr.name.lexeme);\n  }\n\n  public visitAssignExpr(expr: Expr.Assign): any {\n    const value = this.evaluate(expr.value);\n    this.scope.set(expr.name.lexeme, value);\n    return value;\n  }\n\n  public visitKeyExpr(expr: Expr.Key): any {\n    return expr.name.literal;\n  }\n\n  public visitGetExpr(expr: Expr.Get): any {\n    const entity = this.evaluate(expr.entity);\n    const key = this.evaluate(expr.key);\n    if (!entity && expr.type === TokenType.QuestionDot) {\n      return undefined;\n    }\n    return entity[key];\n  }\n\n  public visitSetExpr(expr: Expr.Set): any {\n    const entity = this.evaluate(expr.entity);\n    const key = this.evaluate(expr.key);\n    const value = this.evaluate(expr.value);\n    entity[key] = value;\n    return value;\n  }\n\n  public visitPostfixExpr(expr: Expr.Postfix): any {\n    const value = this.evaluate(expr.entity);\n    const newValue = value + expr.increment;\n\n    if (expr.entity instanceof Expr.Variable) {\n      this.scope.set(expr.entity.name.lexeme, newValue);\n    } else if (expr.entity instanceof Expr.Get) {\n      const assign = new Expr.Set(\n        expr.entity.entity,\n        expr.entity.key,\n        new Expr.Literal(newValue, expr.line),\n        expr.line\n      );\n      this.evaluate(assign);\n    } else {\n      this.error(KErrorCode.INVALID_POSTFIX_LVALUE, { entity: expr.entity }, expr.line);\n    }\n\n    return value;\n  }\n\n  public visitListExpr(expr: Expr.List): any {\n    const values: any[] = [];\n    for (const expression of expr.value) {\n      if (expression instanceof Expr.Spread) {\n        values.push(...this.evaluate((expression as Expr.Spread).value));\n      } else {\n        values.push(this.evaluate(expression));\n      }\n    }\n    return values;\n  }\n\n  public visitSpreadExpr(expr: Expr.Spread): any {\n    return this.evaluate(expr.value);\n  }\n\n  private templateParse(source: string): string {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens, source);\n    let result = \"\";\n    for (const expression of expressions) {\n      result += this.evaluate(expression).toString();\n    }\n    return result;\n  }\n\n  public visitTemplateExpr(expr: Expr.Template): any {\n    const result = expr.value.replace(\n      /\\{\\{([\\s\\S]+?)\\}\\}/g,\n      (m, placeholder) => {\n        return this.templateParse(placeholder);\n      }\n    );\n    return result;\n  }\n\n  public visitBinaryExpr(expr: Expr.Binary): any {\n    const left = this.evaluate(expr.left);\n    const right = this.evaluate(expr.right);\n\n    switch (expr.operator.type) {\n      case TokenType.Minus:\n      case TokenType.MinusEqual:\n        return left - right;\n      case TokenType.Slash:\n      case TokenType.SlashEqual:\n        return left / right;\n      case TokenType.Star:\n      case TokenType.StarEqual:\n        return left * right;\n      case TokenType.Percent:\n      case TokenType.PercentEqual:\n        return left % right;\n      case TokenType.Plus:\n      case TokenType.PlusEqual:\n        return left + right;\n      case TokenType.Pipe:\n        return left | right;\n      case TokenType.Caret:\n        return left ^ right;\n      case TokenType.Greater:\n        return left > right;\n      case TokenType.GreaterEqual:\n        return left >= right;\n      case TokenType.Less:\n        return left < right;\n      case TokenType.LessEqual:\n        return left <= right;\n      case TokenType.EqualEqual:\n      case TokenType.EqualEqualEqual:\n        return left === right;\n      case TokenType.BangEqual:\n      case TokenType.BangEqualEqual:\n        return left !== right;\n      case TokenType.Instanceof:\n        return left instanceof right;\n      case TokenType.In:\n        return left in right;\n      case TokenType.LeftShift:\n        return left << right;\n      case TokenType.RightShift:\n        return left >> right;\n      default:\n        this.error(KErrorCode.UNKNOWN_BINARY_OPERATOR, { operator: expr.operator }, expr.line);\n        return null; // unreachable\n    }\n  }\n\n  public visitLogicalExpr(expr: Expr.Logical): any {\n    const left = this.evaluate(expr.left);\n\n    if (expr.operator.type === TokenType.Or) {\n      if (left) {\n        return left;\n      }\n    } else {\n      if (!left) {\n        return left;\n      }\n    }\n\n    return this.evaluate(expr.right);\n  }\n\n  public visitTernaryExpr(expr: Expr.Ternary): any {\n    return this.evaluate(expr.condition)\n      ? this.evaluate(expr.thenExpr)\n      : this.evaluate(expr.elseExpr);\n  }\n\n  public visitNullCoalescingExpr(expr: Expr.NullCoalescing): any {\n    const left = this.evaluate(expr.left);\n    if (left == null) {\n      return this.evaluate(expr.right);\n    }\n    return left;\n  }\n\n  public visitGroupingExpr(expr: Expr.Grouping): any {\n    return this.evaluate(expr.expression);\n  }\n\n  public visitLiteralExpr(expr: Expr.Literal): any {\n    return expr.value;\n  }\n\n  public visitUnaryExpr(expr: Expr.Unary): any {\n    const right = this.evaluate(expr.right);\n    switch (expr.operator.type) {\n      case TokenType.Minus:\n        return -right;\n      case TokenType.Bang:\n        return !right;\n      case TokenType.Tilde:\n        return ~right;\n      case TokenType.PlusPlus:\n      case TokenType.MinusMinus: {\n        const newValue =\n          Number(right) + (expr.operator.type === TokenType.PlusPlus ? 1 : -1);\n        if (expr.right instanceof Expr.Variable) {\n          this.scope.set(expr.right.name.lexeme, newValue);\n        } else if (expr.right instanceof Expr.Get) {\n          const assign = new Expr.Set(\n            expr.right.entity,\n            expr.right.key,\n            new Expr.Literal(newValue, expr.line),\n            expr.line\n          );\n          this.evaluate(assign);\n        } else {\n          this.error(\n            KErrorCode.INVALID_PREFIX_RVALUE,\n            { right: expr.right },\n            expr.line\n          );\n        }\n        return newValue;\n      }\n      default:\n        this.error(KErrorCode.UNKNOWN_UNARY_OPERATOR, { operator: expr.operator }, expr.line);\n        return null; // should be unreachable\n    }\n  }\n\n  public visitCallExpr(expr: Expr.Call): any {\n    // verify callee is a function\n    const callee = this.evaluate(expr.callee);\n    if (callee == null && expr.optional) return undefined;\n    if (typeof callee !== \"function\") {\n      this.error(KErrorCode.NOT_A_FUNCTION, { callee: callee }, expr.line);\n    }\n    // evaluate function arguments\n    const args = [];\n    for (const argument of expr.args) {\n      if (argument instanceof Expr.Spread) {\n        args.push(...this.evaluate((argument as Expr.Spread).value));\n      } else {\n        args.push(this.evaluate(argument));\n      }\n    }\n    // execute function — preserve `this` for method calls\n    if (expr.callee instanceof Expr.Get) {\n      return callee.apply(expr.callee.entity.result, args);\n    } else {\n      return callee(...args);\n    }\n  }\n\n  public visitNewExpr(expr: Expr.New): any {\n    const clazz = this.evaluate(expr.clazz);\n\n    if (typeof clazz !== \"function\") {\n      this.error(\n        KErrorCode.NOT_A_CLASS,\n        { clazz: clazz },\n        expr.line\n      );\n    }\n\n    const args: any[] = [];\n    for (const arg of expr.args) {\n      args.push(this.evaluate(arg));\n    }\n    return new clazz(...args);\n  }\n\n  public visitDictionaryExpr(expr: Expr.Dictionary): any {\n    const dict: any = {};\n    for (const property of expr.properties) {\n      if (property instanceof Expr.Spread) {\n        Object.assign(dict, this.evaluate((property as Expr.Spread).value));\n      } else {\n        const key = this.evaluate((property as Expr.Set).key);\n        const value = this.evaluate((property as Expr.Set).value);\n        dict[key] = value;\n      }\n    }\n    return dict;\n  }\n\n  public visitTypeofExpr(expr: Expr.Typeof): any {\n    return typeof this.evaluate(expr.value);\n  }\n\n  public visitEachExpr(expr: Expr.Each): any {\n    return [\n      expr.name.lexeme,\n      expr.key ? expr.key.lexeme : null,\n      this.evaluate(expr.iterable),\n    ];\n  }\n\n  visitVoidExpr(expr: Expr.Void): any {\n    this.evaluate(expr.value);\n    return \"\";\n  }\n\n  visitDebugExpr(expr: Expr.Void): any {\n    const result = this.evaluate(expr.value);\n    console.log(result);\n    return \"\";\n  }\n}\n","export abstract class KNode {\n    public line: number;\n    public type: string;\n    public abstract accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R;\n}\n\nexport interface KNodeVisitor<R> {\n    visitElementKNode(knode: Element, parent?: Node): R;\n    visitAttributeKNode(knode: Attribute, parent?: Node): R;\n    visitTextKNode(knode: Text, parent?: Node): R;\n    visitCommentKNode(knode: Comment, parent?: Node): R;\n    visitDoctypeKNode(knode: Doctype, parent?: Node): R;\n}\n\nexport class Element extends KNode {\n    public name: string;\n    public attributes: KNode[];\n    public children: KNode[];\n    public self: boolean;\n\n    constructor(name: string, attributes: KNode[], children: KNode[], self: boolean, line: number = 0) {\n        super();\n        this.type = 'element';\n        this.name = name;\n        this.attributes = attributes;\n        this.children = children;\n        this.self = self;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitElementKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Element';\n    }\n}\n\nexport class Attribute extends KNode {\n    public name: string;\n    public value: string;\n\n    constructor(name: string, value: string, line: number = 0) {\n        super();\n        this.type = 'attribute';\n        this.name = name;\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitAttributeKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Attribute';\n    }\n}\n\nexport class Text extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'text';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitTextKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Text';\n    }\n}\n\nexport class Comment extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'comment';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitCommentKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Comment';\n    }\n}\n\nexport class Doctype extends KNode {\n    public value: string;\n\n    constructor(value: string, line: number = 0) {\n        super();\n        this.type = 'doctype';\n        this.value = value;\n        this.line = line;\n    }\n\n    public accept<R>(visitor: KNodeVisitor<R>, parent?: Node): R {\n        return visitor.visitDoctypeKNode(this, parent);\n    }\n\n    public toString(): string {\n        return 'KNode.Doctype';\n    }\n}\n\n","import { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport * as Node from \"./types/nodes\";\nimport { SelfClosingTags, WhiteSpaces } from \"./types/token\";\n\nexport class TemplateParser {\n  public current: number;\n  public line: number;\n  public col: number;\n  public source: string;\n  public nodes: Node.KNode[];\n\n  public parse(source: string): Node.KNode[] {\n    this.current = 0;\n    this.line = 1;\n    this.col = 1;\n    this.source = source;\n    this.nodes = [];\n\n    while (!this.eof()) {\n      const node = this.node();\n      if (node === null) {\n        continue;\n      }\n      this.nodes.push(node);\n    }\n    this.source = \"\";\n    return this.nodes;\n  }\n\n  private match(...chars: string[]): boolean {\n    for (const char of chars) {\n      if (this.check(char)) {\n        this.current += char.length;\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private advance(eofError: string = \"\"): void {\n    if (!this.eof()) {\n      if (this.check(\"\\n\")) {\n        this.line += 1;\n        this.col = 0;\n      }\n      if (!this.eof()) {\n        this.current++;\n      } else {\n        this.error(KErrorCode.UNEXPECTED_EOF, { eofError: eofError });\n      }\n    }\n  }\n\n  private peek(...chars: string[]): boolean {\n    for (const char of chars) {\n      if (this.check(char)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  private check(char: string): boolean {\n    return this.source.slice(this.current, this.current + char.length) === char;\n  }\n\n  private eof(): boolean {\n    return this.current > this.source.length;\n  }\n\n  private error(code: KErrorCodeType, args: any = {}): any {\n    throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source });\n  }\n\n  private node(): Node.KNode {\n    this.whitespace();\n    let node: Node.KNode;\n\n    if (this.match(\"</\")) {\n      this.error(KErrorCode.UNEXPECTED_CLOSING_TAG);\n    }\n\n    if (this.match(\"<!--\")) {\n      node = this.comment();\n    } else if (this.match(\"<!doctype\") || this.match(\"<!DOCTYPE\")) {\n      node = this.doctype();\n    } else if (this.match(\"<\")) {\n      node = this.element();\n    } else {\n      node = this.text();\n    }\n\n    this.whitespace();\n    return node;\n  }\n\n  private comment(): null {\n    do {\n      this.advance(\"Expected comment closing '-->'\");\n    } while (!this.match(`-->`));\n    return null;\n  }\n\n  private doctype(): Node.KNode {\n    const start = this.current;\n    do {\n      this.advance(\"Expected closing doctype\");\n    } while (!this.match(`>`));\n    const doctype = this.source.slice(start, this.current - 1).trim();\n    return new Node.Doctype(doctype, this.line);\n  }\n\n  private element(): Node.KNode {\n    const line = this.line;\n    const name = this.identifier(\"/\", \">\");\n    if (!name) {\n      this.error(KErrorCode.EXPECTED_TAG_NAME);\n    }\n\n    const attributes = this.attributes();\n\n    if (\n      this.match(\"/>\") ||\n      (SelfClosingTags.includes(name) && this.match(\">\"))\n    ) {\n      return new Node.Element(name, attributes, [], true, this.line);\n    }\n\n    if (!this.match(\">\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_BRACKET);\n    }\n\n    let children: Node.KNode[] = [];\n    this.whitespace();\n    if (!this.peek(\"</\")) {\n      children = this.children(name);\n    }\n\n    this.close(name);\n    return new Node.Element(name, attributes, children, false, line);\n  }\n\n  private close(name: string): void {\n    if (!this.match(\"</\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n    if (!this.match(`${name}`)) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n    this.whitespace();\n    if (!this.match(\">\")) {\n      this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: name });\n    }\n  }\n\n  private children(parent: string): Node.KNode[] {\n    const children: Node.KNode[] = [];\n    do {\n      if (this.eof()) {\n        this.error(KErrorCode.EXPECTED_CLOSING_TAG, { name: parent });\n      }\n      const node = this.node();\n      if (node === null) {\n        continue;\n      }\n      children.push(node);\n    } while (!this.peek(`</`));\n\n    return children;\n  }\n\n  private attributes(): Node.Attribute[] {\n    const attributes: Node.Attribute[] = [];\n    while (!this.peek(\">\", \"/>\") && !this.eof()) {\n      this.whitespace();\n      const line = this.line;\n      const name = this.identifier(\"=\", \">\", \"/>\");\n      if (!name) {\n        this.error(KErrorCode.BLANK_ATTRIBUTE_NAME);\n      }\n      this.whitespace();\n      let value = \"\";\n      if (this.match(\"=\")) {\n        this.whitespace();\n        if (this.match(\"'\")) {\n          value = this.decodeEntities(this.string(\"'\"));\n        } else if (this.match('\"')) {\n          value = this.decodeEntities(this.string('\"'));\n        } else {\n          value = this.decodeEntities(this.identifier(\">\", \"/>\"));\n        }\n      }\n      this.whitespace();\n      attributes.push(new Node.Attribute(name, value, line));\n    }\n    return attributes;\n  }\n\n  private text(): Node.KNode {\n    const start = this.current;\n    const line = this.line;\n    let depth = 0;\n    while (!this.eof()) {\n      if (this.match(\"{{\")) { depth++; continue; }\n      if (depth > 0 && this.match(\"}}\")) { depth--; continue; }\n      if (depth === 0 && this.peek(\"<\")) { break; }\n      this.advance();\n    }\n    const raw = this.source.slice(start, this.current).trim();\n    if (!raw) {\n      return null;\n    }\n    return new Node.Text(this.decodeEntities(raw), line);\n  }\n\n  private decodeEntities(text: string): string {\n    return text\n      .replace(/&nbsp;/g, \"\\u00a0\")\n      .replace(/&lt;/g, \"<\")\n      .replace(/&gt;/g, \">\")\n      .replace(/&quot;/g, '\"')\n      .replace(/&apos;/g, \"'\")\n      .replace(/&amp;/g, \"&\"); // must be last to avoid double-decoding\n  }\n\n  private whitespace(): number {\n    let count = 0;\n    while (this.peek(...WhiteSpaces) && !this.eof()) {\n      count += 1;\n      this.advance();\n    }\n    return count;\n  }\n\n  private identifier(...closing: string[]): string {\n    this.whitespace();\n    const start = this.current;\n    while (!this.peek(...WhiteSpaces, ...closing)) {\n      this.advance(`Expected closing ${closing}`);\n    }\n    const end = this.current;\n    this.whitespace();\n    return this.source.slice(start, end).trim();\n  }\n\n  private string(closing: string): string {\n    const start = this.current;\n    while (!this.match(closing)) {\n      this.advance(`Expected closing ${closing}`);\n    }\n    return this.source.slice(start, this.current - 1);\n  }\n}\n","import { Component, ComponentClass } from \"./component\";\n\nexport interface RouteConfig {\n  path: string;\n  component: ComponentClass;\n  guard?: () => Promise<boolean>;\n}\n\nexport function navigate(path: string): void {\n  history.pushState(null, \"\", path);\n  window.dispatchEvent(new PopStateEvent(\"popstate\"));\n}\n\nexport function matchPath(pattern: string, pathname: string): Record<string, string> | null {\n  if (pattern === \"*\") return {};\n  const patternParts = pattern.split(\"/\").filter(Boolean);\n  const pathParts = pathname.split(\"/\").filter(Boolean);\n  if (patternParts.length !== pathParts.length) return null;\n  const params: Record<string, string> = {};\n  for (let i = 0; i < patternParts.length; i++) {\n    if (patternParts[i].startsWith(\":\")) {\n      params[patternParts[i].slice(1)] = pathParts[i];\n    } else if (patternParts[i] !== pathParts[i]) {\n      return null;\n    }\n  }\n  return params;\n}\n\nexport class Router extends Component {\n  private routes: RouteConfig[] = [];\n\n  setRoutes(routes: RouteConfig[]): void {\n    this.routes = routes;\n  }\n\n  onMount(): void {\n    window.addEventListener(\"popstate\", () => this._navigate(), {\n      signal: this.$abortController.signal,\n    });\n    this._navigate();\n  }\n\n  private async _navigate(): Promise<void> {\n    const pathname = window.location.pathname;\n    for (const route of this.routes) {\n      const params = matchPath(route.path, pathname);\n      if (params === null) continue;\n      if (route.guard) {\n        const allowed = await route.guard();\n        if (!allowed) return;\n      }\n      this._mount(route.component, params);\n      return;\n    }\n  }\n\n  private _mount(ComponentClass: ComponentClass, params: Record<string, string>): void {\n    const element = this.ref as HTMLElement;\n    if (!element || !this.transpiler) return;\n    this.transpiler.mountComponent(ComponentClass, element, params);\n  }\n}\n","export class Boundary {\n  private start: Comment;\n  private end: Comment;\n\n  constructor(parent: Node, label: string = \"boundary\") {\n    this.start = document.createComment(`${label}-start`);\n    this.end = document.createComment(`${label}-end`);\n    if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n      (parent as any).insert(this.start);\n      (parent as any).insert(this.end);\n    } else {\n      parent.appendChild(this.start);\n      parent.appendChild(this.end);\n    }\n  }\n\n  public clear(): void {\n    let current = this.start.nextSibling;\n    while (current && current !== this.end) {\n      const toRemove = current;\n      current = current.nextSibling;\n      toRemove.parentNode?.removeChild(toRemove);\n    }\n  }\n\n  public insert(node: Node): void {\n    this.end.parentNode?.insertBefore(node, this.end);\n  }\n\n  public nodes(): Node[] {\n    const result: Node[] = [];\n    let current = this.start.nextSibling;\n    while (current && current !== this.end) {\n      result.push(current);\n      current = current.nextSibling;\n    }\n    return result;\n  }\n\n  public get parent(): Node | null {\n    return this.start.parentNode;\n  }\n}\n","import { Component } from \"./component\";\nimport { handleError } from \"./error-handler\";\n\ntype Task = () => void;\n\nconst queue = new Map<Component, Task[]>();\nconst nextTickCallbacks: Task[] = [];\nlet isScheduled = false;\nlet batchingEnabled = true;\n\nfunction flush() {\n  isScheduled = false;\n\n  // 1. Process component updates\n  for (const [instance, tasks] of queue.entries()) {\n    try {\n      // Call pre-update hook (only for reactive updates, not first mount)\n      if (typeof instance.onChanges === \"function\") {\n        instance.onChanges();\n      }\n\n      // Run all surgical DOM updates for this component\n      for (const task of tasks) {\n        task();\n      }\n\n      // Call post-update hook\n      if (typeof instance.onRender === \"function\") {\n        instance.onRender();\n      }\n    } catch (e) {\n      handleError(e, 'render', instance);\n    }\n  }\n  queue.clear();\n\n  // 2. Process nextTick callbacks\n  const callbacks = nextTickCallbacks.splice(0);\n  for (const cb of callbacks) {\n    try {\n      cb();\n    } catch (e) {\n      handleError(e, 'render');\n    }\n  }\n}\n\nexport function queueUpdate(instance: Component, task: Task) {\n  if (!batchingEnabled) {\n    task();\n    // During sync mount, we don't call onChanges or onRender here.\n    // onRender is called manually at the end of transpile/bootstrap.\n    return;\n  }\n\n  if (!queue.has(instance)) {\n    queue.set(instance, []);\n  }\n  queue.get(instance)!.push(task);\n\n  if (!isScheduled) {\n    isScheduled = true;\n    queueMicrotask(flush);\n  }\n}\n\n/**\n * Executes a function with batching disabled. \n * Used for initial mount and manual renders.\n */\nexport function isBatching(): boolean {\n  return batchingEnabled;\n}\n\nexport function flushSync(fn: () => void) {\n  const prev = batchingEnabled;\n  batchingEnabled = false;\n  try {\n    fn();\n  } finally {\n    batchingEnabled = prev;\n  }\n}\n\n/**\n * Returns a promise that resolves after the next framework update cycle.\n */\nexport function nextTick(): Promise<void>;\nexport function nextTick(cb: Task): void;\nexport function nextTick(cb?: Task): Promise<void> | void {\n  if (cb) {\n    nextTickCallbacks.push(cb);\n    if (!isScheduled) {\n      isScheduled = true;\n      queueMicrotask(flush);\n    }\n    return;\n  }\n\n  return new Promise((resolve) => {\n    nextTickCallbacks.push(resolve);\n    if (!isScheduled) {\n      isScheduled = true;\n      queueMicrotask(flush);\n    }\n  });\n}\n","import { ComponentClass, ComponentRegistry } from \"./component\";\nimport { ExpressionParser } from \"./expression-parser\";\nimport { Interpreter } from \"./interpreter\";\nimport { Router, RouteConfig } from \"./router\";\nimport { Scanner } from \"./scanner\";\nimport { Scope } from \"./scope\";\nimport { effect } from \"./signal\";\nimport { Boundary } from \"./boundary\";\nimport { TemplateParser } from \"./template-parser\";\nimport { queueUpdate, flushSync } from \"./scheduler\";\nimport { KasperError, KErrorCode, KErrorCodeType } from \"./types/error\";\nimport { handleError } from \"./error-handler\";\nimport { isBatching } from \"./scheduler\";\nimport * as KNode from \"./types/nodes\";\n\nconst KEY_MAP: Record<string, string[]> = {\n  esc: [\"Escape\", \"Esc\"],\n  escape: [\"Escape\", \"Esc\"],\n  space: [\" \", \"Spacebar\"],\n  up: [\"ArrowUp\", \"Up\"],\n  down: [\"ArrowDown\", \"Down\"],\n  left: [\"ArrowLeft\", \"Left\"],\n  right: [\"ArrowRight\", \"Right\"],\n  del: [\"Delete\", \"Del\"],\n  delete: [\"Delete\", \"Del\"],\n  ins: [\"Insert\"],\n  dot: [\".\"],\n  comma: [\",\"],\n  slash: [\"/\"],\n  backslash: [\"\\\\\"],\n  plus: [\"+\"],\n  minus: [\"-\"],\n  equal: [\"=\"],\n};\n\ntype IfElseNode = [KNode.Element, KNode.Attribute];\n\nexport class Transpiler implements KNode.KNodeVisitor<void> {\n  private scanner = new Scanner();\n  private parser = new ExpressionParser();\n  private templateParser = new TemplateParser();\n  private interpreter = new Interpreter();\n  public registry: ComponentRegistry = {};\n  public mode: \"development\" | \"production\" = \"development\";\n  private isRendering = false;\n\n  constructor(options?: { registry: ComponentRegistry }) {\n    this.registry[\"router\"] = { component: Router };\n    if (!options) return;\n    if (options.registry) {\n      this.registry = { ...this.registry, ...options.registry };\n    }\n  }\n\n  private renderComponentInstance(\n    instance: any,\n    nodes: KNode.KNode[],\n    element: HTMLElement,\n    restoreScope: Scope,\n    slots?: Record<string, any>\n  ): void {\n    if (slots) instance.$slots = slots;\n\n    instance.$render = () => {\n      this.isRendering = true;\n      try {\n        this.destroy(element);\n        element.innerHTML = \"\";\n        const scope = new Scope(restoreScope, instance);\n        scope.set(\"$instance\", instance);\n        if (slots) instance.$slots = slots;\n        const prevScope = this.interpreter.scope;\n        this.interpreter.scope = scope;\n        flushSync(() => {\n          this.createSiblings(nodes, element);\n          if (typeof instance.onRender === \"function\") instance.onRender();\n        });\n        this.interpreter.scope = prevScope;\n      } finally {\n        this.isRendering = false;\n      }\n    };\n\n    if (typeof instance.onMount === \"function\") instance.onMount();\n\n    const scope = new Scope(restoreScope, instance);\n    scope.set(\"$instance\", instance);\n    this.interpreter.scope = scope;\n    flushSync(() => {\n      this.createSiblings(nodes, element);\n      if (typeof instance.onRender === \"function\") instance.onRender();\n    });\n    this.interpreter.scope = restoreScope;\n  }\n\n  public resolveNodes(tag: string): KNode.KNode[] {\n    const entry = this.registry[tag];\n    if (entry.nodes !== undefined) return entry.nodes;\n    const source = (entry.component as any).template;\n    if (!source) {\n      entry.nodes = [];\n      return entry.nodes;\n    }\n    entry.nodes = this.templateParser.parse(source);\n    return entry.nodes;\n  }\n\n  private evaluate(node: KNode.KNode, parent?: Node): void {\n    if (node.type === \"element\") {\n      const el = node as KNode.Element;\n      const misplaced = this.findAttr(el, [\"@elseif\", \"@else\"]);\n      if (misplaced) {\n        // These are handled by doIf, if we reach them here it's an error\n        const name = misplaced.name.startsWith(\"@\") ? misplaced.name.slice(1) : misplaced.name;\n        this.error(KErrorCode.MISPLACED_CONDITIONAL, { name: name }, el.name);\n      }\n    }\n    node.accept(this, parent);\n  }\n\n  private bindMethods(entity: any): void {\n    if (!entity || typeof entity !== \"object\") return;\n\n    let proto = Object.getPrototypeOf(entity);\n    while (proto && proto !== Object.prototype) {\n      for (const key of Object.getOwnPropertyNames(proto)) {\n        if (Object.getOwnPropertyDescriptor(proto, key)?.get) continue;\n        if (\n          typeof entity[key] === \"function\" &&\n          key !== \"constructor\" &&\n          !Object.prototype.hasOwnProperty.call(entity, key)\n        ) {\n          entity[key] = entity[key].bind(entity);\n        }\n      }\n      proto = Object.getPrototypeOf(proto);\n    }\n  }\n\n  // Creates an effect that restores the current scope on every re-run,\n  // so effects set up inside @each always evaluate in their item scope.\n  private scopedEffect(fn: () => void): () => void {\n    const scope = this.interpreter.scope;\n    return effect(() => {\n      const prev = this.interpreter.scope;\n      this.interpreter.scope = scope;\n      try {\n        fn();\n      } catch (e) {\n        // Only route to error handler during reactive re-runs (batching enabled).\n        // During initial mount (flushSync / batching disabled) errors propagate normally.\n        if (isBatching()) {\n          const instance = this.interpreter.scope.get(\"$instance\");\n          handleError(e, \"render\", instance);\n        } else {\n          throw e;\n        }\n      } finally {\n        this.interpreter.scope = prev;\n      }\n    });\n  }\n\n  // Wraps a refresh function so it restores the correct scope when called\n  // directly by triggerRefresh (outside of the signal effect machinery).\n  private scopedRefresh(fn: () => void): () => void {\n    const scope = this.interpreter.scope;\n    return () => {\n      const prev = this.interpreter.scope;\n      this.interpreter.scope = scope;\n      try {\n        fn();\n      } finally {\n        this.interpreter.scope = prev;\n      }\n    };\n  }\n\n  // evaluates expressions and returns the result of the first evaluation\n  private execute(source: string, overrideScope?: Scope): any {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens, source);\n\n    const restoreScope = this.interpreter.scope;\n    if (overrideScope) {\n      this.interpreter.scope = overrideScope;\n    }\n    const result = expressions.map((expression) =>\n      this.interpreter.evaluate(expression)\n    );\n    this.interpreter.scope = restoreScope;\n    return result && result.length ? result[result.length - 1] : undefined;\n  }\n\n  public transpile(\n    nodes: KNode.KNode[],\n    entity: any,\n    container: Element\n  ): Node {\n    this.isRendering = true;\n    try {\n      this.destroy(container);\n      container.innerHTML = \"\";\n      this.bindMethods(entity);\n      this.interpreter.scope.init(entity);\n      this.interpreter.scope.set(\"$instance\", entity);\n\n      flushSync(() => {\n        this.createSiblings(nodes, container);\n        this.triggerRender();\n      });\n\n      return container;\n    } finally {\n      this.isRendering = false;\n    }\n  }\n\n  public visitElementKNode(node: KNode.Element, parent?: Node): void {\n    this.createElement(node, parent);\n  }\n\n  public visitTextKNode(node: KNode.Text, parent?: Node): void {\n    const text = document.createTextNode(\"\");\n    if (parent) {\n      if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n        (parent as any).insert(text);\n      } else {\n        parent.appendChild(text);\n      }\n    }\n\n    const stop = this.scopedEffect(() => {\n      const newValue = this.evaluateTemplateString(node.value);\n      const instance = this.interpreter.scope.get(\"$instance\");\n      if (instance) {\n        queueUpdate(instance, () => {\n          text.textContent = newValue;\n        });\n      } else {\n        text.textContent = newValue;\n      }\n    });\n    this.trackEffect(text, stop);\n  }\n\n  public visitAttributeKNode(node: KNode.Attribute, parent?: Node): void {\n    const attr = document.createAttribute(node.name);\n\n    const stop = this.scopedEffect(() => {\n      attr.value = this.evaluateTemplateString(node.value);\n    });\n    this.trackEffect(attr, stop);\n\n    if (parent) {\n      (parent as HTMLElement).setAttributeNode(attr);\n    }\n  }\n\n  public visitCommentKNode(_node: KNode.Comment, _parent?: Node): void {\n    // template comments are stripped from DOM output\n  }\n\n  private trackEffect(target: any, stop: any) {\n    if (!target.$kasperEffects) target.$kasperEffects = [];\n    target.$kasperEffects.push(stop);\n  }\n\n  private findAttr(\n    node: KNode.Element,\n    name: string[]\n  ): KNode.Attribute | null {\n    if (!node || !node.attributes || !node.attributes.length) {\n      return null;\n    }\n\n    const attrib = node.attributes.find((attr) =>\n      name.includes((attr as KNode.Attribute).name)\n    );\n    if (attrib) {\n      return attrib as KNode.Attribute;\n    }\n    return null;\n  }\n\n  private doIf(expressions: IfElseNode[], parent: Node): void {\n    const boundary = new Boundary(parent, \"if\");\n\n    const run = () => {\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      const trackingScope = instance ? new Scope(this.interpreter.scope) : this.interpreter.scope;\n      const prevScope = this.interpreter.scope;\n      this.interpreter.scope = trackingScope;\n\n      // Evaluate conditions synchronously to ensure signal tracking\n      const results: boolean[] = [];\n      results.push(!!this.execute((expressions[0][1] as KNode.Attribute).value));\n\n      if (!results[0]) {\n        for (const expression of expressions.slice(1)) {\n          if (this.findAttr(expression[0] as KNode.Element, [\"@elseif\"])) {\n            const val = !!this.execute((expression[1] as KNode.Attribute).value);\n            results.push(val);\n            if (val) break;\n          } else if (this.findAttr(expression[0] as KNode.Element, [\"@else\"])) {\n            results.push(true);\n            break;\n          }\n        }\n      }\n      this.interpreter.scope = prevScope;\n\n      const task = () => {\n        boundary.nodes().forEach((n) => this.destroyNode(n));\n        boundary.clear();\n\n        const restoreScope = this.interpreter.scope;\n        this.interpreter.scope = trackingScope;\n        try {\n          if (results[0]) {\n            expressions[0][0].accept(this, boundary as any);\n            return;\n          }\n\n          for (let i = 1; i < results.length; i++) {\n            if (results[i]) {\n              expressions[i][0].accept(this, boundary as any);\n              return;\n            }\n          }\n        } finally {\n          this.interpreter.scope = restoreScope;\n        }\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n  private doEach(each: KNode.Attribute, node: KNode.Element, parent: Node) {\n    const keyAttr = this.findAttr(node, [\"@key\"]);\n    if (keyAttr) {\n      this.doEachKeyed(each, node, parent, keyAttr);\n    } else {\n      this.doEachUnkeyed(each, node, parent);\n    }\n  }\n\n  private doEachUnkeyed(each: KNode.Attribute, node: KNode.Element, parent: Node) {\n    const boundary = new Boundary(parent, \"each\");\n    const originalScope = this.interpreter.scope;\n\n    const run = () => {\n      const tokens = this.scanner.scan(each.value);\n      const [name, key, iterable] = this.interpreter.evaluate(\n        this.parser.foreach(tokens)\n      );\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      const task = () => {\n        boundary.nodes().forEach((n) => this.destroyNode(n));\n        boundary.clear();\n\n        let index = 0;\n        for (const item of iterable) {\n          const scopeValues: any = { [name]: item };\n          if (key) scopeValues[key] = index;\n\n          this.interpreter.scope = new Scope(originalScope, scopeValues);\n          this.createElement(node, boundary as any);\n          index += 1;\n        }\n        this.interpreter.scope = originalScope;\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n  private triggerRefresh(node: Node): void {\n    // 1. Re-run structural logic (if/each/while)\n    if ((node as any).$kasperRefresh) {\n      (node as any).$kasperRefresh();\n    }\n\n    // 2. Re-run all surgical effects (text interpolation, attributes, etc.)\n    if ((node as any).$kasperEffects) {\n      (node as any).$kasperEffects.forEach((stop: any) => {\n        if (typeof stop.run === \"function\") {\n          stop.run();\n        }\n      });\n    }\n\n    // 3. Recurse\n    node.childNodes?.forEach((child) => this.triggerRefresh(child));\n  }\n\n  private doEachKeyed(each: KNode.Attribute, node: KNode.Element, parent: Node, keyAttr: KNode.Attribute) {\n    const boundary = new Boundary(parent, \"each\");\n    const originalScope = this.interpreter.scope;\n    const keyedNodes = new Map<any, Node>();\n\n    const run = () => {\n      const tokens = this.scanner.scan(each.value);\n      const [name, indexKey, iterable] = this.interpreter.evaluate(\n        this.parser.foreach(tokens)\n      );\n      const instance = this.interpreter.scope.get(\"$instance\");\n\n      // Compute new items and their keys immediately\n      const newItems: Array<{ item: any; idx: number; key: any }> = [];\n      const seenKeys = new Set();\n      let index = 0;\n      for (const item of iterable) {\n        const scopeValues: any = { [name]: item };\n        if (indexKey) scopeValues[indexKey] = index;\n        this.interpreter.scope = new Scope(originalScope, scopeValues);\n        const key = this.execute(keyAttr.value);\n\n        if (this.mode === \"development\" && seenKeys.has(key)) {\n          console.warn(`[Kasper] Duplicate key detected in @each: \"${key}\". Keys must be unique to ensure correct reconciliation.`);\n        }\n        seenKeys.add(key);\n\n        newItems.push({ item: item, idx: index, key: key });\n        index++;\n      }\n\n      const task = () => {\n        // Destroy nodes whose keys are no longer present\n        const newKeySet = new Set(newItems.map((i) => i.key));\n        for (const [key, domNode] of keyedNodes) {\n          if (!newKeySet.has(key)) {\n            this.destroyNode(domNode);\n            domNode.parentNode?.removeChild(domNode);\n            keyedNodes.delete(key);\n          }\n        }\n\n        // Insert/reuse nodes in new order using a cursor to avoid unnecessary moves\n        const parent = (boundary as any).end.parentNode as Node;\n        let lastInserted: Node = (boundary as any).start;\n\n        for (const { item, idx, key } of newItems) {\n          const scopeValues: any = { [name]: item };\n          if (indexKey) scopeValues[indexKey] = idx;\n          this.interpreter.scope = new Scope(originalScope, scopeValues);\n\n          if (keyedNodes.has(key)) {\n            const domNode = keyedNodes.get(key)!;\n\n            // Only move the node if it's not already in the correct position\n            if (lastInserted.nextSibling !== domNode) {\n              parent.insertBefore(domNode, lastInserted.nextSibling);\n            }\n            lastInserted = domNode;\n\n            // Update scope and trigger re-render of nested structural directives\n            const nodeScope = (domNode as any).$kasperScope;\n            if (nodeScope) {\n              nodeScope.set(name, item);\n              if (indexKey) nodeScope.set(indexKey, idx);\n\n              // If it has its own render logic (nested each/if), trigger it recursively\n              this.triggerRefresh(domNode);\n            }\n          } else {\n            const created = this.createElement(node, boundary as any);\n            if (created) {\n              // createElement inserts before end; move to correct position if needed\n              if (lastInserted.nextSibling !== created) {\n                parent.insertBefore(created, lastInserted.nextSibling);\n              }\n              lastInserted = created;\n              keyedNodes.set(key, created);\n              // Store the scope on the DOM node so we can update it later\n              (created as any).$kasperScope = this.interpreter.scope;\n            }\n          }\n        }\n        this.interpreter.scope = originalScope;\n      };\n\n      if (instance) {\n        queueUpdate(instance, task);\n      } else {\n        task();\n      }\n    };\n\n    (boundary as any).start.$kasperRefresh = this.scopedRefresh(run);\n\n    const stop = this.scopedEffect(run);\n    this.trackEffect(boundary, stop);\n  }\n\n\n  private createSiblings(nodes: KNode.KNode[], parent?: Node): void {\n    let current = 0;\n    const initialScope = this.interpreter.scope;\n    let groupScope: Scope | null = null;\n\n    while (current < nodes.length) {\n      const node = nodes[current++];\n      if (node.type === \"element\") {\n        const el = node as KNode.Element;\n\n        // 1. Process @let (leaks to siblings and available to other directives on this node)\n        const $let = this.findAttr(el, [\"@let\"]);\n        if ($let) {\n          if (!groupScope) {\n            groupScope = new Scope(initialScope);\n            this.interpreter.scope = groupScope;\n          }\n          this.execute($let.value);\n        }\n\n        // 2. Validation: Structural directives are mutually exclusive\n        const ifAttr = this.findAttr(el, [\"@if\"]);\n        const elseifAttr = this.findAttr(el, [\"@elseif\"]);\n        const elseAttr = this.findAttr(el, [\"@else\"]);\n        const $each = this.findAttr(el, [\"@each\"]);\n\n        if (this.mode === \"development\") {\n          const structuralCount = [ifAttr, elseifAttr, elseAttr, $each].filter(a => a).length;\n          if (structuralCount > 1) {\n            this.error(KErrorCode.MULTIPLE_STRUCTURAL_DIRECTIVES, {}, el.name);\n          }\n        }\n\n        // 3. Process structural directives (one will match and continue)\n        if ($each) {\n          this.doEach($each, el, parent!);\n          continue;\n        }\n\n        if (ifAttr) {\n          const expressions: IfElseNode[] = [[el, ifAttr]];\n\n          while (current < nodes.length) {\n            const next = nodes[current];\n            if (next.type !== \"element\") break;\n            const attr = this.findAttr(next as KNode.Element, [\n              \"@else\",\n              \"@elseif\",\n            ]);\n            if (attr) {\n              expressions.push([next as KNode.Element, attr]);\n              current += 1;\n            } else {\n              break;\n            }\n          }\n\n          this.doIf(expressions, parent!);\n          continue;\n        }\n      }\n\n      this.evaluate(node, parent);\n    }\n\n    this.interpreter.scope = initialScope;\n  }\n\n  private createElement(node: KNode.Element, parent?: Node): Node | undefined {\n    try {\n      if (node.name === \"slot\") {\n        const nameAttr = this.findAttr(node, [\"@name\"]);\n        const name = nameAttr ? nameAttr.value : \"default\";\n        const slots = this.interpreter.scope.get(\"$slots\");\n        if (slots && slots[name]) {\n          const prev = this.interpreter.scope;\n          // Restore the scope where the slot content was defined (Lexical Scoping).\n          // We store the scope reference directly on the Array instance to avoid changing signatures.\n          if (slots[name].scope) this.interpreter.scope = slots[name].scope;\n          this.createSiblings(slots[name], parent);\n          this.interpreter.scope = prev;\n        }\n        return undefined;\n      }\n\n      const isVoid = node.name === \"void\";\n      const isComponent = !!this.registry[node.name];\n\n      const element = isVoid ? parent : document.createElement(node.name);\n      const restoreScope = this.interpreter.scope;\n\n      if (element && element !== parent) {\n        this.interpreter.scope.set(\"$ref\", element);\n      }\n\n      if (isComponent) {\n        // create a new instance of the component and set it as the current scope\n        let component: any = {};\n        const argsAttr = node.attributes.filter((attr) =>\n          (attr as KNode.Attribute).name.startsWith(\"@:\")\n        );\n        const args = this.createComponentArgs(argsAttr as KNode.Attribute[]);\n\n        // Capture children for slots. \n        // We use a plain object keyed by slot name. Each value is an Array of KNodes.\n        // To support lexical scoping, we attach the current scope to the Array instance.\n        const slots: Record<string, any> = { default: [] };\n        slots.default.scope = this.interpreter.scope;\n        for (const child of node.children) {\n          if (child.type === \"element\") {\n            const slotAttr = this.findAttr(child as KNode.Element, [\"@slot\"]);\n            if (slotAttr) {\n              const name = slotAttr.value;\n              if (!slots[name]) {\n                slots[name] = [];\n                slots[name].scope = this.interpreter.scope;\n              }\n              slots[name].push(child);\n              continue;\n            }\n          }\n          slots.default.push(child);\n        }\n\n        if (this.registry[node.name]?.lazy) {\n          const entry = this.registry[node.name];\n\n          if (entry.fallback) {\n            const fallbackNodes = this.templateParser.parse((entry.fallback as any).template ?? \"\");\n            const fallbackInstance: any = new entry.fallback({ args: {}, ref: element, transpiler: this });\n            this.bindMethods(fallbackInstance);\n            (element as any).$kasperInstance = fallbackInstance;\n            this.renderComponentInstance(fallbackInstance, fallbackNodes, element as HTMLElement, restoreScope);\n          }\n\n          if (!(entry as any)._promise) {\n            (entry as any)._promise = (entry.component as () => Promise<ComponentClass>)().then((cls) => {\n              entry.nodes = this.templateParser.parse((cls as any).template ?? \"\");\n              entry.component = cls;\n              delete entry.lazy;\n              delete (entry as any)._promise;\n            });\n          }\n\n          (entry as any)._promise.then(() => {\n            this.destroy(element as HTMLElement);\n            (element as HTMLElement).innerHTML = \"\";\n            const cls = entry.component as ComponentClass;\n            const instance: any = new cls({ args: args, ref: element, transpiler: this });\n            this.bindMethods(instance);\n            (element as any).$kasperInstance = instance;\n            this.renderComponentInstance(instance, entry.nodes!, element as HTMLElement, restoreScope, slots);\n          });\n\n          if (parent) {\n            if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n              (parent as any).insert(element);\n            } else {\n              parent.appendChild(element);\n            }\n          }\n          return element;\n        }\n\n        if (this.registry[node.name]?.component) {\n          component = new (this.registry[node.name].component as ComponentClass)({\n            args: args,\n            ref: element,\n            transpiler: this,\n          });\n\n          this.bindMethods(component);\n          (element as any).$kasperInstance = component;\n\n          if (node.name === \"router\" && component instanceof Router) {\n            const routeScope = new Scope(restoreScope, component);\n            component.setRoutes(this.extractRoutes(node.children, undefined, routeScope));\n          }\n\n          this.renderComponentInstance(component, this.resolveNodes(node.name), element as HTMLElement, restoreScope, slots);\n        }\n        if (parent) {\n          if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n            (parent as any).insert(element);\n          } else {\n            parent.appendChild(element);\n          }\n        }\n        return element;\n      }\n\n      if (!isVoid) {\n        // event binding\n        const events = node.attributes.filter((attr) =>\n          (attr as KNode.Attribute).name.startsWith(\"@on:\")\n        );\n\n        for (const event of events) {\n          this.createEventListener(element, event as KNode.Attribute);\n        }\n\n        // regular attributes (processed first)\n        const attributes = node.attributes.filter(\n          (attr) => !(attr as KNode.Attribute).name.startsWith(\"@\")\n        );\n\n        for (const attr of attributes) {\n          this.evaluate(attr, element);\n        }\n\n        // shorthand attributes (processed second, allows merging)\n        const shorthandAttributes = node.attributes.filter((attr) => {\n          const name = (attr as KNode.Attribute).name;\n          return (\n            name.startsWith(\"@\") &&\n            ![\"@if\", \"@elseif\", \"@else\", \"@each\", \"@let\", \"@key\", \"@ref\"].includes(\n              name\n            ) &&\n            !name.startsWith(\"@on:\") &&\n            !name.startsWith(\"@:\")\n          );\n        });\n\n        for (const attr of shorthandAttributes) {\n          const realName = (attr as KNode.Attribute).name.slice(1);\n\n          if (realName === \"class\") {\n            const stop = this.scopedEffect(() => {\n              const value = this.execute((attr as KNode.Attribute).value);\n              const instance = this.interpreter.scope.get(\"$instance\");\n              const task = () => {\n                (element as HTMLElement).setAttribute(\"class\", value);\n              };\n\n              if (instance) {\n                queueUpdate(instance, task);\n              } else {\n                task();\n              }\n            });\n            this.trackEffect(element, stop);\n          } else {\n            const stop = this.scopedEffect(() => {\n              const value = this.execute((attr as KNode.Attribute).value);\n              const instance = this.interpreter.scope.get(\"$instance\");\n              const task = () => {\n                if (value === false || value === null || value === undefined) {\n                  if (realName !== \"style\") {\n                    (element as HTMLElement).removeAttribute(realName);\n                  }\n                } else {\n                  if (realName === \"style\") {\n                    const existing = (element as HTMLElement).getAttribute(\"style\");\n                    const newValue = existing && !existing.includes(value)\n                      ? `${existing.endsWith(\";\") ? existing : existing + \";\"} ${value}`\n                      : value;\n                    (element as HTMLElement).setAttribute(\"style\", newValue);\n                  } else {\n                    (element as HTMLElement).setAttribute(realName, value);\n                  }\n                }\n              };\n\n              if (instance) {\n                queueUpdate(instance, task);\n              } else {\n                task();\n              }\n            });\n            this.trackEffect(element, stop);\n          }\n        }\n      }\n\n      if (parent && !isVoid) {\n        if ((parent as any).insert && typeof (parent as any).insert === \"function\") {\n          (parent as any).insert(element);\n        } else {\n          parent.appendChild(element);\n        }\n      }\n\n      const refAttr = this.findAttr(node, [\"@ref\"]);\n      if (refAttr && !isVoid) {\n        const propName = refAttr.value.trim();\n        const instance = this.interpreter.scope.get(\"$instance\");\n        if (instance) {\n          instance[propName] = element;\n        } else {\n          this.interpreter.scope.set(propName, element);\n        }\n      }\n\n      if (node.self) {\n        return element;\n      }\n\n      this.createSiblings(node.children, element);\n      this.interpreter.scope = restoreScope;\n\n      return element;\n    } catch (e: any) {\n      if (e instanceof KasperError) throw e.withTag(node.name);\n      this.error(KErrorCode.RUNTIME_ERROR, { message: e.message || `${e}` }, node.name);\n    }\n  }\n\n  private createComponentArgs(args: KNode.Attribute[]): Record<string, any> {\n    if (!args.length) {\n      return {};\n    }\n    const result: Record<string, any> = {};\n    for (const arg of args) {\n      const key = arg.name.split(\":\")[1];\n      if (this.mode === \"development\" && key.toLowerCase().startsWith(\"on\")) {\n        const trimmed = arg.value.trim();\n        const isCallExpr = /^[\\w$.][\\w$.]*\\s*\\(.*\\)\\s*$/.test(trimmed) && !trimmed.includes(\"=>\");\n        if (isCallExpr) {\n          console.warn(\n            `[Kasper] @:${key}=\"${arg.value}\" — the expression is called during render and its return value is passed as the prop. ` +\n            `If it returns a function, that function becomes the handler (factory pattern). ` +\n            `If it returns undefined, the prop receives undefined. ` +\n            `If the function has reactive side effects, ensure it does not both read and write the same signal.`\n          );\n        }\n      }\n      result[key] = this.execute(arg.value);\n    }\n    return result;\n  }\n\n  private createEventListener(element: Node, attr: KNode.Attribute): void {\n    const [eventName, ...modifiers] = attr.name.split(\":\")[1].split(\".\");\n    const listenerScope = new Scope(this.interpreter.scope);\n    const instance = this.interpreter.scope.get(\"$instance\");\n\n    const options: any = {};\n    if (instance && instance.$abortController) {\n      options.signal = instance.$abortController.signal;\n    }\n    if (modifiers.includes(\"once\")) options.once = true;\n    if (modifiers.includes(\"passive\")) options.passive = true;\n    if (modifiers.includes(\"capture\")) options.capture = true;\n\n    // Anything not in this list is treated as a potential key modifier\n    const controlModifiers = [\"prevent\", \"stop\", \"once\", \"passive\", \"capture\", \"ctrl\", \"shift\", \"alt\", \"meta\"];\n    const potentialKeyModifiers = modifiers.filter((m) => !controlModifiers.includes(m.toLowerCase()));\n\n    element.addEventListener(\n      eventName,\n      (event: any) => {\n        if (potentialKeyModifiers.length > 0) {\n          const matched = potentialKeyModifiers.some((m) => {\n            const lowerM = m.toLowerCase();\n            if (KEY_MAP[lowerM] && KEY_MAP[lowerM].includes(event.key)) return true;\n            if (lowerM === event.key?.toLowerCase()) return true;\n            return false;\n          });\n          if (!matched) {\n            return;\n          }\n        }\n\n        if (modifiers.includes(\"ctrl\") && !event.ctrlKey) return;\n        if (modifiers.includes(\"shift\") && !event.shiftKey) return;\n        if (modifiers.includes(\"alt\") && !event.altKey) return;\n        if (modifiers.includes(\"meta\") && !event.metaKey) return;\n\n        if (modifiers.includes(\"prevent\")) event.preventDefault();\n        if (modifiers.includes(\"stop\")) event.stopPropagation();\n        listenerScope.set(\"$event\", event);\n        this.execute(attr.value, listenerScope);\n      },\n      options\n    );\n  }\n\n  private evaluateTemplateString(text: string): string {\n    if (!text) {\n      return text;\n    }\n    const regex = /\\{\\{.+\\}\\}/ms;\n    if (regex.test(text)) {\n      return text.replace(/\\{\\{([\\s\\S]+?)\\}\\}/g, (m, placeholder) => {\n        return this.evaluateExpression(placeholder);\n      });\n    }\n    return text;\n  }\n\n  private evaluateExpression(source: string): string {\n    const tokens = this.scanner.scan(source);\n    const expressions = this.parser.parse(tokens, source);\n\n    let result = \"\";\n    for (const expression of expressions) {\n      result += `${this.interpreter.evaluate(expression)}`;\n    }\n    return result;\n  }\n\n  private destroyNode(node: any): void {\n    // 1. Cleanup component instance\n    if (node.$kasperInstance) {\n      const instance = node.$kasperInstance;\n      if (instance.onDestroy) {\n        instance.onDestroy();\n      }\n      if (instance.$abortController) instance.$abortController.abort();\n    }\n\n    // 2. Cleanup effects attached to the node\n    if (node.$kasperEffects) {\n      node.$kasperEffects.forEach((stop: () => void) => stop());\n      node.$kasperEffects = [];\n    }\n\n    // 3. Cleanup effects on attributes\n    if (node.attributes) {\n      for (let i = 0; i < node.attributes.length; i++) {\n        const attr = node.attributes[i];\n        if (attr.$kasperEffects) {\n          attr.$kasperEffects.forEach((stop: () => void) => stop());\n          attr.$kasperEffects = [];\n        }\n      }\n    }\n\n    // 4. Recurse\n    node.childNodes?.forEach((child: any) => this.destroyNode(child));\n  }\n\n  public destroy(container: Element): void {\n    container.childNodes.forEach((child) => this.destroyNode(child));\n  }\n\n  public mountComponent(ComponentClass: ComponentClass, container: HTMLElement, params: Record<string, string> = {}): void {\n    this.destroy(container);\n    container.innerHTML = \"\";\n\n    const template = (ComponentClass as any).template;\n    if (!template) return;\n\n    const nodes = this.templateParser.parse(template);\n    const host = document.createElement(\"div\");\n    container.appendChild(host);\n\n    const component = new ComponentClass({ args: { params: params }, ref: host, transpiler: this });\n    this.bindMethods(component);\n    (host as any).$kasperInstance = component;\n\n    const componentNodes = nodes;\n    component.$render = () => {\n      this.isRendering = true;\n      try {\n        this.destroy(host);\n        host.innerHTML = \"\";\n        const scope = new Scope(null, component);\n        scope.set(\"$instance\", component);\n        const prev = this.interpreter.scope;\n        this.interpreter.scope = scope;\n\n        flushSync(() => {\n          this.createSiblings(componentNodes, host);\n          if (typeof component.onRender === \"function\") component.onRender();\n        });\n\n        this.interpreter.scope = prev;\n      } finally {\n        this.isRendering = false;\n      }\n    };\n\n    const scope = new Scope(null, component);\n    scope.set(\"$instance\", component);\n    const prev = this.interpreter.scope;\n    this.interpreter.scope = scope;\n\n    flushSync(() => {\n      this.createSiblings(nodes, host);\n    });\n\n    this.interpreter.scope = prev;\n\n    if (typeof component.onMount === \"function\") component.onMount();\n    if (typeof component.onRender === \"function\") component.onRender();\n  }\n\n  public extractRoutes(children: KNode.KNode[], parentGuard?: () => Promise<boolean>, scope?: Scope): RouteConfig[] {\n    const routes: RouteConfig[] = [];\n    const prevScope = scope ? this.interpreter.scope : undefined;\n    if (scope) this.interpreter.scope = scope;\n    for (const child of children) {\n      if (child.type !== \"element\") continue;\n      const el = child as KNode.Element;\n      if (el.name === \"route\") {\n        const pathAttr = this.findAttr(el, [\"@path\"]);\n        const componentAttr = this.findAttr(el, [\"@component\"]);\n        const guardAttr = this.findAttr(el, [\"@guard\"]);\n\n        if (!pathAttr || !componentAttr) {\n          this.error(KErrorCode.MISSING_REQUIRED_ATTR, { message: \"<route> requires @path and @component attributes.\" }, el.name);\n        }\n\n        const path = pathAttr!.value;\n        const component = this.execute(componentAttr!.value);\n        const guard = guardAttr ? this.execute(guardAttr.value) : parentGuard;\n        routes.push({ path: path, component: component, guard: guard });\n      } else if (el.name === \"guard\") {\n        const checkAttr = this.findAttr(el, [\"@check\"]);\n        if (!checkAttr) {\n          this.error(KErrorCode.MISSING_REQUIRED_ATTR, { message: \"<guard> requires @check attribute.\" }, el.name);\n        }\n\n        if (!checkAttr) continue;\n        const check = this.execute(checkAttr.value);\n        routes.push(...this.extractRoutes(el.children, check));\n      }\n    }\n    if (scope) this.interpreter.scope = prevScope;\n    return routes;\n  }\n\n  private triggerRender(): void {\n    if (this.isRendering) return;\n    const instance = this.interpreter.scope.get(\"$instance\");\n    if (instance && typeof instance.onRender === \"function\") {\n      instance.onRender();\n    }\n  }\n\n  public visitDoctypeKNode(_node: KNode.Doctype): void {\n    return;\n    // return document.implementation.createDocumentType(\"html\", \"\", \"\");\n  }\n\n  public error(code: KErrorCodeType, args: any, tagName?: string): void {\n    let finalArgs = args;\n    if (typeof args === \"string\") {\n      const cleanMessage = args.includes(\"Runtime Error\")\n        ? args.replace(\"Runtime Error: \", \"\")\n        : args;\n      finalArgs = { message: cleanMessage };\n    }\n\n    throw new KasperError(code, finalArgs, { tag: tagName });\n  }\n\n}\n","import { ComponentClass, ComponentRegistry } from \"./component\";\nimport { TemplateParser } from \"./template-parser\";\nimport { Transpiler } from \"./transpiler\";\nimport { KasperError, KErrorCode } from \"./types/error\";\nimport { setErrorHandler, ErrorHandlerFn } from \"./error-handler\";\n\nexport function lazy(\n  importer: () => Promise<Record<string, ComponentClass>>\n): { component: () => Promise<ComponentClass>; lazy: true } {\n  return {\n    lazy: true,\n    component: () => importer().then((m) => Object.values(m)[0]),\n  };\n}\n\nexport function execute(source: string): string {\n  const parser = new TemplateParser();\n  try {\n    const nodes = parser.parse(source);\n    return JSON.stringify(nodes);\n  } catch (e) {\n    return JSON.stringify([e instanceof Error ? e.message : String(e)]);\n  }\n}\n\nexport function transpile(\n  source: string,\n  entity?: { [key: string]: any },\n  container?: HTMLElement,\n  registry?: ComponentRegistry\n): Node {\n  const parser = new TemplateParser();\n  const nodes = parser.parse(source);\n  const transpiler = new Transpiler({ registry: registry || {} });\n  const result = transpiler.transpile(nodes, entity || {}, container);\n  return result;\n}\n\nexport interface KasperConfig {\n  root?: string | HTMLElement;\n  entry?: string;\n  registry: ComponentRegistry;\n  mode?: \"development\" | \"production\";\n  onError?: ErrorHandlerFn;\n}\n\nfunction createComponent(transpiler: Transpiler, tag: string) {\n  const element = document.createElement(tag);\n  const component = new (transpiler.registry[tag].component as ComponentClass)({\n    ref: element,\n    transpiler: transpiler,\n    args: {},\n  });\n\n  return {\n    node: element,\n    instance: component,\n    nodes: transpiler.resolveNodes(tag),\n  };\n}\n\nexport function bootstrap(config: KasperConfig) {\n  const root =\n    typeof config.root === \"string\"\n      ? document.querySelector(config.root)\n      : config.root;\n\n  if (!root) {\n    throw new KasperError(\n      KErrorCode.ROOT_ELEMENT_NOT_FOUND,\n      { root: config.root }\n    );\n  }\n\n  const entryTag = config.entry || \"kasper-app\";\n  if (!config.registry[entryTag]) {\n    throw new KasperError(\n      KErrorCode.ENTRY_COMPONENT_NOT_FOUND,\n      { tag: entryTag }\n    );\n  }\n\n  if (config.onError) {\n    setErrorHandler(config.onError);\n  }\n\n  const transpiler = new Transpiler({ registry: config.registry });\n\n  if (config.mode) {\n    transpiler.mode = config.mode;\n  }\n\n  const { node, instance, nodes } = createComponent(transpiler, entryTag);\n\n  root.innerHTML = \"\";\n  root.appendChild(node);\n\n  if (typeof instance.onMount === \"function\") {\n    instance.onMount();\n  }\n\n  transpiler.transpile(nodes, instance, node as HTMLElement);\n\n  if (typeof instance.onRender === \"function\") {\n    instance.onRender();\n  }\n\n  return instance;\n}\n"],"names":["rawEffect","rawComputed","Set","TokenType","Expr.Each","Expr.Variable","Expr.Binary","Expr.Assign","Expr.Get","Expr.Set","Expr.Pipeline","Expr.Ternary","Expr.NullCoalescing","Expr.Logical","Expr.Typeof","Expr.Unary","Expr.Call","Expr.New","Expr.Postfix","Expr.Spread","Expr.Key","Expr.Literal","Expr.Template","Expr.ArrowFunction","Expr.Grouping","Expr.Void","Expr.Debug","Expr.Dictionary","Expr.List","Utils.isDigit","Utils.isAlphaNumeric","Utils.capitalize","Utils.isKeyword","Utils.isAlpha","Parser","Node.Doctype","Node.Element","Node.Attribute","Node.Text","ComponentClass","scope","parent","prev"],"mappings":"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"} diff --git a/dist/kasper.min.js b/dist/kasper.min.js index 73d0f05..b3fd37f 100644 --- a/dist/kasper.min.js +++ b/dist/kasper.min.js @@ -33,7 +33,7 @@ const E = { // Transpiler RUNTIME_ERROR: "K007-1", MISSING_REQUIRED_ATTR: "K007-2" -}, xt = { +}, Nt = { "K001-1": (i) => `Root element not found: ${i.root}`, "K001-2": (i) => `Entry component <${i.tag}> not found in registry.`, "K002-1": () => 'Unterminated comment, expecting closing "*/"', @@ -62,24 +62,57 @@ const E = { "K007-1": (i) => i.message, "K007-2": (i) => i.message }; +function At(i, t, e, s = 2) { + const n = i.split(` +`), a = t - 1, o = Math.max(0, a - s), c = Math.min(n.length - 1, a + s), m = [""]; + for (let p = o; p <= c; p++) { + const l = p === a ? ">" : " "; + if (m.push(` ${l} | ${n[p]}`), p === a && e > 0) { + const d = " ".repeat(6 + e - 1) + "^"; + m.push(d); + } + } + return m.join(` +`); +} class C extends Error { - constructor(t, e = {}, s, n, a) { - const o = typeof process < "u" ? process.env.NODE_ENV !== "production" : !1, c = xt[t], m = c ? c(e) : typeof e == "string" ? e : "Unknown error", d = s !== void 0 ? ` (${s}:${n})` : "", l = a ? ` - at <${a}>` : "", p = o ? ` - -See: https://kasperjs.top/reference/errors#${t.toLowerCase().replace(".", "")}` : ""; - super(`[${t}] ${m}${d}${l}${p}`), this.code = t, this.args = e, this.line = s, this.col = n, this.tagName = a, this.name = "KasperError"; + constructor(t, e = {}, s = {}) { + const { line: n, col: a, tag: o, source: c } = s, m = typeof process < "u" ? process.env.NODE_ENV !== "production" : !1, p = Nt[t], l = p ? p(e) : typeof e == "string" ? e : "Unknown error", d = o ? ` + at <${o}>` : "", u = n !== void 0 && c ? At(c, n, a ?? 0) : "", f = m ? ` +See: https://kasperjs.top/reference/errors#${t.toLowerCase().replace(".", "")} +` : ""; + super(`[${t}] ${l}${d}${u}${f}`), this.code = t, this.args = e, this.name = "KasperError", this.line = n, this.col = a, this.tagName = o; } withTag(t) { return this.tagName || (this.tagName = t, this.message += ` at <${t}>`), this; } } +let Y = null; +function Ct(i) { + Y = i ?? null; +} +function X(i, t, e) { + const s = i instanceof Error ? i : new Error(String(i)); + if (e && typeof e.onError == "function") + try { + e.onError(s, t); + return; + } catch { + } + if (Y) + try { + Y(s, { component: e, phase: t }); + return; + } catch { + } + console.error(`[Kasper] Error during ${t}:`, s); +} let U = null; -const V = []; -let Y = !1; -const H = /* @__PURE__ */ new Set(), mt = []; -class Et { +const Q = []; +let J = !1; +const Z = /* @__PURE__ */ new Set(), gt = []; +class vt { constructor(t) { this.subscribers = /* @__PURE__ */ new Set(), this.watchers = /* @__PURE__ */ new Set(), this._value = t; } @@ -89,9 +122,9 @@ class Et { set value(t) { if (this._value !== t) { const e = this._value; - if (this._value = t, Y) { - for (const s of this.subscribers) H.add(s); - for (const s of this.watchers) mt.push(() => s(t, e)); + if (this._value = t, J) { + for (const s of this.subscribers) Z.add(s); + for (const s of this.watchers) gt.push(() => s(t, e)); } else { const s = Array.from(this.subscribers); for (const n of s) @@ -100,7 +133,7 @@ class Et { try { n(t, e); } catch (a) { - console.error("Watcher error:", a); + X(a, "watcher"); } } } @@ -123,10 +156,10 @@ class Et { return this._value; } } -class St extends Et { +class yt extends vt { constructor(t, e) { super(void 0), this.computing = !1, this.fn = t; - const s = tt(() => { + const s = st(() => { if (this.computing) throw new C(E.CIRCULAR_COMPUTED); this.computing = !0; @@ -144,17 +177,17 @@ class St extends Et { set value(t) { } } -function tt(i, t) { +function st(i, t) { var n; if ((n = t == null ? void 0 : t.signal) != null && n.aborted) return () => { }; const e = { fn: () => { - e.deps.forEach((a) => a.unsubscribe(e.fn)), e.deps.clear(), V.push(e), U = e; + e.deps.forEach((a) => a.unsubscribe(e.fn)), e.deps.clear(), Q.push(e), U = e; try { i(); } finally { - V.pop(), U = V[V.length - 1] || null; + Q.pop(), U = Q[Q.length - 1] || null; } }, deps: /* @__PURE__ */ new Set() @@ -165,35 +198,35 @@ function tt(i, t) { }; return s.run = e.fn, t != null && t.signal && t.signal.addEventListener("abort", s, { once: !0 }), s; } -function Ft(i) { - return new Et(i); +function Jt(i) { + return new vt(i); } -function zt(i, t, e) { +function Zt(i, t, e) { return i.onChange(t, e); } -function jt(i) { - Y = !0; +function Tt(i) { + J = !0; try { i(); } finally { - Y = !1; - const t = Array.from(H); - H.clear(); - const e = mt.splice(0); + J = !1; + const t = Array.from(Z); + Z.clear(); + const e = gt.splice(0); for (const s of t) s(); for (const s of e) try { s(); } catch (n) { - console.error("Watcher error:", n); + X(n, "watcher"); } } } -function Nt(i, t) { - return new St(i, t); +function Rt(i, t) { + return new yt(i, t); } -class At { +class Pt { constructor(t) { if (this.args = {}, this.$abortController = new AbortController(), !t) { this.args = {}; @@ -206,7 +239,7 @@ class At { * Runs immediately and re-runs when any signal dependency changes. */ effect(t) { - tt(t, { signal: this.$abortController.signal }); + st(t, { signal: this.$abortController.signal }); } /** * Watches a specific signal for changes. @@ -220,7 +253,7 @@ class At { * The internal effect is automatically cleaned up when the component is destroyed. */ computed(t) { - return Nt(t, { signal: this.$abortController.signal }); + return Rt(t, { signal: this.$abortController.signal }); } onMount() { } @@ -240,7 +273,7 @@ class v { constructor() { } } -class rt extends v { +class at extends v { constructor(t, e, s) { super(), this.params = t, this.body = e, this.line = s; } @@ -251,7 +284,7 @@ class rt extends v { return "Expr.ArrowFunction"; } } -class Ct extends v { +class kt extends v { constructor(t, e, s) { super(), this.name = t, this.value = e, this.line = s; } @@ -262,7 +295,7 @@ class Ct extends v { return "Expr.Assign"; } } -class D extends v { +class _ extends v { constructor(t, e, s, n) { super(), this.left = t, this.operator = e, this.right = s, this.line = n; } @@ -273,7 +306,7 @@ class D extends v { return "Expr.Binary"; } } -class J extends v { +class T extends v { constructor(t, e, s, n, a = !1) { super(), this.callee = t, this.paren = e, this.args = s, this.line = n, this.optional = a; } @@ -284,7 +317,7 @@ class J extends v { return "Expr.Call"; } } -class yt extends v { +class _t extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -295,7 +328,7 @@ class yt extends v { return "Expr.Debug"; } } -class nt extends v { +class ct extends v { constructor(t, e) { super(), this.properties = t, this.line = e; } @@ -306,7 +339,7 @@ class nt extends v { return "Expr.Dictionary"; } } -class Rt extends v { +class Dt extends v { constructor(t, e, s, n) { super(), this.name = t, this.key = e, this.iterable = s, this.line = n; } @@ -328,7 +361,7 @@ class R extends v { return "Expr.Get"; } } -class Pt extends v { +class It extends v { constructor(t, e) { super(), this.expression = t, this.line = e; } @@ -339,7 +372,7 @@ class Pt extends v { return "Expr.Grouping"; } } -class z extends v { +class j extends v { constructor(t, e) { super(), this.name = t, this.line = e; } @@ -350,7 +383,7 @@ class z extends v { return "Expr.Key"; } } -class at extends v { +class ot extends v { constructor(t, e, s, n) { super(), this.left = t, this.operator = e, this.right = s, this.line = n; } @@ -361,7 +394,7 @@ class at extends v { return "Expr.Logical"; } } -class ct extends v { +class ht extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -372,7 +405,7 @@ class ct extends v { return "Expr.List"; } } -class _ extends v { +class D extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -383,7 +416,7 @@ class _ extends v { return "Expr.Literal"; } } -class ot extends v { +class lt extends v { constructor(t, e, s) { super(), this.clazz = t, this.args = e, this.line = s; } @@ -394,7 +427,7 @@ class ot extends v { return "Expr.New"; } } -class kt extends v { +class Lt extends v { constructor(t, e, s) { super(), this.left = t, this.right = e, this.line = s; } @@ -405,7 +438,7 @@ class kt extends v { return "Expr.NullCoalescing"; } } -class ht extends v { +class ut extends v { constructor(t, e, s) { super(), this.entity = t, this.increment = e, this.line = s; } @@ -427,7 +460,7 @@ let B = class extends v { return "Expr.Set"; } }; -class Dt extends v { +class $t extends v { constructor(t, e, s) { super(), this.left = t, this.right = e, this.line = s; } @@ -449,7 +482,7 @@ class I extends v { return "Expr.Spread"; } } -class _t extends v { +class Kt extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -460,7 +493,7 @@ class _t extends v { return "Expr.Template"; } } -class It extends v { +class qt extends v { constructor(t, e, s, n) { super(), this.condition = t, this.thenExpr = e, this.elseExpr = s, this.line = n; } @@ -471,7 +504,7 @@ class It extends v { return "Expr.Ternary"; } } -class Lt extends v { +class Ot extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -482,7 +515,7 @@ class Lt extends v { return "Expr.Typeof"; } } -class Kt extends v { +class Mt extends v { constructor(t, e, s) { super(), this.operator = t, this.right = e, this.line = s; } @@ -504,7 +537,7 @@ class O extends v { return "Expr.Variable"; } } -class $t extends v { +class Ut extends v { constructor(t, e) { super(), this.value = t, this.line = e; } @@ -516,7 +549,7 @@ class $t extends v { } } var r = /* @__PURE__ */ ((i) => (i[i.Eof = 0] = "Eof", i[i.Panic = 1] = "Panic", i[i.Ampersand = 2] = "Ampersand", i[i.AtSign = 3] = "AtSign", i[i.Caret = 4] = "Caret", i[i.Comma = 5] = "Comma", i[i.Dollar = 6] = "Dollar", i[i.Dot = 7] = "Dot", i[i.Hash = 8] = "Hash", i[i.LeftBrace = 9] = "LeftBrace", i[i.LeftBracket = 10] = "LeftBracket", i[i.LeftParen = 11] = "LeftParen", i[i.Percent = 12] = "Percent", i[i.Pipe = 13] = "Pipe", i[i.RightBrace = 14] = "RightBrace", i[i.RightBracket = 15] = "RightBracket", i[i.RightParen = 16] = "RightParen", i[i.Semicolon = 17] = "Semicolon", i[i.Slash = 18] = "Slash", i[i.Star = 19] = "Star", i[i.Arrow = 20] = "Arrow", i[i.Bang = 21] = "Bang", i[i.BangEqual = 22] = "BangEqual", i[i.BangEqualEqual = 23] = "BangEqualEqual", i[i.Colon = 24] = "Colon", i[i.Equal = 25] = "Equal", i[i.EqualEqual = 26] = "EqualEqual", i[i.EqualEqualEqual = 27] = "EqualEqualEqual", i[i.Greater = 28] = "Greater", i[i.GreaterEqual = 29] = "GreaterEqual", i[i.Less = 30] = "Less", i[i.LessEqual = 31] = "LessEqual", i[i.Minus = 32] = "Minus", i[i.MinusEqual = 33] = "MinusEqual", i[i.MinusMinus = 34] = "MinusMinus", i[i.PercentEqual = 35] = "PercentEqual", i[i.Plus = 36] = "Plus", i[i.PlusEqual = 37] = "PlusEqual", i[i.PlusPlus = 38] = "PlusPlus", i[i.Question = 39] = "Question", i[i.QuestionDot = 40] = "QuestionDot", i[i.QuestionQuestion = 41] = "QuestionQuestion", i[i.SlashEqual = 42] = "SlashEqual", i[i.StarEqual = 43] = "StarEqual", i[i.DotDot = 44] = "DotDot", i[i.DotDotDot = 45] = "DotDotDot", i[i.LessEqualGreater = 46] = "LessEqualGreater", i[i.Identifier = 47] = "Identifier", i[i.Template = 48] = "Template", i[i.String = 49] = "String", i[i.Number = 50] = "Number", i[i.LeftShift = 51] = "LeftShift", i[i.RightShift = 52] = "RightShift", i[i.Pipeline = 53] = "Pipeline", i[i.Tilde = 54] = "Tilde", i[i.And = 55] = "And", i[i.Const = 56] = "Const", i[i.Debug = 57] = "Debug", i[i.False = 58] = "False", i[i.In = 59] = "In", i[i.Instanceof = 60] = "Instanceof", i[i.New = 61] = "New", i[i.Null = 62] = "Null", i[i.Undefined = 63] = "Undefined", i[i.Of = 64] = "Of", i[i.Or = 65] = "Or", i[i.True = 66] = "True", i[i.Typeof = 67] = "Typeof", i[i.Void = 68] = "Void", i[i.With = 69] = "With", i))(r || {}); -class lt { +class ft { constructor(t, e, s, n, a) { this.name = r[t], this.type = t, this.lexeme = e, this.literal = s, this.line = n, this.col = a; } @@ -524,8 +557,8 @@ class lt { return `[(${this.line}):"${this.lexeme}"]`; } } -const ut = [" ", ` -`, " ", "\r"], qt = [ +const pt = [" ", ` +`, " ", "\r"], Bt = [ "area", "base", "br", @@ -541,13 +574,13 @@ const ut = [" ", ` "track", "wbr" ]; -class gt { - parse(t) { - this.current = 0, this.tokens = t; - const e = []; +class wt { + parse(t, e = "") { + this.current = 0, this.tokens = t, this.source = e; + const s = []; for (; !this.eof(); ) - e.push(this.expression()); - return e; + s.push(this.expression()); + return s; } match(...t) { for (const e of t) @@ -578,7 +611,7 @@ class gt { ); } error(t, e, s = {}) { - throw new C(t, s, e.line, e.col); + throw new C(t, s, { line: e.line, col: e.col, source: this.source }); } synchronize() { do { @@ -604,7 +637,7 @@ class gt { 'Expected "of" keyword inside foreach statement' ); const n = this.expression(); - return new Rt(e, s, n, e.line); + return new Dt(e, s, n, e.line); } expression() { const t = this.assignment(); @@ -626,14 +659,14 @@ class gt { let s = this.assignment(); if (t instanceof O) { const n = t.name; - return e.type !== r.Equal && (s = new D( + return e.type !== r.Equal && (s = new _( new O(n, n.line), e, s, e.line - )), new Ct(n, s, n.line); + )), new kt(n, s, n.line); } else if (t instanceof R) - return e.type !== r.Equal && (s = new D( + return e.type !== r.Equal && (s = new _( new R(t.entity, t.key, t.type, t.line), e, s, @@ -647,7 +680,7 @@ class gt { let t = this.ternary(); for (; this.match(r.Pipeline); ) { const e = this.ternary(); - t = new Dt(t, e, t.line); + t = new $t(t, e, t.line); } return t; } @@ -657,7 +690,7 @@ class gt { const e = this.ternary(); this.consume(r.Colon, 'Expected ":" after ternary ? expression'); const s = this.ternary(); - return new It(t, e, s, t.line); + return new qt(t, e, s, t.line); } return t; } @@ -665,7 +698,7 @@ class gt { const t = this.logicalOr(); if (this.match(r.QuestionQuestion)) { const e = this.nullCoalescing(); - return new kt(t, e, t.line); + return new Lt(t, e, t.line); } return t; } @@ -673,7 +706,7 @@ class gt { let t = this.logicalAnd(); for (; this.match(r.Or); ) { const e = this.previous(), s = this.logicalAnd(); - t = new at(t, e, s, e.line); + t = new ot(t, e, s, e.line); } return t; } @@ -681,7 +714,7 @@ class gt { let t = this.equality(); for (; this.match(r.And); ) { const e = this.previous(), s = this.equality(); - t = new at(t, e, s, e.line); + t = new ot(t, e, s, e.line); } return t; } @@ -700,7 +733,7 @@ class gt { r.In ); ) { const e = this.previous(), s = this.shift(); - t = new D(t, e, s, e.line); + t = new _(t, e, s, e.line); } return t; } @@ -708,7 +741,7 @@ class gt { let t = this.addition(); for (; this.match(r.LeftShift, r.RightShift); ) { const e = this.previous(), s = this.addition(); - t = new D(t, e, s, e.line); + t = new _(t, e, s, e.line); } return t; } @@ -716,7 +749,7 @@ class gt { let t = this.modulus(); for (; this.match(r.Minus, r.Plus); ) { const e = this.previous(), s = this.modulus(); - t = new D(t, e, s, e.line); + t = new _(t, e, s, e.line); } return t; } @@ -724,7 +757,7 @@ class gt { let t = this.multiplication(); for (; this.match(r.Percent); ) { const e = this.previous(), s = this.multiplication(); - t = new D(t, e, s, e.line); + t = new _(t, e, s, e.line); } return t; } @@ -732,14 +765,14 @@ class gt { let t = this.typeof(); for (; this.match(r.Slash, r.Star); ) { const e = this.previous(), s = this.typeof(); - t = new D(t, e, s, e.line); + t = new _(t, e, s, e.line); } return t; } typeof() { if (this.match(r.Typeof)) { const t = this.previous(), e = this.typeof(); - return new Lt(e, t.line); + return new Ot(e, t.line); } return this.unary(); } @@ -753,20 +786,20 @@ class gt { r.MinusMinus )) { const t = this.previous(), e = this.unary(); - return new Kt(t, e, t.line); + return new Mt(t, e, t.line); } return this.newKeyword(); } newKeyword() { if (this.match(r.New)) { const t = this.previous(), e = this.call(); - return e instanceof J ? new ot(e.callee, e.args, t.line) : new ot(e, [], t.line); + return e instanceof T ? new lt(e.callee, e.args, t.line) : new lt(e, [], t.line); } return this.postfix(); } postfix() { const t = this.call(); - return this.match(r.PlusPlus) ? new ht(t, 1, t.line) : this.match(r.MinusMinus) ? new ht(t, -1, t.line) : t; + return this.match(r.PlusPlus) ? new ut(t, 1, t.line) : this.match(r.MinusMinus) ? new ut(t, -1, t.line) : t; } call() { let t = this.primary(), e; @@ -811,13 +844,13 @@ class gt { this.match(r.DotDotDot) ? n.push(new I(this.expression(), this.previous().line)) : n.push(this.expression()); while (this.match(r.Comma)); const a = this.consume(r.RightParen, 'Expected ")" after arguments'); - return new J(t, a, n, a.line, s); + return new T(t, a, n, a.line, s); } dotGet(t, e) { const s = this.consume( r.Identifier, "Expect property name after '.'" - ), n = new z(s, s.line); + ), n = new j(s, s.line); return new R(t, n, e.type, s.line); } bracketGet(t, e) { @@ -826,22 +859,22 @@ class gt { } primary() { if (this.match(r.False)) - return new _(!1, this.previous().line); + return new D(!1, this.previous().line); if (this.match(r.True)) - return new _(!0, this.previous().line); + return new D(!0, this.previous().line); if (this.match(r.Null)) - return new _(null, this.previous().line); + return new D(null, this.previous().line); if (this.match(r.Undefined)) - return new _(void 0, this.previous().line); + return new D(void 0, this.previous().line); if (this.match(r.Number) || this.match(r.String)) - return new _(this.previous().literal, this.previous().line); + return new D(this.previous().literal, this.previous().line); if (this.match(r.Template)) - return new _t(this.previous().literal, this.previous().line); + return new Kt(this.previous().literal, this.previous().line); if (this.check(r.Identifier) && this.tokenAt(1) === r.Arrow) { const t = this.advance(); this.advance(); const e = this.expression(); - return new rt([t], e, t.line); + return new at([t], e, t.line); } if (this.match(r.Identifier)) { const t = this.previous(); @@ -856,11 +889,11 @@ class gt { while (this.match(r.Comma)); this.consume(r.RightParen, 'Expected ")"'), this.consume(r.Arrow, 'Expected "=>"'); const e = this.expression(); - return new rt(t, e, this.previous().line); + return new at(t, e, this.previous().line); } if (this.match(r.LeftParen)) { const t = this.expression(); - return this.consume(r.RightParen, 'Expected ")" after expression'), new Pt(t, t.line); + return this.consume(r.RightParen, 'Expected ")" after expression'), new It(t, t.line); } if (this.match(r.LeftBrace)) return this.dictionary(); @@ -868,11 +901,11 @@ class gt { return this.list(); if (this.match(r.Void)) { const t = this.expression(); - return new $t(t, this.previous().line); + return new Ut(t, this.previous().line); } if (this.match(r.Debug)) { const t = this.expression(); - return new yt(t, this.previous().line); + return new _t(t, this.previous().line); } throw this.error( E.EXPECTED_EXPRESSION, @@ -883,7 +916,7 @@ class gt { dictionary() { const t = this.previous(); if (this.match(r.RightBrace)) - return new nt([], this.previous().line); + return new ct([], this.previous().line); const e = []; do if (this.match(r.DotDotDot)) @@ -893,12 +926,12 @@ class gt { if (this.match(r.Colon)) { const n = this.expression(); e.push( - new B(null, new z(s, s.line), n, s.line) + new B(null, new j(s, s.line), n, s.line) ); } else { const n = new O(s, s.line); e.push( - new B(null, new z(s, s.line), n, s.line) + new B(null, new j(s, s.line), n, s.line) ); } } else @@ -908,41 +941,41 @@ class gt { { token: this.peek().lexeme } ); while (this.match(r.Comma)); - return this.consume(r.RightBrace, 'Expected "}" after object literal'), new nt(e, t.line); + return this.consume(r.RightBrace, 'Expected "}" after object literal'), new ct(e, t.line); } list() { const t = [], e = this.previous(); if (this.match(r.RightBracket)) - return new ct([], this.previous().line); + return new ht([], this.previous().line); do this.match(r.DotDotDot) ? t.push(new I(this.expression(), this.previous().line)) : t.push(this.expression()); while (this.match(r.Comma)); return this.consume( r.RightBracket, 'Expected "]" after array declaration' - ), new ct(t, e.line); + ), new ht(t, e.line); } } function q(i) { return i >= "0" && i <= "9"; } -function vt(i) { +function bt(i) { return i >= "a" && i <= "z" || i >= "A" && i <= "Z" || i === "$" || i === "_"; } -function Ot(i) { - return vt(i) || q(i); +function Gt(i) { + return bt(i) || q(i); } -function Mt(i) { +function Vt(i) { return i.charAt(0).toUpperCase() + i.substring(1).toLowerCase(); } -function Ut(i) { +function Xt(i) { return r[i] >= r.And; } -class wt { +class xt { scan(t) { for (this.source = t, this.tokens = [], this.current = 0, this.start = 0, this.line = 1, this.col = 1; !this.eof(); ) this.start = this.current, this.getToken(); - return this.tokens.push(new lt(r.Eof, "", null, this.line, 0)), this.tokens; + return this.tokens.push(new ft(r.Eof, "", null, this.line, 0)), this.tokens; } eof() { return this.current >= this.source.length; @@ -953,7 +986,7 @@ class wt { } addToken(t, e) { const s = this.source.substring(this.start, this.current); - this.tokens.push(new lt(t, s, e, this.line, this.col)); + this.tokens.push(new ft(t, s, e, this.line, this.col)); } match(t) { return this.eof() || this.source.charAt(this.current) !== t ? !1 : (this.current++, !0); @@ -996,10 +1029,10 @@ class wt { this.addToken(r.Number, Number(t)); } identifier() { - for (; Ot(this.peek()); ) + for (; Gt(this.peek()); ) this.advance(); - const t = this.source.substring(this.start, this.current), e = Mt(t); - Ut(e) ? this.addToken(r[e], t) : this.addToken(r.Identifier, t); + const t = this.source.substring(this.start, this.current), e = Vt(t); + Xt(e) ? this.addToken(r[e], t) : this.addToken(r.Identifier, t); } getToken() { const t = this.advance(); @@ -1139,12 +1172,12 @@ class wt { break; // complex cases default: - q(t) ? this.number() : vt(t) ? this.identifier() : this.error(E.UNEXPECTED_CHARACTER, { char: t }); + q(t) ? this.number() : bt(t) ? this.identifier() : this.error(E.UNEXPECTED_CHARACTER, { char: t }); break; } } error(t, e = {}) { - throw new C(t, e, this.line, this.col); + throw new C(t, e, { line: this.line, col: this.col, source: this.source }); } } class b { @@ -1165,16 +1198,16 @@ class b { return e && typeof e[t] < "u" ? e[t] : this.parent !== null ? this.parent.get(t) : window[t]; } } -class Bt { +class Qt { constructor() { - this.scope = new b(), this.scanner = new wt(), this.parser = new gt(); + this.scope = new b(), this.scanner = new xt(), this.parser = new wt(); } evaluate(t) { return t.result = t.accept(this); } visitPipelineExpr(t) { const e = this.evaluate(t.left); - if (t.right instanceof J) { + if (t.right instanceof T) { const n = this.evaluate(t.right.callee), a = [e]; for (const o of t.right.args) o instanceof I ? a.push(...this.evaluate(o.value)) : a.push(this.evaluate(o)); @@ -1197,7 +1230,7 @@ class Bt { }; } error(t, e = {}, s, n) { - throw new C(t, e, s, n); + throw new C(t, e, { line: s, col: n }); } visitVariableExpr(t) { return this.scope.get(t.name.lexeme); @@ -1226,7 +1259,7 @@ class Bt { const n = new B( t.entity.entity, t.entity.key, - new _(s, t.line), + new D(s, t.line), t.line ); this.evaluate(n); @@ -1244,7 +1277,7 @@ class Bt { return this.evaluate(t.value); } templateParse(t) { - const e = this.scanner.scan(t), s = this.parser.parse(e); + const e = this.scanner.scan(t), s = this.parser.parse(e, t); let n = ""; for (const a of s) n += this.evaluate(a).toString(); @@ -1344,7 +1377,7 @@ class Bt { const n = new B( t.right.entity, t.right.key, - new _(s, t.line), + new D(s, t.line), t.line ); this.evaluate(n); @@ -1410,9 +1443,9 @@ class Bt { return console.log(e), ""; } } -class Q { +class F { } -class ft extends Q { +class dt extends F { constructor(t, e, s, n, a = 0) { super(), this.type = "element", this.name = t, this.attributes = e, this.children = s, this.self = n, this.line = a; } @@ -1423,7 +1456,7 @@ class ft extends Q { return "KNode.Element"; } } -class Gt extends Q { +class Ft extends F { constructor(t, e, s = 0) { super(), this.type = "attribute", this.name = t, this.value = e, this.line = s; } @@ -1434,7 +1467,7 @@ class Gt extends Q { return "KNode.Attribute"; } } -class Vt extends Q { +class Wt extends F { constructor(t, e = 0) { super(), this.type = "text", this.value = t, this.line = e; } @@ -1445,7 +1478,7 @@ class Vt extends Q { return "KNode.Text"; } } -class Xt extends Q { +class zt extends F { constructor(t, e = 0) { super(), this.type = "doctype", this.value = t, this.line = e; } @@ -1456,7 +1489,7 @@ class Xt extends Q { return "KNode.Doctype"; } } -class et { +class it { parse(t) { for (this.current = 0, this.line = 1, this.col = 1, this.source = t, this.nodes = []; !this.eof(); ) { const e = this.node(); @@ -1487,7 +1520,7 @@ class et { return this.current > this.source.length; } error(t, e = {}) { - throw new C(t, e, this.line, this.col); + throw new C(t, e, { line: this.line, col: this.col, source: this.source }); } node() { this.whitespace(); @@ -1506,17 +1539,17 @@ class et { this.advance("Expected closing doctype"); while (!this.match(">")); const e = this.source.slice(t, this.current - 1).trim(); - return new Xt(e, this.line); + return new zt(e, this.line); } element() { const t = this.line, e = this.identifier("/", ">"); e || this.error(E.EXPECTED_TAG_NAME); const s = this.attributes(); - if (this.match("/>") || qt.includes(e) && this.match(">")) - return new ft(e, s, [], !0, this.line); + if (this.match("/>") || Bt.includes(e) && this.match(">")) + return new dt(e, s, [], !0, this.line); this.match(">") || this.error(E.EXPECTED_CLOSING_BRACKET); let n = []; - return this.whitespace(), this.peek("") || this.error(E.EXPECTED_CLOSING_TAG, { name: t }); @@ -1537,7 +1570,7 @@ class et { const e = this.line, s = this.identifier("=", ">", "/>"); s || this.error(E.BLANK_ATTRIBUTE_NAME), this.whitespace(); let n = ""; - this.match("=") && (this.whitespace(), this.match("'") ? n = this.decodeEntities(this.string("'")) : this.match('"') ? n = this.decodeEntities(this.string('"')) : n = this.decodeEntities(this.identifier(">", "/>"))), this.whitespace(), t.push(new Gt(s, n, e)); + this.match("=") && (this.whitespace(), this.match("'") ? n = this.decodeEntities(this.string("'")) : this.match('"') ? n = this.decodeEntities(this.string('"')) : n = this.decodeEntities(this.identifier(">", "/>"))), this.whitespace(), t.push(new Ft(s, n, e)); } return t; } @@ -1558,21 +1591,21 @@ class et { this.advance(); } const n = this.source.slice(t, this.current).trim(); - return n ? new Vt(this.decodeEntities(n), e) : null; + return n ? new Wt(this.decodeEntities(n), e) : null; } decodeEntities(t) { return t.replace(/ /g, " ").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, '"').replace(/'/g, "'").replace(/&/g, "&"); } whitespace() { let t = 0; - for (; this.peek(...ut) && !this.eof(); ) + for (; this.peek(...pt) && !this.eof(); ) t += 1, this.advance(); return t; } identifier(...t) { this.whitespace(); const e = this.current; - for (; !this.peek(...ut, ...t); ) + for (; !this.peek(...pt, ...t); ) this.advance(`Expected closing ${t}`); const s = this.current; return this.whitespace(), this.source.slice(e, s).trim(); @@ -1584,10 +1617,10 @@ class et { return this.source.slice(e, this.current - 1); } } -function Ht(i) { +function ee(i) { history.pushState(null, "", i), window.dispatchEvent(new PopStateEvent("popstate")); } -function Qt(i, t) { +function jt(i, t) { if (i === "*") return {}; const e = i.split("/").filter(Boolean), s = t.split("/").filter(Boolean); if (e.length !== s.length) return null; @@ -1599,7 +1632,7 @@ function Qt(i, t) { return null; return n; } -class pt extends At { +class mt extends Pt { constructor() { super(...arguments), this.routes = []; } @@ -1614,7 +1647,7 @@ class pt extends At { async _navigate() { const t = window.location.pathname; for (const e of this.routes) { - const s = Qt(e.path, t); + const s = jt(e.path, t); if (s !== null) { if (e.guard && !await e.guard()) return; @@ -1628,7 +1661,7 @@ class pt extends At { !s || !this.transpiler || this.transpiler.mountComponent(t, s, e); } } -class j { +class H { constructor(t, e = "boundary") { this.start = document.createComment(`${e}-start`), this.end = document.createComment(`${e}-end`), t.insert && typeof t.insert == "function" ? (t.insert(this.start), t.insert(this.end)) : (t.appendChild(this.start), t.appendChild(this.end)); } @@ -1655,9 +1688,9 @@ class j { return this.start.parentNode; } } -const G = /* @__PURE__ */ new Map(), Z = []; -let L = !1, X = !0; -function T() { +const G = /* @__PURE__ */ new Map(), tt = []; +let L = !1, V = !0; +function et() { L = !1; for (const [t, e] of G.entries()) try { @@ -1666,43 +1699,46 @@ function T() { s(); typeof t.onRender == "function" && t.onRender(); } catch (s) { - console.error("[Kasper] Error during component update:", s); + X(s, "render", t); } G.clear(); - const i = Z.splice(0); + const i = tt.splice(0); for (const t of i) try { t(); } catch (e) { - console.error("[Kasper] Error in nextTick callback:", e); + X(e, "render"); } } -function $(i, t) { - if (!X) { +function K(i, t) { + if (!V) { t(); return; } - G.has(i) || G.set(i, []), G.get(i).push(t), L || (L = !0, queueMicrotask(T)); + G.has(i) || G.set(i, []), G.get(i).push(t), L || (L = !0, queueMicrotask(et)); +} +function Ht() { + return V; } function M(i) { - const t = X; - X = !1; + const t = V; + V = !1; try { i(); } finally { - X = t; + V = t; } } -function Jt(i) { +function se(i) { if (i) { - Z.push(i), L || (L = !0, queueMicrotask(T)); + tt.push(i), L || (L = !0, queueMicrotask(et)); return; } return new Promise((t) => { - Z.push(t), L || (L = !0, queueMicrotask(T)); + tt.push(t), L || (L = !0, queueMicrotask(et)); }); } -const dt = { +const Et = { esc: ["Escape", "Esc"], escape: ["Escape", "Esc"], space: [" ", "Spacebar"], @@ -1721,9 +1757,9 @@ const dt = { minus: ["-"], equal: ["="] }; -class bt { +class St { constructor(t) { - this.scanner = new wt(), this.parser = new gt(), this.templateParser = new et(), this.interpreter = new Bt(), this.registry = {}, this.mode = "development", this.isRendering = !1, this.registry.router = { component: pt }, t && t.registry && (this.registry = { ...this.registry, ...t.registry }); + this.scanner = new xt(), this.parser = new wt(), this.templateParser = new it(), this.interpreter = new Qt(), this.registry = {}, this.mode = "development", this.isRendering = !1, this.registry.router = { component: mt }, t && t.registry && (this.registry = { ...this.registry, ...t.registry }); } renderComponentInstance(t, e, s, n, a) { a && (t.$slots = a), t.$render = () => { @@ -1775,11 +1811,17 @@ class bt { // so effects set up inside @each always evaluate in their item scope. scopedEffect(t) { const e = this.interpreter.scope; - return tt(() => { + return st(() => { const s = this.interpreter.scope; this.interpreter.scope = e; try { t(); + } catch (n) { + if (Ht()) { + const a = this.interpreter.scope.get("$instance"); + X(n, "render", a); + } else + throw n; } finally { this.interpreter.scope = s; } @@ -1801,7 +1843,7 @@ class bt { } // evaluates expressions and returns the result of the first evaluation execute(t, e) { - const s = this.scanner.scan(t), n = this.parser.parse(s), a = this.interpreter.scope; + const s = this.scanner.scan(t), n = this.parser.parse(s, t), a = this.interpreter.scope; e && (this.interpreter.scope = e); const o = n.map( (c) => this.interpreter.evaluate(c) @@ -1826,7 +1868,7 @@ class bt { e && (e.insert && typeof e.insert == "function" ? e.insert(s) : e.appendChild(s)); const n = this.scopedEffect(() => { const a = this.evaluateTemplateString(t.value), o = this.interpreter.scope.get("$instance"); - o ? $(o, () => { + o ? K(o, () => { s.textContent = a; }) : s.textContent = a; }); @@ -1852,40 +1894,40 @@ class bt { return s || null; } doIf(t, e) { - const s = new j(e, "if"), n = () => { + const s = new H(e, "if"), n = () => { const o = this.interpreter.scope.get("$instance"), c = o ? new b(this.interpreter.scope) : this.interpreter.scope, m = this.interpreter.scope; this.interpreter.scope = c; - const d = []; - if (d.push(!!this.execute(t[0][1].value)), !d[0]) { - for (const p of t.slice(1)) - if (this.findAttr(p[0], ["@elseif"])) { - const u = !!this.execute(p[1].value); - if (d.push(u), u) break; - } else if (this.findAttr(p[0], ["@else"])) { - d.push(!0); + const p = []; + if (p.push(!!this.execute(t[0][1].value)), !p[0]) { + for (const d of t.slice(1)) + if (this.findAttr(d[0], ["@elseif"])) { + const u = !!this.execute(d[1].value); + if (p.push(u), u) break; + } else if (this.findAttr(d[0], ["@else"])) { + p.push(!0); break; } } this.interpreter.scope = m; const l = () => { s.nodes().forEach((u) => this.destroyNode(u)), s.clear(); - const p = this.interpreter.scope; + const d = this.interpreter.scope; this.interpreter.scope = c; try { - if (d[0]) { + if (p[0]) { t[0][0].accept(this, s); return; } - for (let u = 1; u < d.length; u++) - if (d[u]) { + for (let u = 1; u < p.length; u++) + if (p[u]) { t[u][0].accept(this, s); return; } } finally { - this.interpreter.scope = p; + this.interpreter.scope = d; } }; - o ? $(o, l) : l(); + o ? K(o, l) : l(); }; s.start.$kasperRefresh = this.scopedRefresh(n); const a = this.scopedEffect(n); @@ -1896,19 +1938,19 @@ class bt { n ? this.doEachKeyed(t, e, s, n) : this.doEachUnkeyed(t, e, s); } doEachUnkeyed(t, e, s) { - const n = new j(s, "each"), a = this.interpreter.scope, o = () => { - const m = this.scanner.scan(t.value), [d, l, p] = this.interpreter.evaluate( + const n = new H(s, "each"), a = this.interpreter.scope, o = () => { + const m = this.scanner.scan(t.value), [p, l, d] = this.interpreter.evaluate( this.parser.foreach(m) ), u = this.interpreter.scope.get("$instance"), f = () => { n.nodes().forEach((w) => this.destroyNode(w)), n.clear(); let h = 0; - for (const w of p) { - const g = { [d]: w }; + for (const w of d) { + const g = { [p]: w }; l && (g[l] = h), this.interpreter.scope = new b(a, g), this.createElement(e, n), h += 1; } this.interpreter.scope = a; }; - u ? $(u, f) : f(); + u ? K(u, f) : f(); }; n.start.$kasperRefresh = this.scopedRefresh(o); const c = this.scopedEffect(o); @@ -1921,31 +1963,31 @@ class bt { }), (e = t.childNodes) == null || e.forEach((s) => this.triggerRefresh(s)); } doEachKeyed(t, e, s, n) { - const a = new j(s, "each"), o = this.interpreter.scope, c = /* @__PURE__ */ new Map(), m = () => { - const l = this.scanner.scan(t.value), [p, u, f] = this.interpreter.evaluate( + const a = new H(s, "each"), o = this.interpreter.scope, c = /* @__PURE__ */ new Map(), m = () => { + const l = this.scanner.scan(t.value), [d, u, f] = this.interpreter.evaluate( this.parser.foreach(l) ), h = this.interpreter.scope.get("$instance"), w = [], g = /* @__PURE__ */ new Set(); let A = 0; for (const N of f) { - const P = { [p]: N }; + const P = { [d]: N }; u && (P[u] = A), this.interpreter.scope = new b(o, P); const S = this.execute(n.value); this.mode === "development" && g.has(S) && console.warn(`[Kasper] Duplicate key detected in @each: "${S}". Keys must be unique to ensure correct reconciliation.`), g.add(S), w.push({ item: N, idx: A, key: S }), A++; } const y = () => { - var st; + var rt; const N = new Set(w.map((k) => k.key)); - for (const [k, K] of c) - N.has(k) || (this.destroyNode(K), (st = K.parentNode) == null || st.removeChild(K), c.delete(k)); + for (const [k, $] of c) + N.has(k) || (this.destroyNode($), (rt = $.parentNode) == null || rt.removeChild($), c.delete(k)); const P = a.end.parentNode; let S = a.start; - for (const { item: k, idx: K, key: W } of w) { - const it = { [p]: k }; - if (u && (it[u] = K), this.interpreter.scope = new b(o, it), c.has(W)) { + for (const { item: k, idx: $, key: W } of w) { + const nt = { [d]: k }; + if (u && (nt[u] = $), this.interpreter.scope = new b(o, nt), c.has(W)) { const x = c.get(W); S.nextSibling !== x && P.insertBefore(x, S.nextSibling), S = x; - const F = x.$kasperScope; - F && (F.set(p, k), u && F.set(u, K), this.triggerRefresh(x)); + const z = x.$kasperScope; + z && (z.set(d, k), u && z.set(u, $), this.triggerRefresh(x)); } else { const x = this.createElement(e, a); x && (S.nextSibling !== x && P.insertBefore(x, S.nextSibling), S = x, c.set(W, x), x.$kasperScope = this.interpreter.scope); @@ -1953,11 +1995,11 @@ class bt { } this.interpreter.scope = o; }; - h ? $(h, y) : y(); + h ? K(h, y) : y(); }; a.start.$kasperRefresh = this.scopedRefresh(m); - const d = this.scopedEffect(m); - this.trackEffect(a, d); + const p = this.scopedEffect(m); + this.trackEffect(a, p); } createSiblings(t, e) { let s = 0; @@ -1968,13 +2010,13 @@ class bt { if (o.type === "element") { const c = o, m = this.findAttr(c, ["@let"]); m && (a || (a = new b(n), this.interpreter.scope = a), this.execute(m.value)); - const d = this.findAttr(c, ["@if"]), l = this.findAttr(c, ["@elseif"]), p = this.findAttr(c, ["@else"]), u = this.findAttr(c, ["@each"]); - if (this.mode === "development" && [d, l, p, u].filter((h) => h).length > 1 && this.error(E.MULTIPLE_STRUCTURAL_DIRECTIVES, {}, c.name), u) { + const p = this.findAttr(c, ["@if"]), l = this.findAttr(c, ["@elseif"]), d = this.findAttr(c, ["@else"]), u = this.findAttr(c, ["@each"]); + if (this.mode === "development" && [p, l, d, u].filter((h) => h).length > 1 && this.error(E.MULTIPLE_STRUCTURAL_DIRECTIVES, {}, c.name), u) { this.doEach(u, c, e); continue; } - if (d) { - const f = [[c, d]]; + if (p) { + const f = [[c, p]]; for (; s < t.length; ) { const h = t[s]; if (h.type !== "element") break; @@ -1999,19 +2041,19 @@ class bt { var s, n; try { if (t.name === "slot") { - const l = this.findAttr(t, ["@name"]), p = l ? l.value : "default", u = this.interpreter.scope.get("$slots"); - if (u && u[p]) { + const l = this.findAttr(t, ["@name"]), d = l ? l.value : "default", u = this.interpreter.scope.get("$slots"); + if (u && u[d]) { const f = this.interpreter.scope; - u[p].scope && (this.interpreter.scope = u[p].scope), this.createSiblings(u[p], e), this.interpreter.scope = f; + u[d].scope && (this.interpreter.scope = u[d].scope), this.createSiblings(u[d], e), this.interpreter.scope = f; } return; } const a = t.name === "void", o = !!this.registry[t.name], c = a ? e : document.createElement(t.name), m = this.interpreter.scope; if (c && c !== e && this.interpreter.scope.set("$ref", c), o) { let l = {}; - const p = t.attributes.filter( + const d = t.attributes.filter( (h) => h.name.startsWith("@:") - ), u = this.createComponentArgs(p), f = { default: [] }; + ), u = this.createComponentArgs(d), f = { default: [] }; f.default.scope = this.interpreter.scope; for (const h of t.children) { if (h.type === "element") { @@ -2043,7 +2085,7 @@ class bt { args: u, ref: c, transpiler: this - }), this.bindMethods(l), c.$kasperInstance = l, t.name === "router" && l instanceof pt) { + }), this.bindMethods(l), c.$kasperInstance = l, t.name === "router" && l instanceof mt) { const h = new b(m, l); l.setRoutes(this.extractRoutes(t.children, void 0, h)); } @@ -2057,10 +2099,10 @@ class bt { ); for (const f of l) this.createEventListener(c, f); - const p = t.attributes.filter( + const d = t.attributes.filter( (f) => !f.name.startsWith("@") ); - for (const f of p) + for (const f of d) this.evaluate(f, c); const u = t.attributes.filter((f) => { const h = f.name; @@ -2075,7 +2117,7 @@ class bt { const g = this.execute(f.value), A = this.interpreter.scope.get("$instance"), y = () => { c.setAttribute("class", g); }; - A ? $(A, y) : y(); + A ? K(A, y) : y(); }); this.trackEffect(c, w); } else { @@ -2089,17 +2131,17 @@ class bt { } else c.setAttribute(h, g); }; - A ? $(A, y) : y(); + A ? K(A, y) : y(); }); this.trackEffect(c, w); } } } e && !a && (e.insert && typeof e.insert == "function" ? e.insert(c) : e.appendChild(c)); - const d = this.findAttr(t, ["@ref"]); - if (d && !a) { - const l = d.value.trim(), p = this.interpreter.scope.get("$instance"); - p ? p[l] = c : this.interpreter.scope.set(l, c); + const p = this.findAttr(t, ["@ref"]); + if (p && !a) { + const l = p.value.trim(), d = this.interpreter.scope.get("$instance"); + d ? d[l] = c : this.interpreter.scope.set(l, c); } return t.self || (this.createSiblings(t.children, c), this.interpreter.scope = m), c; } catch (a) { @@ -2126,14 +2168,14 @@ class bt { createEventListener(t, e) { const [s, ...n] = e.name.split(":")[1].split("."), a = new b(this.interpreter.scope), o = this.interpreter.scope.get("$instance"), c = {}; o && o.$abortController && (c.signal = o.$abortController.signal), n.includes("once") && (c.once = !0), n.includes("passive") && (c.passive = !0), n.includes("capture") && (c.capture = !0); - const m = ["prevent", "stop", "once", "passive", "capture", "ctrl", "shift", "alt", "meta"], d = n.filter((l) => !m.includes(l.toLowerCase())); + const m = ["prevent", "stop", "once", "passive", "capture", "ctrl", "shift", "alt", "meta"], p = n.filter((l) => !m.includes(l.toLowerCase())); t.addEventListener( s, (l) => { - d.length > 0 && !d.some((u) => { + p.length > 0 && !p.some((u) => { var h; const f = u.toLowerCase(); - return !!(dt[f] && dt[f].includes(l.key) || f === ((h = l.key) == null ? void 0 : h.toLowerCase())); + return !!(Et[f] && Et[f].includes(l.key) || f === ((h = l.key) == null ? void 0 : h.toLowerCase())); }) || n.includes("ctrl") && !l.ctrlKey || n.includes("shift") && !l.shiftKey || n.includes("alt") && !l.altKey || n.includes("meta") && !l.metaKey || (n.includes("prevent") && l.preventDefault(), n.includes("stop") && l.stopPropagation(), a.set("$event", l), this.execute(e.value, a)); }, c @@ -2143,7 +2185,7 @@ class bt { return t && (/\{\{.+\}\}/ms.test(t) ? t.replace(/\{\{([\s\S]+?)\}\}/g, (s, n) => this.evaluateExpression(n)) : t); } evaluateExpression(t) { - const e = this.scanner.scan(t), s = this.parser.parse(e); + const e = this.scanner.scan(t), s = this.parser.parse(e, t); let n = ""; for (const a of s) n += `${this.interpreter.evaluate(a)}`; @@ -2178,20 +2220,20 @@ class bt { this.isRendering = !0; try { this.destroy(o), o.innerHTML = ""; - const p = new b(null, c); - p.set("$instance", c); + const d = new b(null, c); + d.set("$instance", c); const u = this.interpreter.scope; - this.interpreter.scope = p, M(() => { + this.interpreter.scope = d, M(() => { this.createSiblings(m, o), typeof c.onRender == "function" && c.onRender(); }), this.interpreter.scope = u; } finally { this.isRendering = !1; } }; - const d = new b(null, c); - d.set("$instance", c); + const p = new b(null, c); + p.set("$instance", c); const l = this.interpreter.scope; - this.interpreter.scope = d, M(() => { + this.interpreter.scope = p, M(() => { this.createSiblings(a, o); }), this.interpreter.scope = l, typeof c.onMount == "function" && c.onMount(), typeof c.onRender == "function" && c.onRender(); } @@ -2202,15 +2244,15 @@ class bt { if (o.type !== "element") continue; const c = o; if (c.name === "route") { - const m = this.findAttr(c, ["@path"]), d = this.findAttr(c, ["@component"]), l = this.findAttr(c, ["@guard"]); - (!m || !d) && this.error(E.MISSING_REQUIRED_ATTR, { message: " requires @path and @component attributes." }, c.name); - const p = m.value, u = this.execute(d.value), f = l ? this.execute(l.value) : e; - n.push({ path: p, component: u, guard: f }); + const m = this.findAttr(c, ["@path"]), p = this.findAttr(c, ["@component"]), l = this.findAttr(c, ["@guard"]); + (!m || !p) && this.error(E.MISSING_REQUIRED_ATTR, { message: " requires @path and @component attributes." }, c.name); + const d = m.value, u = this.execute(p.value), f = l ? this.execute(l.value) : e; + n.push({ path: d, component: u, guard: f }); } else if (c.name === "guard") { const m = this.findAttr(c, ["@check"]); if (m || this.error(E.MISSING_REQUIRED_ATTR, { message: " requires @check attribute." }, c.name), !m) continue; - const d = this.execute(m.value); - n.push(...this.extractRoutes(c.children, d)); + const p = this.execute(m.value); + n.push(...this.extractRoutes(c.children, p)); } } return s && (this.interpreter.scope = a), n; @@ -2224,17 +2266,17 @@ class bt { } error(t, e, s) { let n = e; - throw typeof e == "string" && (n = { message: e.includes("Runtime Error") ? e.replace("Runtime Error: ", "") : e }), new C(t, n, void 0, void 0, s); + throw typeof e == "string" && (n = { message: e.includes("Runtime Error") ? e.replace("Runtime Error: ", "") : e }), new C(t, n, { tag: s }); } } -function Zt(i) { +function ie(i) { return { lazy: !0, component: () => i().then((t) => Object.values(t)[0]) }; } -function Tt(i) { - const t = new et(); +function re(i) { + const t = new it(); try { const e = t.parse(i); return JSON.stringify(e); @@ -2242,11 +2284,11 @@ function Tt(i) { return JSON.stringify([e instanceof Error ? e.message : String(e)]); } } -function te(i, t, e, s) { - const a = new et().parse(i); - return new bt({ registry: s || {} }).transpile(a, t || {}, e); +function ne(i, t, e, s) { + const a = new it().parse(i); + return new St({ registry: s || {} }).transpile(a, t || {}, e); } -function Wt(i, t) { +function Yt(i, t) { const e = document.createElement(t), s = new i.registry[t].component({ ref: e, transpiler: i, @@ -2258,7 +2300,7 @@ function Wt(i, t) { nodes: i.resolveNodes(t) }; } -function ee(i) { +function ae(i) { const t = typeof i.root == "string" ? document.querySelector(i.root) : i.root; if (!t) throw new C( @@ -2271,28 +2313,29 @@ function ee(i) { E.ENTRY_COMPONENT_NOT_FOUND, { tag: e } ); - const s = new bt({ registry: i.registry }); + i.onError && Ct(i.onError); + const s = new St({ registry: i.registry }); i.mode && (s.mode = i.mode); - const { node: n, instance: a, nodes: o } = Wt(s, e); + const { node: n, instance: a, nodes: o } = Yt(s, e); return t.innerHTML = "", t.appendChild(n), typeof a.onMount == "function" && a.onMount(), s.transpile(o, a, n), typeof a.onRender == "function" && a.onRender(), a; } export { - ee as App, - At as Component, - gt as ExpressionParser, - Bt as Interpreter, - pt as Router, - wt as Scanner, - et as TemplateParser, - bt as Transpiler, - jt as batch, - Nt as computed, - tt as effect, - Tt as execute, - Zt as lazy, - Ht as navigate, - Jt as nextTick, - Ft as signal, - te as transpile, - zt as watch + ae as App, + Pt as Component, + wt as ExpressionParser, + Qt as Interpreter, + mt as Router, + xt as Scanner, + it as TemplateParser, + St as Transpiler, + Tt as batch, + Rt as computed, + st as effect, + re as execute, + ie as lazy, + ee as navigate, + se as nextTick, + Jt as signal, + ne as transpile, + Zt as watch }; diff --git a/dist/types/component.d.ts b/dist/types/component.d.ts index 7f05cb5..d948cce 100644 --- a/dist/types/component.d.ts +++ b/dist/types/component.d.ts @@ -34,6 +34,7 @@ export declare class Component = Record | null | undefined; diff --git a/dist/types/error-handler.d.ts b/dist/types/error-handler.d.ts new file mode 100644 index 0000000..9f2291f --- /dev/null +++ b/dist/types/error-handler.d.ts @@ -0,0 +1,7 @@ +export type ErrorPhase = 'render' | 'watcher'; +export type ErrorHandlerFn = (error: Error, context: { + component?: any; + phase: ErrorPhase; +}) => void; +export declare function setErrorHandler(handler: ErrorHandlerFn | undefined): void; +export declare function handleError(error: unknown, phase: ErrorPhase, component?: any): void; diff --git a/dist/types/expression-parser.d.ts b/dist/types/expression-parser.d.ts index ee0ef52..399fead 100644 --- a/dist/types/expression-parser.d.ts +++ b/dist/types/expression-parser.d.ts @@ -3,7 +3,8 @@ import { Token } from "./types/token"; export declare class ExpressionParser { private current; private tokens; - parse(tokens: Token[]): Expr.Expr[]; + private source; + parse(tokens: Token[], source?: string): Expr.Expr[]; private match; private advance; private peek; diff --git a/dist/types/index.d.ts b/dist/types/index.d.ts index de2ce4c..5027b8b 100644 --- a/dist/types/index.d.ts +++ b/dist/types/index.d.ts @@ -10,3 +10,4 @@ import { signal, effect, computed, batch, watch } from "./signal"; import { nextTick } from "./scheduler"; export { ExpressionParser, Interpreter, Scanner, TemplateParser, Transpiler, signal, effect, computed, batch, watch, nextTick }; export { execute, transpile, bootstrap as App, lazy, Component, navigate, Router }; +export type { ErrorHandlerFn } from "./error-handler"; diff --git a/dist/types/kasper.d.ts b/dist/types/kasper.d.ts index 98c7ec6..6445dd5 100644 --- a/dist/types/kasper.d.ts +++ b/dist/types/kasper.d.ts @@ -1,4 +1,5 @@ import { ComponentClass, ComponentRegistry } from "./component"; +import { ErrorHandlerFn } from "./error-handler"; export declare function lazy(importer: () => Promise>): { component: () => Promise; lazy: true; @@ -12,5 +13,6 @@ export interface KasperConfig { entry?: string; registry: ComponentRegistry; mode?: "development" | "production"; + onError?: ErrorHandlerFn; } export declare function bootstrap(config: KasperConfig): import("./component").Component>; diff --git a/dist/types/scheduler.d.ts b/dist/types/scheduler.d.ts index 3ae74d1..2b0594d 100644 --- a/dist/types/scheduler.d.ts +++ b/dist/types/scheduler.d.ts @@ -5,6 +5,7 @@ export declare function queueUpdate(instance: Component, task: Task): void; * Executes a function with batching disabled. * Used for initial mount and manual renders. */ +export declare function isBatching(): boolean; export declare function flushSync(fn: () => void): void; /** * Returns a promise that resolves after the next framework update cycle. diff --git a/dist/types/types/error.d.ts b/dist/types/types/error.d.ts index 3398112..757296c 100644 --- a/dist/types/types/error.d.ts +++ b/dist/types/types/error.d.ts @@ -29,12 +29,18 @@ export declare const KErrorCode: { }; export type KErrorCodeType = (typeof KErrorCode)[keyof typeof KErrorCode]; export declare const ErrorTemplates: Record string>; +export interface KasperErrorOptions { + line?: number; + col?: number; + tag?: string; + source?: string; +} export declare class KasperError extends Error { code: KErrorCodeType; args: any; line?: number; col?: number; tagName?: string; - constructor(code: KErrorCodeType, args?: any, line?: number, col?: number, tagName?: string); + constructor(code: KErrorCodeType, args?: any, options?: KasperErrorOptions); withTag(tagName: string): this; } diff --git a/docs-web/astro.config.mjs b/docs-web/astro.config.mjs index 4bd89e6..57162d1 100644 --- a/docs-web/astro.config.mjs +++ b/docs-web/astro.config.mjs @@ -30,6 +30,7 @@ export default defineConfig({ { label: 'Pipes', link: '/guides/pipes/' }, { label: 'Routing', link: '/guides/routing/' }, { label: 'Lazy Loading', link: '/guides/lazy-loading/' }, + { label: 'Error Handling', link: '/guides/error-handling/' }, { label: 'AI-Driven Development', link: '/guides/agents/' }, { label: 'Vite Integration', link: '/guides/vite/' } ] diff --git a/docs-web/public/llms.txt b/docs-web/public/llms.txt index cb31490..3268961 100644 --- a/docs-web/public/llms.txt +++ b/docs-web/public/llms.txt @@ -527,6 +527,33 @@ registry: { --- +## Error handling + +Errors during reactive updates are caught by the framework. Configure handlers to surface them: + +```ts +// Global handler — receives all unhandled errors +App({ + onError(error, { component, phase }) { + // phase: 'render' | 'watcher' + Sentry.captureException(error); + }, +}); + +// Component-level — handle locally, optionally show fallback UI +export class MyComponent extends Component { + onError(error: Error, phase: string) { + this.hasError.value = true; + // re-throw to also reach the global handler + } +} +``` + +Propagation order: component `onError` → global `onError` → `console.error`. +Component `onError` suppresses the global handler unless it re-throws. + +--- + ## Key rules - One component per `.kasper` file diff --git a/docs-web/src/content/docs/guides/error-handling.md b/docs-web/src/content/docs/guides/error-handling.md new file mode 100644 index 0000000..337637d --- /dev/null +++ b/docs-web/src/content/docs/guides/error-handling.md @@ -0,0 +1,104 @@ +--- +title: Error Handling +description: Catching and reporting render errors with component and global error handlers. +sidebar: + order: 10 +--- + +By default, errors that occur during a reactive update (signal change triggering a re-render) are caught by the framework to prevent a single component from crashing the whole app. Without error handlers configured those errors are only logged to the console — your application code never sees them. + +Kasper provides two levels of error handling: a **component-level `onError` hook** and a **global `onError` handler** on the app config. + +## Global error handler + +Pass `onError` to `App()` to intercept all unhandled render and watcher errors. Use this for error reporting services like Sentry: + +```ts +import { App } from 'kasper-js'; +import { AppRoot } from './components/AppRoot.kasper'; + +App({ + root: document.body, + entry: 'app-root', + registry: { + 'app-root': { component: AppRoot }, + }, + onError(error, { component, phase }) { + console.error(`[${phase}] in`, component?.constructor?.name, error); + // e.g. Sentry.captureException(error, { extra: { phase } }); + }, +}); +``` + +`phase` is either `'render'` (reactive DOM update) or `'watcher'` (a `watch()` callback threw). + +## Component-level `onError` + +Define `onError` on any component to handle errors locally — for example to show a fallback UI instead of leaving a broken element on screen: + +```html + + + + +``` + +If `onError` handles the error (does not re-throw), the global handler is **not** called. Re-throw if you want both — local recovery AND global reporting. + +## Error propagation order + +``` +Error during render / watcher + │ + ├─ component.onError defined? + │ ├─ yes → call it + │ │ ├─ returns normally → done (global handler skipped) + │ │ └─ throws → fall through with original error + │ └─ no → fall through + │ + ├─ global onError configured? + │ ├─ yes → call it → done + │ └─ no → fall through + │ + └─ console.error (final fallback) +``` + +## TypeScript + +`ErrorHandlerFn` is exported for typing the global handler: + +```ts +import type { ErrorHandlerFn } from 'kasper-js'; + +const handler: ErrorHandlerFn = (error, { component, phase }) => { + // ... +}; +``` + +## What is and isn't caught + +| Scenario | Caught | +|---|---| +| Error in template expression during reactive update | ✓ | +| Error in a `watch()` callback | ✓ | +| Error thrown during initial mount (`App()`) | ✗ — propagates to caller | +| Error in `onMount` / `onDestroy` | ✗ — propagates normally | diff --git a/spec/error-handling.spec.ts b/spec/error-handling.spec.ts new file mode 100644 index 0000000..2d51a4d --- /dev/null +++ b/spec/error-handling.spec.ts @@ -0,0 +1,261 @@ +import { describe, it, expect, vi, afterEach } from "vitest"; +import { Component } from "../src/component"; +import { signal } from "../src/signal"; +import { queueUpdate, nextTick } from "../src/scheduler"; +import { setErrorHandler } from "../src/error-handler"; +import { Transpiler } from "../src/transpiler"; +import { App } from "../src/index"; + +// Reset the global error handler after every test to avoid cross-contamination +afterEach(() => { + setErrorHandler(undefined); + vi.restoreAllMocks(); +}); + +// --------------------------------------------------------------------------- +// Helpers +// --------------------------------------------------------------------------- + +function makeTranspiler(registry: any = {}) { + return new Transpiler({ registry }); +} + +function render(html: string, transpiler: Transpiler, entity: Record = {}) { + const container = document.createElement("div"); + transpiler.transpile( + (transpiler as any).templateParser.parse(html), + entity, + container + ); + return container; +} + +// --------------------------------------------------------------------------- + +describe("Error handling — global handler", () => { + it("is called with phase='render' when a render task throws", async () => { + const handler = vi.fn(); + setErrorHandler(handler); + + const instance = new Component() as any; + instance.onChanges = () => { throw new Error("render boom"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(handler).toHaveBeenCalledOnce(); + const [err, ctx] = handler.mock.calls[0]; + expect(err.message).toBe("render boom"); + expect(ctx.phase).toBe("render"); + expect(ctx.component).toBe(instance); + }); + + it("is called with phase='watcher' when a watch callback throws", async () => { + const handler = vi.fn(); + setErrorHandler(handler); + + const count = signal(0); + count.onChange(() => { throw new Error("watcher boom"); }); + + count.value = 1; + + expect(handler).toHaveBeenCalledOnce(); + const [err, ctx] = handler.mock.calls[0]; + expect(err.message).toBe("watcher boom"); + expect(ctx.phase).toBe("watcher"); + expect(ctx.component).toBeUndefined(); + }); + + it("receives the Error object even when a non-Error is thrown", async () => { + const handler = vi.fn(); + setErrorHandler(handler); + + const instance = new Component() as any; + instance.onChanges = () => { throw "string error"; }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + const [err] = handler.mock.calls[0]; + expect(err).toBeInstanceOf(Error); + expect(err.message).toBe("string error"); + }); + + it("falls back to console.error when no handler is registered", async () => { + const consoleSpy = vi.spyOn(console, "error").mockImplementation(() => {}); + + const instance = new Component() as any; + instance.onChanges = () => { throw new Error("unhandled"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(consoleSpy).toHaveBeenCalledOnce(); + expect(consoleSpy.mock.calls[0][0]).toContain("[Kasper]"); + }); + + it("is registered via App() onError config option", async () => { + const handler = vi.fn(); + const root = document.createElement("div"); + + class Broken extends Component { + static template = ""; + } + + App({ + root, + entry: "broken", + registry: { broken: { component: Broken as any } }, + onError: handler, + }); + + const instance = new Component() as any; + instance.onChanges = () => { throw new Error("app-level error"); }; + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(handler).toHaveBeenCalledOnce(); + expect(handler.mock.calls[0][0].message).toBe("app-level error"); + }); +}); + +// --------------------------------------------------------------------------- + +describe("Error handling — component onError hook", () => { + it("is called before the global handler", async () => { + const order: string[] = []; + setErrorHandler(() => order.push("global")); + + const instance = new Component() as any; + instance.onError = () => order.push("component"); + instance.onChanges = () => { throw new Error("boom"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(order).toEqual(["component"]); + }); + + it("suppresses the global handler when it handles the error normally", async () => { + const globalHandler = vi.fn(); + setErrorHandler(globalHandler); + + const instance = new Component() as any; + instance.onError = vi.fn(); // handles silently + instance.onChanges = () => { throw new Error("boom"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(instance.onError).toHaveBeenCalledOnce(); + expect(globalHandler).not.toHaveBeenCalled(); + }); + + it("reaches the global handler when component onError re-throws", async () => { + const globalHandler = vi.fn(); + setErrorHandler(globalHandler); + + const instance = new Component() as any; + instance.onError = (err: Error) => { throw err; }; + instance.onChanges = () => { throw new Error("rethrown"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(globalHandler).toHaveBeenCalledOnce(); + expect(globalHandler.mock.calls[0][0].message).toBe("rethrown"); + }); + + it("receives the correct error and phase", async () => { + const instance = new Component() as any; + const onError = vi.fn(); + instance.onError = onError; + instance.onChanges = () => { throw new Error("phase-check"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(onError).toHaveBeenCalledWith( + expect.objectContaining({ message: "phase-check" }), + "render" + ); + }); + + it("falls back to console.error when component onError itself throws and no global handler", async () => { + const consoleSpy = vi.spyOn(console, "error").mockImplementation(() => {}); + + const instance = new Component() as any; + instance.onError = () => { throw new Error("handler exploded"); }; + instance.onChanges = () => { throw new Error("original"); }; + + queueUpdate(instance, vi.fn()); + await nextTick(); + + expect(consoleSpy).toHaveBeenCalledOnce(); + }); +}); + +// --------------------------------------------------------------------------- + +describe("Error handling — reactive template errors", () => { + it("calls the global handler when a template expression throws during reactive update", async () => { + const handler = vi.fn(); + setErrorHandler(handler); + + class BrokenComp extends Component { + static template = "{{ data.value.name }}"; + data = signal({ name: "Alice" }); + } + + const transpiler = makeTranspiler({ "broken-comp": { component: BrokenComp } }); + const container = document.createElement("div"); + transpiler.transpile( + (transpiler as any).templateParser.parse(""), + {}, + container + ); + + const comp = (container.querySelector("broken-comp") as any)?.$kasperInstance as BrokenComp; + + // Setting data to null makes data.value.name throw on re-render + comp.data.value = null; + + expect(handler).toHaveBeenCalled(); + expect(handler.mock.calls[0][1].phase).toBe("render"); + }); + + it("component onError can set a fallback signal to show error UI", async () => { + class SafeComp extends Component { + static template = ` +
{{ data.value.name }}
+
Error occurred
+ `; + data = signal({ name: "Alice" }); + broken = signal(false); + + onError() { + this.broken.value = true; + } + } + + const transpiler = makeTranspiler({ "safe-comp": { component: SafeComp } }); + const container = document.createElement("div"); + transpiler.transpile( + (transpiler as any).templateParser.parse(""), + {}, + container + ); + + const comp = (container.querySelector("safe-comp") as any)?.$kasperInstance as SafeComp; + + expect(container.textContent).toContain("Alice"); + expect(container.querySelector(".fallback")).toBeNull(); + + // Trigger an error: set data to null so data.value.name throws + comp.data.value = null; + await nextTick(); + + expect(comp.broken.value).toBe(true); + expect(container.querySelector(".fallback")).not.toBeNull(); + }); +}); diff --git a/spec/error-system.spec.ts b/spec/error-system.spec.ts index 08a1784..597a852 100644 --- a/spec/error-system.spec.ts +++ b/spec/error-system.spec.ts @@ -1,8 +1,68 @@ import { describe, it, expect } from "vitest"; import { App, Component } from "../src/index"; +import { Scanner } from "../src/scanner"; +import { ExpressionParser } from "../src/expression-parser"; import { TemplateParser } from "../src/template-parser"; import { Transpiler } from "../src/transpiler"; +describe("Error message format", () => { + function catchError(fn: () => void): Error { + try { fn(); } catch (e: any) { return e; } + throw new Error("expected an error to be thrown"); + } + + it("scanner: error message contains the source line in the snippet", () => { + const err = catchError(() => new Scanner().scan("let x = @;")); + expect(err.message).toMatchInlineSnapshot(` + "[K002-3] Unexpected character '@' + > | let x = @; + ^ + + See: https://kasperjs.top/reference/errors#k002-3 + " + `); + }); + + it("expression parser: error message contains the source expression in the snippet", () => { + const source = "foo.bar("; + const err = catchError(() => + new ExpressionParser().parse(new Scanner().scan(source), source) + ); + expect(err.message).toMatchInlineSnapshot(` + "[K004-3] Expected expression, unexpected token "" + > | foo.bar( + + See: https://kasperjs.top/reference/errors#k004-3 + " + `); + }); + + it("template parser: error message contains the source markup in the snippet", () => { + const err = catchError(() => new TemplateParser().parse("
\n \n
")); + expect(err.message).toMatchInlineSnapshot(` + "[K003-5] Expected + |
+ > | + |
+ + See: https://kasperjs.top/reference/errors#k003-5 + " + `); + }); + + it("transpiler: error message contains the error code and message, no snippet", () => { + const nodes = new TemplateParser().parse('
'); + const err = catchError(() => new Transpiler().transpile(nodes, {}, document.createElement("div"))); + expect(err.message).toMatchInlineSnapshot(` + "[K003-7] @else must be preceded by an @if or @elseif block. + at
+ + See: https://kasperjs.top/reference/errors#k003-7 + " + `); + }); +}); + describe("Error System (New Checks)", () => { it("K001-2: throws if entry component is missing from registry", () => { const root = document.createElement("div"); @@ -19,7 +79,7 @@ describe("Error System (New Checks)", () => { const parser = new TemplateParser(); const transpiler = new Transpiler(); const container = document.createElement("div"); - + const nodes = parser.parse(''); expect(() => { transpiler.transpile(nodes, {}, container); @@ -30,7 +90,7 @@ describe("Error System (New Checks)", () => { const parser = new TemplateParser(); const transpiler = new Transpiler(); const container = document.createElement("div"); - + const nodes = parser.parse(''); expect(() => { transpiler.transpile(nodes, {}, container); @@ -42,7 +102,7 @@ describe("Error System (New Checks)", () => { const parser = new TemplateParser(); const transpiler = new Transpiler(); const container = document.createElement("div"); - + const nodes = parser.parse('
'); expect(() => { transpiler.transpile(nodes, {}, container); @@ -88,7 +148,7 @@ describe("Error System (New Checks)", () => { const parser = new TemplateParser(); const transpiler = new Transpiler(); const container = document.createElement("div"); - + const nodes = parser.parse('
'); expect(() => { transpiler.transpile(nodes, {}, container); diff --git a/spec/scanner.spec.ts b/spec/scanner.spec.ts index 311adfc..59b12da 100644 --- a/spec/scanner.spec.ts +++ b/spec/scanner.spec.ts @@ -294,8 +294,8 @@ describe("Scanner", () => { expect(() => new Scanner().scan("@")).toThrow("Unexpected character"); }); - it("error message includes line and column", () => { - expect(() => new Scanner().scan("@")).toThrow(/\(\d+:\d+\)/); + it("error message includes a code snippet", () => { + expect(() => new Scanner().scan("@")).toThrow(/>\s+\|/); }); }); diff --git a/spec/scheduler.spec.ts b/spec/scheduler.spec.ts index 77433d3..31818b2 100644 --- a/spec/scheduler.spec.ts +++ b/spec/scheduler.spec.ts @@ -89,7 +89,7 @@ describe("Scheduler", () => { queueUpdate(instance, task); await nextTick(); - expect(consoleSpy).toHaveBeenCalledWith(expect.stringContaining("Error during component update:"), expect.any(Error)); + expect(consoleSpy).toHaveBeenCalledWith(expect.stringContaining("[Kasper] Error during render:"), expect.any(Error)); // Even if hook fails, the scheduler should continue (though current implementation might skip tasks for that component) // Actually, my current flush handles each component in a try-catch. diff --git a/spec/template-parser.spec.ts b/spec/template-parser.spec.ts index 421a897..26527b3 100644 --- a/spec/template-parser.spec.ts +++ b/spec/template-parser.spec.ts @@ -331,8 +331,8 @@ describe("TemplateParser", () => { expect(() => new TemplateParser().parse("
")).toThrow(); }); - it("thrown error message includes line and column info", () => { - expect(() => new TemplateParser().parse("
")).toThrow(/\(\d+:\d+\)/); + it("thrown error message includes a code snippet", () => { + expect(() => new TemplateParser().parse("
")).toThrow(/>\s+\|/); }); }); }); diff --git a/spec/types.spec.ts b/spec/types.spec.ts index 2a99842..2b8a552 100644 --- a/spec/types.spec.ts +++ b/spec/types.spec.ts @@ -17,20 +17,19 @@ describe("KasperError", () => { }); it("message includes code and value", () => { - const err = new KasperError("K000" as any, "something failed", 3, 5); - expect(err.message).toContain("[K000] something failed (3:5)"); + const err = new KasperError("K000" as any, "something failed"); + expect(err.message).toContain("[K000] something failed"); expect(err.message).toContain("See: https://kasperjs.top/reference/errors#k000"); }); it("exposes line and col", () => { - const err = new KasperError("K000" as any, "something failed", 3, 5); + const err = new KasperError("K000" as any, "something failed", { line: 3, col: 5 }); expect(err.line).toBe(3); expect(err.col).toBe(5); }); - it("has a stack trace", () => { - expect(new KasperError("K000" as any, "something failed", 3, 5).stack).toBeDefined(); + expect(new KasperError("K000" as any, "something failed").stack).toBeDefined(); }); }); diff --git a/src/component.ts b/src/component.ts index 8e81f50..f1f42a4 100644 --- a/src/component.ts +++ b/src/component.ts @@ -62,6 +62,7 @@ export class Component = Record> onRender() { } onChanges() { } onDestroy() { } + onError?(error: Error, phase: string): void; render() { this.$render?.(); diff --git a/src/error-handler.ts b/src/error-handler.ts new file mode 100644 index 0000000..5e4bfde --- /dev/null +++ b/src/error-handler.ts @@ -0,0 +1,37 @@ +export type ErrorPhase = 'render' | 'watcher'; + +export type ErrorHandlerFn = ( + error: Error, + context: { component?: any; phase: ErrorPhase } +) => void; + +let globalHandler: ErrorHandlerFn | null = null; + +export function setErrorHandler(handler: ErrorHandlerFn | undefined): void { + globalHandler = handler ?? null; +} + +export function handleError(error: unknown, phase: ErrorPhase, component?: any): void { + const err = error instanceof Error ? error : new Error(String(error)); + + // Try component-level onError first + if (component && typeof component.onError === 'function') { + try { + component.onError(err, phase); + return; + } catch (e) { + // onError itself threw — fall through with original error + } + } + + // Try global handler + if (globalHandler) { + try { + globalHandler(err, { component, phase }); + return; + } catch (_) {} + } + + // Final fallback + console.error(`[Kasper] Error during ${phase}:`, err); +} diff --git a/src/expression-parser.ts b/src/expression-parser.ts index 75dad5a..5196535 100644 --- a/src/expression-parser.ts +++ b/src/expression-parser.ts @@ -5,10 +5,12 @@ import { Token, TokenType } from "./types/token"; export class ExpressionParser { private current: number; private tokens: Token[]; + private source: string; - public parse(tokens: Token[]): Expr.Expr[] { + public parse(tokens: Token[], source = ""): Expr.Expr[] { this.current = 0; this.tokens = tokens; + this.source = source; const expressions: Expr.Expr[] = []; while (!this.eof()) { expressions.push(this.expression()); @@ -62,7 +64,7 @@ export class ExpressionParser { } private error(code: KErrorCodeType, token: Token, args: any = {}): any { - throw new KasperError(code, args, token.line, token.col); + throw new KasperError(code, args, { line: token.line, col: token.col, source: this.source }); } private synchronize(): void { diff --git a/src/index.ts b/src/index.ts index fa351e0..76b02cf 100644 --- a/src/index.ts +++ b/src/index.ts @@ -11,3 +11,4 @@ import { nextTick } from "./scheduler"; export { ExpressionParser, Interpreter, Scanner, TemplateParser, Transpiler, signal, effect, computed, batch, watch, nextTick }; export { execute, transpile, bootstrap as App, lazy, Component, navigate, Router }; +export type { ErrorHandlerFn } from "./error-handler"; diff --git a/src/interpreter.ts b/src/interpreter.ts index c8ae276..43f4084 100644 --- a/src/interpreter.ts +++ b/src/interpreter.ts @@ -54,7 +54,7 @@ export class Interpreter implements Expr.ExprVisitor { } public error(code: KErrorCodeType, args: any = {}, line?: number, col?: number): void { - throw new KasperError(code, args, line, col); + throw new KasperError(code, args, { line, col }); } public visitVariableExpr(expr: Expr.Variable): any { @@ -127,7 +127,7 @@ export class Interpreter implements Expr.ExprVisitor { private templateParse(source: string): string { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); let result = ""; for (const expression of expressions) { result += this.evaluate(expression).toString(); diff --git a/src/kasper.ts b/src/kasper.ts index b5556c9..fff12bc 100644 --- a/src/kasper.ts +++ b/src/kasper.ts @@ -2,6 +2,7 @@ import { ComponentClass, ComponentRegistry } from "./component"; import { TemplateParser } from "./template-parser"; import { Transpiler } from "./transpiler"; import { KasperError, KErrorCode } from "./types/error"; +import { setErrorHandler, ErrorHandlerFn } from "./error-handler"; export function lazy( importer: () => Promise> @@ -40,6 +41,7 @@ export interface KasperConfig { entry?: string; registry: ComponentRegistry; mode?: "development" | "production"; + onError?: ErrorHandlerFn; } function createComponent(transpiler: Transpiler, tag: string) { @@ -78,6 +80,10 @@ export function bootstrap(config: KasperConfig) { ); } + if (config.onError) { + setErrorHandler(config.onError); + } + const transpiler = new Transpiler({ registry: config.registry }); if (config.mode) { diff --git a/src/scanner.ts b/src/scanner.ts index 96e2d87..a69d453 100644 --- a/src/scanner.ts +++ b/src/scanner.ts @@ -347,6 +347,6 @@ export class Scanner { } private error(code: KErrorCodeType, args: any = {}): void { - throw new KasperError(code, args, this.line, this.col); + throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source }); } } diff --git a/src/scheduler.ts b/src/scheduler.ts index 8cd7424..40b1c52 100644 --- a/src/scheduler.ts +++ b/src/scheduler.ts @@ -1,4 +1,5 @@ import { Component } from "./component"; +import { handleError } from "./error-handler"; type Task = () => void; @@ -28,7 +29,7 @@ function flush() { instance.onRender(); } } catch (e) { - console.error("[Kasper] Error during component update:", e); + handleError(e, 'render', instance); } } queue.clear(); @@ -39,7 +40,7 @@ function flush() { try { cb(); } catch (e) { - console.error("[Kasper] Error in nextTick callback:", e); + handleError(e, 'render'); } } } @@ -67,6 +68,10 @@ export function queueUpdate(instance: Component, task: Task) { * Executes a function with batching disabled. * Used for initial mount and manual renders. */ +export function isBatching(): boolean { + return batchingEnabled; +} + export function flushSync(fn: () => void) { const prev = batchingEnabled; batchingEnabled = false; diff --git a/src/signal.ts b/src/signal.ts index a87222d..5e0290c 100644 --- a/src/signal.ts +++ b/src/signal.ts @@ -2,6 +2,8 @@ import { KasperError, KErrorCode } from "./types/error"; type Listener = () => void; +import { handleError } from "./error-handler"; + let activeEffect: { fn: Listener; deps: Set } | null = null; const effectStack: any[] = []; @@ -45,7 +47,7 @@ export class Signal { sub(); } for (const watcher of this.watchers) { - try { watcher(newValue, oldValue); } catch (e) { console.error("Watcher error:", e); } + try { watcher(newValue, oldValue); } catch (e) { handleError(e, 'watcher'); } } } } @@ -162,7 +164,7 @@ export function batch(fn: () => void): void { sub(); } for (const watcher of watchers) { - try { watcher(); } catch (e) { console.error("Watcher error:", e); } + try { watcher(); } catch (e) { handleError(e, 'watcher'); } } } } diff --git a/src/template-parser.ts b/src/template-parser.ts index 992be91..d83299c 100644 --- a/src/template-parser.ts +++ b/src/template-parser.ts @@ -69,7 +69,7 @@ export class TemplateParser { } private error(code: KErrorCodeType, args: any = {}): any { - throw new KasperError(code, args, this.line, this.col); + throw new KasperError(code, args, { line: this.line, col: this.col, source: this.source }); } private node(): Node.KNode { diff --git a/src/transpiler.ts b/src/transpiler.ts index 5de7b8d..0b1ec20 100644 --- a/src/transpiler.ts +++ b/src/transpiler.ts @@ -9,6 +9,8 @@ import { Boundary } from "./boundary"; import { TemplateParser } from "./template-parser"; import { queueUpdate, flushSync } from "./scheduler"; import { KasperError, KErrorCode, KErrorCodeType } from "./types/error"; +import { handleError } from "./error-handler"; +import { isBatching } from "./scheduler"; import * as KNode from "./types/nodes"; const KEY_MAP: Record = { @@ -144,6 +146,15 @@ export class Transpiler implements KNode.KNodeVisitor { this.interpreter.scope = scope; try { fn(); + } catch (e) { + // Only route to error handler during reactive re-runs (batching enabled). + // During initial mount (flushSync / batching disabled) errors propagate normally. + if (isBatching()) { + const instance = this.interpreter.scope.get("$instance"); + handleError(e, "render", instance); + } else { + throw e; + } } finally { this.interpreter.scope = prev; } @@ -168,7 +179,7 @@ export class Transpiler implements KNode.KNodeVisitor { // evaluates expressions and returns the result of the first evaluation private execute(source: string, overrideScope?: Scope): any { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); const restoreScope = this.interpreter.scope; if (overrideScope) { @@ -896,7 +907,7 @@ export class Transpiler implements KNode.KNodeVisitor { private evaluateExpression(source: string): string { const tokens = this.scanner.scan(source); - const expressions = this.parser.parse(tokens); + const expressions = this.parser.parse(tokens, source); let result = ""; for (const expression of expressions) { @@ -1049,7 +1060,7 @@ export class Transpiler implements KNode.KNodeVisitor { finalArgs = { message: cleanMessage }; } - throw new KasperError(code, finalArgs, undefined, undefined, tagName); + throw new KasperError(code, finalArgs, { tag: tagName }); } } diff --git a/src/types/error.ts b/src/types/error.ts index cfd063f..a2e6800 100644 --- a/src/types/error.ts +++ b/src/types/error.ts @@ -46,7 +46,7 @@ export type KErrorCodeType = (typeof KErrorCode)[keyof typeof KErrorCode]; export const ErrorTemplates: Record string> = { "K001-1": (a) => `Root element not found: ${a.root}`, "K001-2": (a) => `Entry component <${a.tag}> not found in registry.`, - + "K002-1": () => 'Unterminated comment, expecting closing "*/"', "K002-2": (a) => `Unterminated string, expecting closing ${a.quote}`, "K002-3": (a) => `Unexpected character '${a.char}'`, @@ -79,14 +79,44 @@ export const ErrorTemplates: Record string> = { "K007-2": (a) => a.message, }; +function codeSnippet(source: string, line: number, col: number, context = 2): string { + const lines = source.split("\n"); + const errorLine = line - 1; // 0-indexed + const start = Math.max(0, errorLine - context); + const end = Math.min(lines.length - 1, errorLine + context); + + const result: string[] = [""]; + for (let i = start; i <= end; i++) { + const indicator = i === errorLine ? ">" : " "; + result.push(` ${indicator} | ${lines[i]}`); + if (i === errorLine && col > 0) { + // prefix: " > | " (6) + (col - 1) spaces + const pointer = " ".repeat(6 + col - 1) + "^"; + result.push(pointer); + } + } + return result.join("\n"); +} + +export interface KasperErrorOptions { + line?: number; + col?: number; + tag?: string; + source?: string; +} + export class KasperError extends Error { + public line?: number; + public col?: number; + public tagName?: string; + constructor( public code: KErrorCodeType, public args: any = {}, - public line?: number, - public col?: number, - public tagName?: string + options: KasperErrorOptions = {} ) { + const { line, col, tag, source } = options; + // Detect environment const isDev = typeof process !== "undefined" @@ -94,18 +124,21 @@ export class KasperError extends Error { : (import.meta as any).env?.MODE !== "production"; const template = ErrorTemplates[code]; - const message = template - ? template(args) + const message = template + ? template(args) : (typeof args === 'string' ? args : "Unknown error"); - - const location = line !== undefined ? ` (${line}:${col})` : ""; - const tagInfo = tagName ? `\n at <${tagName}>` : ""; + + const tagInfo = tag ? `\n at <${tag}>` : ""; + const snippet = line !== undefined && source ? codeSnippet(source, line, col ?? 0) : ""; const link = isDev - ? `\n\nSee: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(".", "")}` + ? `\n\nSee: https://kasperjs.top/reference/errors#${code.toLowerCase().replace(".", "")}\n` : ""; - super(`[${code}] ${message}${location}${tagInfo}${link}`); + super(`[${code}] ${message}${tagInfo}${snippet}${link}`); this.name = "KasperError"; + this.line = line; + this.col = col; + this.tagName = tag; } public withTag(tagName: string): this {