@idlesummer/pen 0.2.2 → 0.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/bin.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  #!/usr/bin/env node
2
- import{a as e,f as t,i as n,n as r,r as i,t as a}from"./serialized-routes-DFDKf4sB.mjs";import{join as o,resolve as s}from"path";import{pathToFileURL as c}from"url";import{existsSync as l}from"fs";import{Command as u}from"commander";import{duration as d,fileList as f,pipe as p}from"@idlesummer/tasker";import{mkdir as m,writeFile as h}from"fs/promises";import{build as g}from"rolldown";import _ from"rollup-plugin-node-externals";var v=Object.create,y=Object.defineProperty,b=Object.getOwnPropertyDescriptor,x=Object.getOwnPropertyNames,S=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty,w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),T=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=x(t),a=0,o=i.length,s;a<o;a++)s=i[a],!C.call(e,s)&&s!==n&&y(e,s,{get:(e=>t[e]).bind(null,s),enumerable:!(r=b(t,s))||r.enumerable});return e},E=(e,t,n)=>(n=e==null?{}:v(S(e)),T(t||!e||!e.__esModule?y(n,`default`,{value:e,enumerable:!0}):n,e));const D=`@idlesummer/pen`,O=`0.2.2`,k=`@idlesummer/pen`.split(`/`)?.[1]??`@idlesummer/pen`;var A=E(w(((e,t)=>{let n=process||{},r=n.argv||[],i=n.env||{},a=!(i.NO_COLOR||r.includes(`--no-color`))&&(!!i.FORCE_COLOR||r.includes(`--color`)||n.platform===`win32`||(n.stdout||{}).isTTY&&i.TERM!==`dumb`||!!i.CI),o=(e,t,n=e)=>r=>{let i=``+r,a=i.indexOf(t,e.length);return~a?e+s(i,t,n,a)+t:e+i+t},s=(e,t,n,r)=>{let i=``,a=0;do i+=e.substring(a,r)+n,a=r+t.length,r=e.indexOf(t,a);while(~r);return i+e.substring(a)},c=(e=a)=>{let t=e?o:()=>String;return{isColorSupported:e,reset:t(`\x1B[0m`,`\x1B[0m`),bold:t(`\x1B[1m`,`\x1B[22m`,`\x1B[22m\x1B[1m`),dim:t(`\x1B[2m`,`\x1B[22m`,`\x1B[22m\x1B[2m`),italic:t(`\x1B[3m`,`\x1B[23m`),underline:t(`\x1B[4m`,`\x1B[24m`),inverse:t(`\x1B[7m`,`\x1B[27m`),hidden:t(`\x1B[8m`,`\x1B[28m`),strikethrough:t(`\x1B[9m`,`\x1B[29m`),black:t(`\x1B[30m`,`\x1B[39m`),red:t(`\x1B[31m`,`\x1B[39m`),green:t(`\x1B[32m`,`\x1B[39m`),yellow:t(`\x1B[33m`,`\x1B[39m`),blue:t(`\x1B[34m`,`\x1B[39m`),magenta:t(`\x1B[35m`,`\x1B[39m`),cyan:t(`\x1B[36m`,`\x1B[39m`),white:t(`\x1B[37m`,`\x1B[39m`),gray:t(`\x1B[90m`,`\x1B[39m`),bgBlack:t(`\x1B[40m`,`\x1B[49m`),bgRed:t(`\x1B[41m`,`\x1B[49m`),bgGreen:t(`\x1B[42m`,`\x1B[49m`),bgYellow:t(`\x1B[43m`,`\x1B[49m`),bgBlue:t(`\x1B[44m`,`\x1B[49m`),bgMagenta:t(`\x1B[45m`,`\x1B[49m`),bgCyan:t(`\x1B[46m`,`\x1B[49m`),bgWhite:t(`\x1B[47m`,`\x1B[49m`),blackBright:t(`\x1B[90m`,`\x1B[39m`),redBright:t(`\x1B[91m`,`\x1B[39m`),greenBright:t(`\x1B[92m`,`\x1B[39m`),yellowBright:t(`\x1B[93m`,`\x1B[39m`),blueBright:t(`\x1B[94m`,`\x1B[39m`),magentaBright:t(`\x1B[95m`,`\x1B[39m`),cyanBright:t(`\x1B[96m`,`\x1B[39m`),whiteBright:t(`\x1B[97m`,`\x1B[39m`),bgBlackBright:t(`\x1B[100m`,`\x1B[49m`),bgRedBright:t(`\x1B[101m`,`\x1B[49m`),bgGreenBright:t(`\x1B[102m`,`\x1B[49m`),bgYellowBright:t(`\x1B[103m`,`\x1B[49m`),bgBlueBright:t(`\x1B[104m`,`\x1B[49m`),bgMagentaBright:t(`\x1B[105m`,`\x1B[49m`),bgCyanBright:t(`\x1B[106m`,`\x1B[49m`),bgWhiteBright:t(`\x1B[107m`,`\x1B[49m`)}};t.exports=c(),t.exports.createColors=c}))(),1);const j={name:`Building file tree`,onSuccess:(e,t)=>`Built file tree (${d(t)})`,run:async t=>({fileTree:e(t.appDir)})},M={name:`Building segment tree...`,onSuccess:(e,t)=>`Built segment tree (${d(t)})`,run:async e=>({segmentTree:n(e.fileTree)})},N={name:`Building route chain map`,onSuccess:(e,t)=>`Built route chain map (${d(t)})`,run:async e=>({routeChainMap:i(e.segmentTree,e.outDir)})},P={name:`Building component index map`,onSuccess:(e,t)=>`Built component map (${d(t)})`,run:async e=>({componentIdMap:r(e.routeChainMap)})},F=`route-chain-map.ts`,I={name:`Writing ${F}`,onSuccess:(e,t)=>`Saved ${F}} (${d(t)})`,run:async e=>{let t=o(e.outDir,`artifacts`),n=o(t,F),r=[`// Auto-generated by ${D}`,`// Do not manually edit this file`,`// NOTE: This file is kept for documentation/debugging.`,`// Runtime uses pre-built routes from routes.ts instead.`,``,`import type { RouteChainMap } from '${D}'`,``,`export const routes: RouteChainMap = ${JSON.stringify(e.routeChainMap,null,2)} as const`,``].join(`
3
- `);await m(t,{recursive:!0}),await h(n,r,`utf-8`)}},L={name:`Serializing routes`,onSuccess:(e,t)=>`Serialized routes (${d(t)})`,run:async e=>({serializedRoutes:a(e.routeChainMap,e.componentIdMap)})},R=`serialized-route-tree.ts`,z={name:`Writing ${R}`,onSuccess:(e,t)=>`Saved ${R} (${d(t)})`,run:async e=>{let t=o(e.outDir,`artifacts`),n=o(t,R),r=[`// Auto-generated by ${D}`,`// Do not manually edit this file`,`// NOTE: This file is kept for documentation/debugging.`,``,`import type { SerializedRouteTreeMap } from '${D}'`,``,`export const serializedRoutes: SerializedRouteTreeMap = ${JSON.stringify(e.serializedRoutes,null,2)} as const`,``].join(`
2
+ import{a as e,f as t,i as n,n as r,r as i,t as a}from"./serialized-routes-DFDKf4sB.mjs";import{join as o,resolve as s}from"path";import{pathToFileURL as c}from"url";import{existsSync as l}from"fs";import{Command as u}from"commander";import{duration as d,fileList as f,pipe as p}from"@idlesummer/tasker";import{mkdir as m,writeFile as h}from"fs/promises";import{build as g}from"rolldown";import _ from"rollup-plugin-node-externals";var v=Object.create,y=Object.defineProperty,b=Object.getOwnPropertyDescriptor,x=Object.getOwnPropertyNames,S=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty,w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),T=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=x(t),a=0,o=i.length,s;a<o;a++)s=i[a],!C.call(e,s)&&s!==n&&y(e,s,{get:(e=>t[e]).bind(null,s),enumerable:!(r=b(t,s))||r.enumerable});return e},E=(e,t,n)=>(n=e==null?{}:v(S(e)),T(t||!e||!e.__esModule?y(n,`default`,{value:e,enumerable:!0}):n,e));const D=`@idlesummer/pen`,O=`0.2.3`,k=`@idlesummer/pen`.split(`/`)?.[1]??`@idlesummer/pen`;var A=E(w(((e,t)=>{let n=process||{},r=n.argv||[],i=n.env||{},a=!(i.NO_COLOR||r.includes(`--no-color`))&&(!!i.FORCE_COLOR||r.includes(`--color`)||n.platform===`win32`||(n.stdout||{}).isTTY&&i.TERM!==`dumb`||!!i.CI),o=(e,t,n=e)=>r=>{let i=``+r,a=i.indexOf(t,e.length);return~a?e+s(i,t,n,a)+t:e+i+t},s=(e,t,n,r)=>{let i=``,a=0;do i+=e.substring(a,r)+n,a=r+t.length,r=e.indexOf(t,a);while(~r);return i+e.substring(a)},c=(e=a)=>{let t=e?o:()=>String;return{isColorSupported:e,reset:t(`\x1B[0m`,`\x1B[0m`),bold:t(`\x1B[1m`,`\x1B[22m`,`\x1B[22m\x1B[1m`),dim:t(`\x1B[2m`,`\x1B[22m`,`\x1B[22m\x1B[2m`),italic:t(`\x1B[3m`,`\x1B[23m`),underline:t(`\x1B[4m`,`\x1B[24m`),inverse:t(`\x1B[7m`,`\x1B[27m`),hidden:t(`\x1B[8m`,`\x1B[28m`),strikethrough:t(`\x1B[9m`,`\x1B[29m`),black:t(`\x1B[30m`,`\x1B[39m`),red:t(`\x1B[31m`,`\x1B[39m`),green:t(`\x1B[32m`,`\x1B[39m`),yellow:t(`\x1B[33m`,`\x1B[39m`),blue:t(`\x1B[34m`,`\x1B[39m`),magenta:t(`\x1B[35m`,`\x1B[39m`),cyan:t(`\x1B[36m`,`\x1B[39m`),white:t(`\x1B[37m`,`\x1B[39m`),gray:t(`\x1B[90m`,`\x1B[39m`),bgBlack:t(`\x1B[40m`,`\x1B[49m`),bgRed:t(`\x1B[41m`,`\x1B[49m`),bgGreen:t(`\x1B[42m`,`\x1B[49m`),bgYellow:t(`\x1B[43m`,`\x1B[49m`),bgBlue:t(`\x1B[44m`,`\x1B[49m`),bgMagenta:t(`\x1B[45m`,`\x1B[49m`),bgCyan:t(`\x1B[46m`,`\x1B[49m`),bgWhite:t(`\x1B[47m`,`\x1B[49m`),blackBright:t(`\x1B[90m`,`\x1B[39m`),redBright:t(`\x1B[91m`,`\x1B[39m`),greenBright:t(`\x1B[92m`,`\x1B[39m`),yellowBright:t(`\x1B[93m`,`\x1B[39m`),blueBright:t(`\x1B[94m`,`\x1B[39m`),magentaBright:t(`\x1B[95m`,`\x1B[39m`),cyanBright:t(`\x1B[96m`,`\x1B[39m`),whiteBright:t(`\x1B[97m`,`\x1B[39m`),bgBlackBright:t(`\x1B[100m`,`\x1B[49m`),bgRedBright:t(`\x1B[101m`,`\x1B[49m`),bgGreenBright:t(`\x1B[102m`,`\x1B[49m`),bgYellowBright:t(`\x1B[103m`,`\x1B[49m`),bgBlueBright:t(`\x1B[104m`,`\x1B[49m`),bgMagentaBright:t(`\x1B[105m`,`\x1B[49m`),bgCyanBright:t(`\x1B[106m`,`\x1B[49m`),bgWhiteBright:t(`\x1B[107m`,`\x1B[49m`)}};t.exports=c(),t.exports.createColors=c}))(),1);const j={name:`Building file tree`,onSuccess:(e,t)=>`Built file tree (${d(t)})`,run:async t=>({fileTree:e(t.appDir)})},M={name:`Building segment tree...`,onSuccess:(e,t)=>`Built segment tree (${d(t)})`,run:async e=>({segmentTree:n(e.fileTree)})},N={name:`Building route chain map`,onSuccess:(e,t)=>`Built route chain map (${d(t)})`,run:async e=>({routeChainMap:i(e.segmentTree,e.outDir)})},P={name:`Building component index map`,onSuccess:(e,t)=>`Built component map (${d(t)})`,run:async e=>({componentIdMap:r(e.routeChainMap)})},F=`route-chain-map.ts`,I={name:`Writing ${F}`,onSuccess:(e,t)=>`Saved ${F}} (${d(t)})`,run:async e=>{let t=o(e.outDir,`artifacts`),n=o(t,F),r=[`// Auto-generated by ${D}`,`// Do not manually edit this file`,`// NOTE: This file is kept for documentation/debugging.`,`// Runtime uses pre-built routes from routes.ts instead.`,``,`import type { RouteChainMap } from '${D}'`,``,`export const routes: RouteChainMap = ${JSON.stringify(e.routeChainMap,null,2)} as const`,``].join(`
3
+ `);await m(t,{recursive:!0}),await h(n,r,`utf-8`)}},L={name:`Serializing routes`,onSuccess:(e,t)=>`Serialized routes (${d(t)})`,run:async e=>({serializedRoutes:a(e.routeChainMap,e.componentIdMap)})},R=`serialized-routes.ts`,z={name:`Writing ${R}`,onSuccess:(e,t)=>`Saved ${R} (${d(t)})`,run:async e=>{let t=o(e.outDir,`artifacts`),n=o(t,R),r=[`// Auto-generated by ${D}`,`// Do not manually edit this file`,`// NOTE: This file is kept for documentation/debugging.`,``,`import type { SerializedRouteTreeMap } from '${D}'`,``,`export const serializedRoutes: SerializedRouteTreeMap = ${JSON.stringify(e.serializedRoutes,null,2)} as const`,``].join(`
4
4
  `);await m(t,{recursive:!0}),await h(n,r,`utf-8`)}},B=`component-id-map.ts`,V={name:`Writing ${B}`,onSuccess:(e,t)=>`Saved ${B} (${d(t)})`,run:async e=>{let t=o(e.outDir,`artifacts`),n=o(t,B),r=e.componentIdMap,i=[`// Auto-generated by ${D}`,`// Do not manually edit this file`,``,`import type { ComponentIdMap } from '${D}'`,``,`export const componentIdMap: ComponentIdMap = ${JSON.stringify(r,null,2)} as const`,``].join(`
5
5
  `);await m(t,{recursive:!0}),await h(n,i,`utf-8`)}},H=`compiled-routes.ts`,U={name:`Writing ${H}`,onSuccess:(e,t)=>`Saved ${H} (${d(t)})`,run:async e=>{let t=o(e.outDir,`generated`),n=o(t,H),r=e.serializedRoutes,i=e.componentIdMap,a=Object.keys(i).map((e,t)=>`import Component${t} from '${e}'`).join(`
6
6
  `),s=[];for(let[e,t]of Object.entries(r)){let n=` ${W(t).replace(/\n/g,`
package/dist/bin.mjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"bin.mjs","names":["filename","filename","filename","filename","rolldownBuild","build","pc","pc","pc","run","build"],"sources":["../src/pen/constants.ts","../node_modules/picocolors/picocolors.js","../src/cli/commands/build/tasks/build-file-tree.ts","../src/cli/commands/build/tasks/build-segment-tree.ts","../src/cli/commands/build/tasks/build-route-chain-map.ts","../src/cli/commands/build/tasks/build-component-id-map.ts","../src/cli/commands/build/tasks/write-route-chain-map-file.ts","../src/cli/commands/build/tasks/build-serialized-routes.ts","../src/cli/commands/build/tasks/write-serialized-routes-file.ts","../src/cli/commands/build/tasks/write-component-id-map-file.ts","../src/cli/commands/build/tasks/write-compiled-routes-file.ts","../src/cli/commands/build/tasks/write-entry-file.ts","../src/cli/commands/build/tasks/compile-application.ts","../src/cli/commands/build/index.ts","../src/cli/commands/init/index.ts","../src/cli/commands/start/index.ts","../src/cli/index.ts","../src/bin.ts"],"sourcesContent":["// Build-time globals injected by tsdown via `define`.\r\n// tsdown replaces these placeholders with actual values\r\n// from package.json at compile time.\r\n\r\ndeclare const __DESCRIPTION__: string\r\ndeclare const __PACKAGE_NAME__: string\r\ndeclare const __VERSION__: string\r\n\r\n// Package metadata\r\nexport const DESCRIPTION = __DESCRIPTION__\r\nexport const PACKAGE_NAME = __PACKAGE_NAME__\r\nexport const VERSION = __VERSION__\r\n\r\n// Framework metadata\r\nexport const CLI_NAME = __PACKAGE_NAME__.split('/')?.[1] ?? __PACKAGE_NAME__\r\n","let p = process || {}, argv = p.argv || [], env = p.env || {}\nlet isColorSupported =\n\t!(!!env.NO_COLOR || argv.includes(\"--no-color\")) &&\n\t(!!env.FORCE_COLOR || argv.includes(\"--color\") || p.platform === \"win32\" || ((p.stdout || {}).isTTY && env.TERM !== \"dumb\") || !!env.CI)\n\nlet formatter = (open, close, replace = open) =>\n\tinput => {\n\t\tlet string = \"\" + input, index = string.indexOf(close, open.length)\n\t\treturn ~index ? open + replaceClose(string, close, replace, index) + close : open + string + close\n\t}\n\nlet replaceClose = (string, close, replace, index) => {\n\tlet result = \"\", cursor = 0\n\tdo {\n\t\tresult += string.substring(cursor, index) + replace\n\t\tcursor = index + close.length\n\t\tindex = string.indexOf(close, cursor)\n\t} while (~index)\n\treturn result + string.substring(cursor)\n}\n\nlet createColors = (enabled = isColorSupported) => {\n\tlet f = enabled ? formatter : () => String\n\treturn {\n\t\tisColorSupported: enabled,\n\t\treset: f(\"\\x1b[0m\", \"\\x1b[0m\"),\n\t\tbold: f(\"\\x1b[1m\", \"\\x1b[22m\", \"\\x1b[22m\\x1b[1m\"),\n\t\tdim: f(\"\\x1b[2m\", \"\\x1b[22m\", \"\\x1b[22m\\x1b[2m\"),\n\t\titalic: f(\"\\x1b[3m\", \"\\x1b[23m\"),\n\t\tunderline: f(\"\\x1b[4m\", \"\\x1b[24m\"),\n\t\tinverse: f(\"\\x1b[7m\", \"\\x1b[27m\"),\n\t\thidden: f(\"\\x1b[8m\", \"\\x1b[28m\"),\n\t\tstrikethrough: f(\"\\x1b[9m\", \"\\x1b[29m\"),\n\n\t\tblack: f(\"\\x1b[30m\", \"\\x1b[39m\"),\n\t\tred: f(\"\\x1b[31m\", \"\\x1b[39m\"),\n\t\tgreen: f(\"\\x1b[32m\", \"\\x1b[39m\"),\n\t\tyellow: f(\"\\x1b[33m\", \"\\x1b[39m\"),\n\t\tblue: f(\"\\x1b[34m\", \"\\x1b[39m\"),\n\t\tmagenta: f(\"\\x1b[35m\", \"\\x1b[39m\"),\n\t\tcyan: f(\"\\x1b[36m\", \"\\x1b[39m\"),\n\t\twhite: f(\"\\x1b[37m\", \"\\x1b[39m\"),\n\t\tgray: f(\"\\x1b[90m\", \"\\x1b[39m\"),\n\n\t\tbgBlack: f(\"\\x1b[40m\", \"\\x1b[49m\"),\n\t\tbgRed: f(\"\\x1b[41m\", \"\\x1b[49m\"),\n\t\tbgGreen: f(\"\\x1b[42m\", \"\\x1b[49m\"),\n\t\tbgYellow: f(\"\\x1b[43m\", \"\\x1b[49m\"),\n\t\tbgBlue: f(\"\\x1b[44m\", \"\\x1b[49m\"),\n\t\tbgMagenta: f(\"\\x1b[45m\", \"\\x1b[49m\"),\n\t\tbgCyan: f(\"\\x1b[46m\", \"\\x1b[49m\"),\n\t\tbgWhite: f(\"\\x1b[47m\", \"\\x1b[49m\"),\n\n\t\tblackBright: f(\"\\x1b[90m\", \"\\x1b[39m\"),\n\t\tredBright: f(\"\\x1b[91m\", \"\\x1b[39m\"),\n\t\tgreenBright: f(\"\\x1b[92m\", \"\\x1b[39m\"),\n\t\tyellowBright: f(\"\\x1b[93m\", \"\\x1b[39m\"),\n\t\tblueBright: f(\"\\x1b[94m\", \"\\x1b[39m\"),\n\t\tmagentaBright: f(\"\\x1b[95m\", \"\\x1b[39m\"),\n\t\tcyanBright: f(\"\\x1b[96m\", \"\\x1b[39m\"),\n\t\twhiteBright: f(\"\\x1b[97m\", \"\\x1b[39m\"),\n\n\t\tbgBlackBright: f(\"\\x1b[100m\", \"\\x1b[49m\"),\n\t\tbgRedBright: f(\"\\x1b[101m\", \"\\x1b[49m\"),\n\t\tbgGreenBright: f(\"\\x1b[102m\", \"\\x1b[49m\"),\n\t\tbgYellowBright: f(\"\\x1b[103m\", \"\\x1b[49m\"),\n\t\tbgBlueBright: f(\"\\x1b[104m\", \"\\x1b[49m\"),\n\t\tbgMagentaBright: f(\"\\x1b[105m\", \"\\x1b[49m\"),\n\t\tbgCyanBright: f(\"\\x1b[106m\", \"\\x1b[49m\"),\n\t\tbgWhiteBright: f(\"\\x1b[107m\", \"\\x1b[49m\"),\n\t}\n}\n\nmodule.exports = createColors()\nmodule.exports.createColors = createColors\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createFileTree } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildFileTree: Task<BuildContext> = {\r\n name: 'Building file tree',\r\n onSuccess: (_, dur) => `Built file tree (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n fileTree: createFileTree(ctx.appDir),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createSegmentTree } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildSegmentTree: Task<BuildContext> = {\r\n name: 'Building segment tree...',\r\n onSuccess: (_, dur) => `Built segment tree (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n segmentTree: createSegmentTree(ctx.fileTree!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createRouteChainMap } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildRouteChainMap: Task<BuildContext> = {\r\n name: 'Building route chain map',\r\n onSuccess: (_, dur) => `Built route chain map (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n routeChainMap: createRouteChainMap(ctx.segmentTree!, ctx.outDir),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createComponentIdMap } from '@/pen/compiler'\r\n\r\nexport const buildComponentIdMap: Task<BuildContext> = {\r\n name: 'Building component index map',\r\n onSuccess: (_, dur) => `Built component map (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n componentIdMap: createComponentIdMap(ctx.routeChainMap!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'route-chain-map.ts'\r\n\r\nexport const writeRouteMapFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename}} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '// NOTE: This file is kept for documentation/debugging.',\r\n '// Runtime uses pre-built routes from routes.ts instead.',\r\n '',\r\n `import type { RouteChainMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const routes: RouteChainMap = ${JSON.stringify(ctx.routeChainMap!, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createSerializedRoutes } from '@/pen/compiler'\r\n\r\nexport const buildSerializedRoutes: Task<BuildContext> = {\r\n name: 'Serializing routes',\r\n onSuccess: (_, dur) => `Serialized routes (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n serializedRoutes: createSerializedRoutes(ctx.routeChainMap!, ctx.componentIdMap!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'serialized-route-tree.ts'\r\n\r\nexport const writeSerializedTreeFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '// NOTE: This file is kept for documentation/debugging.',\r\n '',\r\n `import type { SerializedRouteTreeMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const serializedRoutes: SerializedRouteTreeMap = ${JSON.stringify(ctx.serializedRoutes!, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'component-id-map.ts'\r\n\r\nexport const writeComponentIdMapFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n\r\n const componentIdMap = ctx.componentIdMap!\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n `import type { ComponentIdMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const componentIdMap: ComponentIdMap = ${JSON.stringify(componentIdMap, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { SerializedTree } from '@/pen/compiler'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'compiled-routes.ts'\r\n\r\nexport const writeCompiledRoutesFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'generated')\r\n const outDir = join(genDir, filename)\r\n const serializedRoutes = ctx.serializedRoutes!\r\n const componentIdMap = ctx.componentIdMap!\r\n\r\n // Get sorted imports from component map\r\n const sortedImports = Object.keys(componentIdMap)\r\n\r\n // Generate component imports\r\n const importStatements = sortedImports\r\n .map((importPath, i) => `import Component${i} from '${importPath}'`)\r\n .join('\\n')\r\n\r\n // Generate pre-built route components from element trees\r\n const routeEntries: string[] = []\r\n for (const [url, tree] of Object.entries(serializedRoutes)) {\r\n const elementCode = ` ${serialize(tree).replace(/\\n/g, '\\n ')}`\r\n routeEntries.push(` '${url}':\\n${elementCode},`)\r\n }\r\n\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n `import type { CompiledRoutes } from '${PACKAGE_NAME}'`,\r\n 'import { createElement } from \\'react\\'',\r\n '',\r\n importStatements,\r\n '',\r\n '// Compiled route elements generated at build time',\r\n 'export const compiledRoutes: CompiledRoutes = {',\r\n routeEntries.join('\\n'),\r\n '} as const',\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n\r\n/** Serializes an SerializedTree to React.createElement() code string. */\r\nexport function serialize(tree: SerializedTree, indent = 0): string {\r\n const spaces = ' '.repeat(indent)\r\n\r\n // Props are already pre-serialized (strings have quotes, identifiers don't)\r\n const props = Object.entries(tree.props)\r\n .map(([key, value]) => `${key}: ${value}`)\r\n .join(', ')\r\n\r\n if (!tree.children)\r\n return `createElement(${tree.component}, { ${props} })`\r\n\r\n const childCode = serialize(tree.children, indent + 1)\r\n return `createElement(${tree.component}, { ${props} },\\n${spaces} ${childCode}\\n${spaces})`\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'entry.ts'\r\n\r\nexport const writeEntryFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'generated')\r\n const outDir = join(genDir, filename)\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n 'import { createElement } from \\'react\\'',\r\n 'import { render } from \\'ink\\'',\r\n `import { App } from '${PACKAGE_NAME}'`,\r\n 'import { compiledRoutes as routes } from \\'./compiled-routes\\'',\r\n '',\r\n 'export async function run(initialUrl: string) {',\r\n ' const element = createElement(App, { initialUrl, routes })',\r\n ' const { waitUntilExit } = render(element)',\r\n ' await waitUntilExit()',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import { join, resolve } from 'path'\r\nimport { build as rolldownBuild } from 'rolldown'\r\nimport nodeExternals from 'rollup-plugin-node-externals'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\n\r\nexport const compileApplication: Task<BuildContext> = {\r\n name: 'Compiling application',\r\n onSuccess: (_, dur) => `Compiled application (${duration(dur)})`,\r\n onError: (err) => `Compilation failed: ${err.message}`,\r\n run: async (ctx) => {\r\n await rolldownBuild({\r\n input: resolve(join(ctx.outDir, 'generated', 'entry.ts')), // entry point\r\n platform: 'node',\r\n resolve: {\r\n extensions: ['.ts', '.tsx', '.js', '.jsx'],\r\n },\r\n plugins: [nodeExternals()],\r\n output: {\r\n dir: resolve(join(ctx.outDir, 'dist')),\r\n format: 'esm',\r\n sourcemap: true,\r\n minify: true,\r\n },\r\n })\r\n },\r\n}\r\n","import type { CLICommand } from '../../types'\r\nimport pc from 'picocolors'\r\nimport { pipe, duration, fileList } from '@idlesummer/tasker'\r\nimport { loadConfig } from '@/pen/config'\r\nimport { CLI_NAME, VERSION } from '@/pen/constants'\r\n\r\n// Import individual tasks\r\nimport { buildFileTree } from './tasks/build-file-tree'\r\nimport { buildSegmentTree } from './tasks/build-segment-tree'\r\nimport { buildRouteChainMap } from './tasks/build-route-chain-map'\r\nimport { buildComponentIdMap } from './tasks/build-component-id-map'\r\nimport { writeRouteMapFile } from './tasks/write-route-chain-map-file'\r\nimport { buildSerializedRoutes } from './tasks/build-serialized-routes'\r\nimport { writeSerializedTreeFile } from './tasks/write-serialized-routes-file'\r\nimport { writeComponentIdMapFile } from './tasks/write-component-id-map-file'\r\nimport { writeCompiledRoutesFile } from './tasks/write-compiled-routes-file'\r\nimport { writeEntryFile } from './tasks/write-entry-file'\r\nimport { compileApplication } from './tasks/compile-application'\r\n\r\nexport const build: CLICommand = {\r\n name: 'build',\r\n desc: 'Build the routing structure and compile application',\r\n action: async () => {\r\n try {\r\n const { appDir, outDir, emitMetadata } = await loadConfig()\r\n console.log(pc.cyan(' Starting production build...\\n'))\r\n console.log(pc.bold(` ✎ ${CLI_NAME} v${VERSION}\\n`))\r\n console.log(pc.dim( ` entry: ${appDir}`))\r\n console.log(pc.dim( ' target: node24'))\r\n console.log(pc.dim( ` output: ${outDir}`))\r\n console.log()\r\n\r\n const pipeline = pipe([\r\n buildFileTree,\r\n buildSegmentTree,\r\n buildRouteChainMap,\r\n buildComponentIdMap,\r\n buildSerializedRoutes,\r\n\r\n // Conditionally add metadata file generation tasks\r\n emitMetadata && writeRouteMapFile,\r\n emitMetadata && writeSerializedTreeFile,\r\n emitMetadata && writeComponentIdMapFile,\r\n\r\n writeCompiledRoutesFile,\r\n writeEntryFile,\r\n compileApplication,\r\n ])\r\n\r\n const { duration: dur } = await pipeline.run({ appDir, outDir })\r\n console.log()\r\n console.log(fileList(outDir, '**/*'))\r\n console.log()\r\n console.log(`${pc.green('✓')} Built in ${pc.bold(duration(dur))}`)\r\n console.log()\r\n }\r\n\r\n catch (err) {\r\n console.error(`${pc.red('✗')} Build failed`)\r\n console.log()\r\n\r\n const message = err instanceof Error ? err.message : String(err)\r\n console.error(pc.red(message))\r\n console.log()\r\n process.exit(1)\r\n }\r\n },\r\n}\r\n","import { existsSync } from 'fs'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport pc from 'picocolors'\r\n\r\nimport { CLI_NAME, PACKAGE_NAME } from '@/pen/constants'\r\nimport type { CLICommand } from '../../types'\r\n\r\nexport const init: CLICommand = {\r\n name: 'init',\r\n desc: 'Initialize a new Pen project',\r\n action: async () => {\r\n console.log(pc.cyan(`\\n Initializing ${CLI_NAME} project...\\n`))\r\n\r\n // Check if already initialized\r\n if (existsSync('pen.config.ts')) {\r\n console.error(pc.yellow('⚠') + ' Project already initialized')\r\n console.error(pc.dim(' pen.config.ts already exists'))\r\n return\r\n }\r\n\r\n // Create pen.config.ts\r\n const configContent = [\r\n `import { defineConfig } from '${PACKAGE_NAME}'`,\r\n '',\r\n 'export default defineConfig({',\r\n ' appDir: \\'./src/app\\',',\r\n ' outDir: \\'./.pen\\',',\r\n '})',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile('pen.config.ts', configContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created pen.config.ts')\r\n\r\n // Create src/app directory\r\n const appDir = './src/app'\r\n await mkdir(appDir, { recursive: true })\r\n\r\n // Create layout.tsx\r\n const layoutContent = [\r\n 'import { Box, Text } from \\'ink\\'',\r\n 'import type { ReactNode } from \\'react\\'',\r\n '',\r\n 'export default function Layout({ children }: { children?: ReactNode }) {',\r\n ' return (',\r\n ' <Box flexDirection=\"column\" padding={1}>',\r\n ' <Box marginBottom={1} borderStyle=\"round\" borderColor=\"cyan\" paddingX={2}>',\r\n ' <Text bold color=\"cyan\">Welcome to Pen</Text>',\r\n ' </Box>',\r\n ' {children}',\r\n ' </Box>',\r\n ' )',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile(join(appDir, 'layout.tsx'), layoutContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created src/app/layout.tsx')\r\n\r\n // Create screen.tsx\r\n const screenContent = [\r\n 'import { useState } from \\'react\\'',\r\n 'import { Box, Text, useInput } from \\'ink\\'',\r\n '',\r\n 'export default function Screen() {',\r\n ' const [count, setCount] = useState(0)',\r\n '',\r\n ' useInput((input) => {',\r\n ' if (input === \\' \\') setCount(c => c + 1)',\r\n ' })',\r\n '',\r\n ' return (',\r\n ' <Box flexDirection=\"column\" gap={1}>',\r\n ' <Box>',\r\n ' <Text>Count: <Text bold color=\"green\">{count}</Text></Text>',\r\n ' </Box>',\r\n ' <Box>',\r\n ' <Text dimColor>Press <Text bold>SPACE</Text> to increment</Text>',\r\n ' </Box>',\r\n ' </Box>',\r\n ' )',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile(join(appDir, 'screen.tsx'), screenContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created src/app/screen.tsx')\r\n\r\n // Success message with instructions\r\n console.log()\r\n console.log(pc.green('✓') + ' Project initialized!')\r\n console.log()\r\n console.log(pc.bold(' Next steps:'))\r\n console.log()\r\n console.log(pc.dim(' 1. Add scripts to package.json:'))\r\n console.log()\r\n console.log(' {')\r\n console.log(' \"scripts\": {')\r\n console.log(` \"build\": \"${CLI_NAME} build\",`)\r\n console.log(` \"start\": \"${CLI_NAME} start\"`)\r\n console.log(' }')\r\n console.log(' }')\r\n console.log()\r\n console.log(pc.dim(' 2. Run \"npm run build\" to build your app'))\r\n console.log(pc.dim(' 3. Run \"npm run start\" to start your app'))\r\n console.log()\r\n },\r\n}\r\n","import { existsSync } from 'fs'\r\nimport { resolve } from 'path'\r\nimport { pathToFileURL } from 'url'\r\nimport pc from 'picocolors'\r\n\r\nimport { loadConfig } from '@/pen/config'\r\nimport { CLI_NAME } from '@/pen/constants'\r\nimport type { CLICommand } from '../../types'\r\n\r\nexport const start: CLICommand = {\r\n name: 'start',\r\n desc: 'Start the application',\r\n action: async () => {\r\n const { outDir } = await loadConfig()\r\n const initialUrl = '/'\r\n const entryPath = resolve(outDir, 'dist', 'entry.js')\r\n\r\n // Check if build exists\r\n if (!existsSync(entryPath)) {\r\n console.error(pc.red('✗') + ' Build not found')\r\n console.error(pc.dim(` Run \"${CLI_NAME} build\" first`))\r\n throw new Error('Build not found') // Let Commander handle exit\r\n }\r\n\r\n // Import and run the bundled entry\r\n const entryUrl = pathToFileURL(entryPath).href\r\n const { run } = await import(entryUrl)\r\n\r\n // Run with initial URL\r\n await run(initialUrl)\r\n },\r\n}\r\n","import { Command } from 'commander'\r\nimport { CLI_NAME, DESCRIPTION, VERSION } from '@/pen/constants'\r\nimport { build } from './commands/build'\r\nimport { init } from './commands/init'\r\nimport { start } from './commands/start'\r\n\r\nfunction configureProgram(program: Command) {\r\n program\r\n .name(CLI_NAME)\r\n .description(DESCRIPTION)\r\n .version(VERSION)\r\n\r\n const commands = [build, init, start] as const\r\n for (const { name, desc, action } of commands) {\r\n program\r\n .command(name)\r\n .description(desc)\r\n .action(action)\r\n }\r\n return program\r\n}\r\n\r\nexport async function run(argv: string[]) {\r\n const command = new Command()\r\n const program = configureProgram(command)\r\n\r\n try {\r\n await program.parseAsync(argv)\r\n return 0\r\n }\r\n catch (err) {\r\n const message = err instanceof Error ? err.message : 'Unknown error'\r\n console.error(message)\r\n return 1\r\n }\r\n}\r\n","#!/usr/bin/env node\r\n\r\nimport { run } from './cli'\r\n\r\nprocess.exit(await run(process.argv))\r\n"],"x_google_ignoreList":[1],"mappings":"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"}
1
+ {"version":3,"file":"bin.mjs","names":["filename","filename","filename","filename","rolldownBuild","build","pc","pc","pc","run","build"],"sources":["../src/pen/constants.ts","../node_modules/picocolors/picocolors.js","../src/cli/commands/build/tasks/build-file-tree.ts","../src/cli/commands/build/tasks/build-segment-tree.ts","../src/cli/commands/build/tasks/build-route-chain-map.ts","../src/cli/commands/build/tasks/build-component-id-map.ts","../src/cli/commands/build/tasks/write-route-chain-map-file.ts","../src/cli/commands/build/tasks/build-serialized-routes.ts","../src/cli/commands/build/tasks/write-serialized-routes-file.ts","../src/cli/commands/build/tasks/write-component-id-map-file.ts","../src/cli/commands/build/tasks/write-compiled-routes-file.ts","../src/cli/commands/build/tasks/write-entry-file.ts","../src/cli/commands/build/tasks/compile-application.ts","../src/cli/commands/build/index.ts","../src/cli/commands/init/index.ts","../src/cli/commands/start/index.ts","../src/cli/index.ts","../src/bin.ts"],"sourcesContent":["// Build-time globals injected by tsdown via `define`.\r\n// tsdown replaces these placeholders with actual values\r\n// from package.json at compile time.\r\n\r\ndeclare const __DESCRIPTION__: string\r\ndeclare const __PACKAGE_NAME__: string\r\ndeclare const __VERSION__: string\r\n\r\n// Package metadata\r\nexport const DESCRIPTION = __DESCRIPTION__\r\nexport const PACKAGE_NAME = __PACKAGE_NAME__\r\nexport const VERSION = __VERSION__\r\n\r\n// Framework metadata\r\nexport const CLI_NAME = __PACKAGE_NAME__.split('/')?.[1] ?? __PACKAGE_NAME__\r\n","let p = process || {}, argv = p.argv || [], env = p.env || {}\nlet isColorSupported =\n\t!(!!env.NO_COLOR || argv.includes(\"--no-color\")) &&\n\t(!!env.FORCE_COLOR || argv.includes(\"--color\") || p.platform === \"win32\" || ((p.stdout || {}).isTTY && env.TERM !== \"dumb\") || !!env.CI)\n\nlet formatter = (open, close, replace = open) =>\n\tinput => {\n\t\tlet string = \"\" + input, index = string.indexOf(close, open.length)\n\t\treturn ~index ? open + replaceClose(string, close, replace, index) + close : open + string + close\n\t}\n\nlet replaceClose = (string, close, replace, index) => {\n\tlet result = \"\", cursor = 0\n\tdo {\n\t\tresult += string.substring(cursor, index) + replace\n\t\tcursor = index + close.length\n\t\tindex = string.indexOf(close, cursor)\n\t} while (~index)\n\treturn result + string.substring(cursor)\n}\n\nlet createColors = (enabled = isColorSupported) => {\n\tlet f = enabled ? formatter : () => String\n\treturn {\n\t\tisColorSupported: enabled,\n\t\treset: f(\"\\x1b[0m\", \"\\x1b[0m\"),\n\t\tbold: f(\"\\x1b[1m\", \"\\x1b[22m\", \"\\x1b[22m\\x1b[1m\"),\n\t\tdim: f(\"\\x1b[2m\", \"\\x1b[22m\", \"\\x1b[22m\\x1b[2m\"),\n\t\titalic: f(\"\\x1b[3m\", \"\\x1b[23m\"),\n\t\tunderline: f(\"\\x1b[4m\", \"\\x1b[24m\"),\n\t\tinverse: f(\"\\x1b[7m\", \"\\x1b[27m\"),\n\t\thidden: f(\"\\x1b[8m\", \"\\x1b[28m\"),\n\t\tstrikethrough: f(\"\\x1b[9m\", \"\\x1b[29m\"),\n\n\t\tblack: f(\"\\x1b[30m\", \"\\x1b[39m\"),\n\t\tred: f(\"\\x1b[31m\", \"\\x1b[39m\"),\n\t\tgreen: f(\"\\x1b[32m\", \"\\x1b[39m\"),\n\t\tyellow: f(\"\\x1b[33m\", \"\\x1b[39m\"),\n\t\tblue: f(\"\\x1b[34m\", \"\\x1b[39m\"),\n\t\tmagenta: f(\"\\x1b[35m\", \"\\x1b[39m\"),\n\t\tcyan: f(\"\\x1b[36m\", \"\\x1b[39m\"),\n\t\twhite: f(\"\\x1b[37m\", \"\\x1b[39m\"),\n\t\tgray: f(\"\\x1b[90m\", \"\\x1b[39m\"),\n\n\t\tbgBlack: f(\"\\x1b[40m\", \"\\x1b[49m\"),\n\t\tbgRed: f(\"\\x1b[41m\", \"\\x1b[49m\"),\n\t\tbgGreen: f(\"\\x1b[42m\", \"\\x1b[49m\"),\n\t\tbgYellow: f(\"\\x1b[43m\", \"\\x1b[49m\"),\n\t\tbgBlue: f(\"\\x1b[44m\", \"\\x1b[49m\"),\n\t\tbgMagenta: f(\"\\x1b[45m\", \"\\x1b[49m\"),\n\t\tbgCyan: f(\"\\x1b[46m\", \"\\x1b[49m\"),\n\t\tbgWhite: f(\"\\x1b[47m\", \"\\x1b[49m\"),\n\n\t\tblackBright: f(\"\\x1b[90m\", \"\\x1b[39m\"),\n\t\tredBright: f(\"\\x1b[91m\", \"\\x1b[39m\"),\n\t\tgreenBright: f(\"\\x1b[92m\", \"\\x1b[39m\"),\n\t\tyellowBright: f(\"\\x1b[93m\", \"\\x1b[39m\"),\n\t\tblueBright: f(\"\\x1b[94m\", \"\\x1b[39m\"),\n\t\tmagentaBright: f(\"\\x1b[95m\", \"\\x1b[39m\"),\n\t\tcyanBright: f(\"\\x1b[96m\", \"\\x1b[39m\"),\n\t\twhiteBright: f(\"\\x1b[97m\", \"\\x1b[39m\"),\n\n\t\tbgBlackBright: f(\"\\x1b[100m\", \"\\x1b[49m\"),\n\t\tbgRedBright: f(\"\\x1b[101m\", \"\\x1b[49m\"),\n\t\tbgGreenBright: f(\"\\x1b[102m\", \"\\x1b[49m\"),\n\t\tbgYellowBright: f(\"\\x1b[103m\", \"\\x1b[49m\"),\n\t\tbgBlueBright: f(\"\\x1b[104m\", \"\\x1b[49m\"),\n\t\tbgMagentaBright: f(\"\\x1b[105m\", \"\\x1b[49m\"),\n\t\tbgCyanBright: f(\"\\x1b[106m\", \"\\x1b[49m\"),\n\t\tbgWhiteBright: f(\"\\x1b[107m\", \"\\x1b[49m\"),\n\t}\n}\n\nmodule.exports = createColors()\nmodule.exports.createColors = createColors\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createFileTree } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildFileTree: Task<BuildContext> = {\r\n name: 'Building file tree',\r\n onSuccess: (_, dur) => `Built file tree (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n fileTree: createFileTree(ctx.appDir),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createSegmentTree } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildSegmentTree: Task<BuildContext> = {\r\n name: 'Building segment tree...',\r\n onSuccess: (_, dur) => `Built segment tree (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n segmentTree: createSegmentTree(ctx.fileTree!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createRouteChainMap } from '@/pen/compiler'\r\n\r\n// ===== Main Task =====\r\n\r\nexport const buildRouteChainMap: Task<BuildContext> = {\r\n name: 'Building route chain map',\r\n onSuccess: (_, dur) => `Built route chain map (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n routeChainMap: createRouteChainMap(ctx.segmentTree!, ctx.outDir),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createComponentIdMap } from '@/pen/compiler'\r\n\r\nexport const buildComponentIdMap: Task<BuildContext> = {\r\n name: 'Building component index map',\r\n onSuccess: (_, dur) => `Built component map (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n componentIdMap: createComponentIdMap(ctx.routeChainMap!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'route-chain-map.ts'\r\n\r\nexport const writeRouteMapFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename}} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '// NOTE: This file is kept for documentation/debugging.',\r\n '// Runtime uses pre-built routes from routes.ts instead.',\r\n '',\r\n `import type { RouteChainMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const routes: RouteChainMap = ${JSON.stringify(ctx.routeChainMap!, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { createSerializedRoutes } from '@/pen/compiler'\r\n\r\nexport const buildSerializedRoutes: Task<BuildContext> = {\r\n name: 'Serializing routes',\r\n onSuccess: (_, dur) => `Serialized routes (${duration(dur)})`,\r\n run: async (ctx) => ({\r\n serializedRoutes: createSerializedRoutes(ctx.routeChainMap!, ctx.componentIdMap!),\r\n }),\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'serialized-routes.ts'\r\n\r\nexport const writeSerializedTreeFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '// NOTE: This file is kept for documentation/debugging.',\r\n '',\r\n `import type { SerializedRouteTreeMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const serializedRoutes: SerializedRouteTreeMap = ${JSON.stringify(ctx.serializedRoutes!, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'component-id-map.ts'\r\n\r\nexport const writeComponentIdMapFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'artifacts')\r\n const outDir = join(genDir, filename)\r\n\r\n const componentIdMap = ctx.componentIdMap!\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n `import type { ComponentIdMap } from '${PACKAGE_NAME}'`,\r\n '',\r\n `export const componentIdMap: ComponentIdMap = ${JSON.stringify(componentIdMap, null, 2)} as const`,\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { SerializedTree } from '@/pen/compiler'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'compiled-routes.ts'\r\n\r\nexport const writeCompiledRoutesFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'generated')\r\n const outDir = join(genDir, filename)\r\n const serializedRoutes = ctx.serializedRoutes!\r\n const componentIdMap = ctx.componentIdMap!\r\n\r\n // Get sorted imports from component map\r\n const sortedImports = Object.keys(componentIdMap)\r\n\r\n // Generate component imports\r\n const importStatements = sortedImports\r\n .map((importPath, i) => `import Component${i} from '${importPath}'`)\r\n .join('\\n')\r\n\r\n // Generate pre-built route components from element trees\r\n const routeEntries: string[] = []\r\n for (const [url, tree] of Object.entries(serializedRoutes)) {\r\n const elementCode = ` ${serialize(tree).replace(/\\n/g, '\\n ')}`\r\n routeEntries.push(` '${url}':\\n${elementCode},`)\r\n }\r\n\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n `import type { CompiledRoutes } from '${PACKAGE_NAME}'`,\r\n 'import { createElement } from \\'react\\'',\r\n '',\r\n importStatements,\r\n '',\r\n '// Compiled route elements generated at build time',\r\n 'export const compiledRoutes: CompiledRoutes = {',\r\n routeEntries.join('\\n'),\r\n '} as const',\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n\r\n/** Serializes an SerializedTree to React.createElement() code string. */\r\nexport function serialize(tree: SerializedTree, indent = 0): string {\r\n const spaces = ' '.repeat(indent)\r\n\r\n // Props are already pre-serialized (strings have quotes, identifiers don't)\r\n const props = Object.entries(tree.props)\r\n .map(([key, value]) => `${key}: ${value}`)\r\n .join(', ')\r\n\r\n if (!tree.children)\r\n return `createElement(${tree.component}, { ${props} })`\r\n\r\n const childCode = serialize(tree.children, indent + 1)\r\n return `createElement(${tree.component}, { ${props} },\\n${spaces} ${childCode}\\n${spaces})`\r\n}\r\n","import type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport { PACKAGE_NAME } from '@/pen/constants'\r\n\r\nconst filename = 'entry.ts'\r\n\r\nexport const writeEntryFile: Task<BuildContext> = {\r\n name: `Writing ${filename}`,\r\n onSuccess: (_, dur) => `Saved ${filename} (${duration(dur)})`,\r\n run: async (ctx) => {\r\n const genDir = join(ctx.outDir, 'generated')\r\n const outDir = join(genDir, filename)\r\n const code = [\r\n `// Auto-generated by ${PACKAGE_NAME}`,\r\n '// Do not manually edit this file',\r\n '',\r\n 'import { createElement } from \\'react\\'',\r\n 'import { render } from \\'ink\\'',\r\n `import { App } from '${PACKAGE_NAME}'`,\r\n 'import { compiledRoutes as routes } from \\'./compiled-routes\\'',\r\n '',\r\n 'export async function run(initialUrl: string) {',\r\n ' const element = createElement(App, { initialUrl, routes })',\r\n ' const { waitUntilExit } = render(element)',\r\n ' await waitUntilExit()',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await mkdir(genDir, { recursive: true })\r\n await writeFile(outDir, code, 'utf-8')\r\n },\r\n}\r\n","import { join, resolve } from 'path'\r\nimport { build as rolldownBuild } from 'rolldown'\r\nimport nodeExternals from 'rollup-plugin-node-externals'\r\nimport { duration } from '@idlesummer/tasker'\r\nimport type { Task } from '@idlesummer/tasker'\r\nimport type { BuildContext } from '../types'\r\n\r\nexport const compileApplication: Task<BuildContext> = {\r\n name: 'Compiling application',\r\n onSuccess: (_, dur) => `Compiled application (${duration(dur)})`,\r\n onError: (err) => `Compilation failed: ${err.message}`,\r\n run: async (ctx) => {\r\n await rolldownBuild({\r\n input: resolve(join(ctx.outDir, 'generated', 'entry.ts')), // entry point\r\n platform: 'node',\r\n resolve: {\r\n extensions: ['.ts', '.tsx', '.js', '.jsx'],\r\n },\r\n plugins: [nodeExternals()],\r\n output: {\r\n dir: resolve(join(ctx.outDir, 'dist')),\r\n format: 'esm',\r\n sourcemap: true,\r\n minify: true,\r\n },\r\n })\r\n },\r\n}\r\n","import type { CLICommand } from '../../types'\r\nimport pc from 'picocolors'\r\nimport { pipe, duration, fileList } from '@idlesummer/tasker'\r\nimport { loadConfig } from '@/pen/config'\r\nimport { CLI_NAME, VERSION } from '@/pen/constants'\r\n\r\n// Import individual tasks\r\nimport { buildFileTree } from './tasks/build-file-tree'\r\nimport { buildSegmentTree } from './tasks/build-segment-tree'\r\nimport { buildRouteChainMap } from './tasks/build-route-chain-map'\r\nimport { buildComponentIdMap } from './tasks/build-component-id-map'\r\nimport { writeRouteMapFile } from './tasks/write-route-chain-map-file'\r\nimport { buildSerializedRoutes } from './tasks/build-serialized-routes'\r\nimport { writeSerializedTreeFile } from './tasks/write-serialized-routes-file'\r\nimport { writeComponentIdMapFile } from './tasks/write-component-id-map-file'\r\nimport { writeCompiledRoutesFile } from './tasks/write-compiled-routes-file'\r\nimport { writeEntryFile } from './tasks/write-entry-file'\r\nimport { compileApplication } from './tasks/compile-application'\r\n\r\nexport const build: CLICommand = {\r\n name: 'build',\r\n desc: 'Build the routing structure and compile application',\r\n action: async () => {\r\n try {\r\n const { appDir, outDir, emitMetadata } = await loadConfig()\r\n console.log(pc.cyan(' Starting production build...\\n'))\r\n console.log(pc.bold(` ✎ ${CLI_NAME} v${VERSION}\\n`))\r\n console.log(pc.dim( ` entry: ${appDir}`))\r\n console.log(pc.dim( ' target: node24'))\r\n console.log(pc.dim( ` output: ${outDir}`))\r\n console.log()\r\n\r\n const pipeline = pipe([\r\n buildFileTree,\r\n buildSegmentTree,\r\n buildRouteChainMap,\r\n buildComponentIdMap,\r\n buildSerializedRoutes,\r\n\r\n // Conditionally add metadata file generation tasks\r\n emitMetadata && writeRouteMapFile,\r\n emitMetadata && writeSerializedTreeFile,\r\n emitMetadata && writeComponentIdMapFile,\r\n\r\n writeCompiledRoutesFile,\r\n writeEntryFile,\r\n compileApplication,\r\n ])\r\n\r\n const { duration: dur } = await pipeline.run({ appDir, outDir })\r\n console.log()\r\n console.log(fileList(outDir, '**/*'))\r\n console.log()\r\n console.log(`${pc.green('✓')} Built in ${pc.bold(duration(dur))}`)\r\n console.log()\r\n }\r\n\r\n catch (err) {\r\n console.error(`${pc.red('✗')} Build failed`)\r\n console.log()\r\n\r\n const message = err instanceof Error ? err.message : String(err)\r\n console.error(pc.red(message))\r\n console.log()\r\n process.exit(1)\r\n }\r\n },\r\n}\r\n","import { existsSync } from 'fs'\r\nimport { mkdir, writeFile } from 'fs/promises'\r\nimport { join } from 'path'\r\nimport pc from 'picocolors'\r\n\r\nimport { CLI_NAME, PACKAGE_NAME } from '@/pen/constants'\r\nimport type { CLICommand } from '../../types'\r\n\r\nexport const init: CLICommand = {\r\n name: 'init',\r\n desc: 'Initialize a new Pen project',\r\n action: async () => {\r\n console.log(pc.cyan(`\\n Initializing ${CLI_NAME} project...\\n`))\r\n\r\n // Check if already initialized\r\n if (existsSync('pen.config.ts')) {\r\n console.error(pc.yellow('⚠') + ' Project already initialized')\r\n console.error(pc.dim(' pen.config.ts already exists'))\r\n return\r\n }\r\n\r\n // Create pen.config.ts\r\n const configContent = [\r\n `import { defineConfig } from '${PACKAGE_NAME}'`,\r\n '',\r\n 'export default defineConfig({',\r\n ' appDir: \\'./src/app\\',',\r\n ' outDir: \\'./.pen\\',',\r\n '})',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile('pen.config.ts', configContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created pen.config.ts')\r\n\r\n // Create src/app directory\r\n const appDir = './src/app'\r\n await mkdir(appDir, { recursive: true })\r\n\r\n // Create layout.tsx\r\n const layoutContent = [\r\n 'import { Box, Text } from \\'ink\\'',\r\n 'import type { ReactNode } from \\'react\\'',\r\n '',\r\n 'export default function Layout({ children }: { children?: ReactNode }) {',\r\n ' return (',\r\n ' <Box flexDirection=\"column\" padding={1}>',\r\n ' <Box marginBottom={1} borderStyle=\"round\" borderColor=\"cyan\" paddingX={2}>',\r\n ' <Text bold color=\"cyan\">Welcome to Pen</Text>',\r\n ' </Box>',\r\n ' {children}',\r\n ' </Box>',\r\n ' )',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile(join(appDir, 'layout.tsx'), layoutContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created src/app/layout.tsx')\r\n\r\n // Create screen.tsx\r\n const screenContent = [\r\n 'import { useState } from \\'react\\'',\r\n 'import { Box, Text, useInput } from \\'ink\\'',\r\n '',\r\n 'export default function Screen() {',\r\n ' const [count, setCount] = useState(0)',\r\n '',\r\n ' useInput((input) => {',\r\n ' if (input === \\' \\') setCount(c => c + 1)',\r\n ' })',\r\n '',\r\n ' return (',\r\n ' <Box flexDirection=\"column\" gap={1}>',\r\n ' <Box>',\r\n ' <Text>Count: <Text bold color=\"green\">{count}</Text></Text>',\r\n ' </Box>',\r\n ' <Box>',\r\n ' <Text dimColor>Press <Text bold>SPACE</Text> to increment</Text>',\r\n ' </Box>',\r\n ' </Box>',\r\n ' )',\r\n '}',\r\n '',\r\n ].join('\\n')\r\n\r\n await writeFile(join(appDir, 'screen.tsx'), screenContent, 'utf-8')\r\n console.log(pc.green('✓') + ' Created src/app/screen.tsx')\r\n\r\n // Success message with instructions\r\n console.log()\r\n console.log(pc.green('✓') + ' Project initialized!')\r\n console.log()\r\n console.log(pc.bold(' Next steps:'))\r\n console.log()\r\n console.log(pc.dim(' 1. Add scripts to package.json:'))\r\n console.log()\r\n console.log(' {')\r\n console.log(' \"scripts\": {')\r\n console.log(` \"build\": \"${CLI_NAME} build\",`)\r\n console.log(` \"start\": \"${CLI_NAME} start\"`)\r\n console.log(' }')\r\n console.log(' }')\r\n console.log()\r\n console.log(pc.dim(' 2. Run \"npm run build\" to build your app'))\r\n console.log(pc.dim(' 3. Run \"npm run start\" to start your app'))\r\n console.log()\r\n },\r\n}\r\n","import { existsSync } from 'fs'\r\nimport { resolve } from 'path'\r\nimport { pathToFileURL } from 'url'\r\nimport pc from 'picocolors'\r\n\r\nimport { loadConfig } from '@/pen/config'\r\nimport { CLI_NAME } from '@/pen/constants'\r\nimport type { CLICommand } from '../../types'\r\n\r\nexport const start: CLICommand = {\r\n name: 'start',\r\n desc: 'Start the application',\r\n action: async () => {\r\n const { outDir } = await loadConfig()\r\n const initialUrl = '/'\r\n const entryPath = resolve(outDir, 'dist', 'entry.js')\r\n\r\n // Check if build exists\r\n if (!existsSync(entryPath)) {\r\n console.error(pc.red('✗') + ' Build not found')\r\n console.error(pc.dim(` Run \"${CLI_NAME} build\" first`))\r\n throw new Error('Build not found') // Let Commander handle exit\r\n }\r\n\r\n // Import and run the bundled entry\r\n const entryUrl = pathToFileURL(entryPath).href\r\n const { run } = await import(entryUrl)\r\n\r\n // Run with initial URL\r\n await run(initialUrl)\r\n },\r\n}\r\n","import { Command } from 'commander'\r\nimport { CLI_NAME, DESCRIPTION, VERSION } from '@/pen/constants'\r\nimport { build } from './commands/build'\r\nimport { init } from './commands/init'\r\nimport { start } from './commands/start'\r\n\r\nfunction configureProgram(program: Command) {\r\n program\r\n .name(CLI_NAME)\r\n .description(DESCRIPTION)\r\n .version(VERSION)\r\n\r\n const commands = [build, init, start] as const\r\n for (const { name, desc, action } of commands) {\r\n program\r\n .command(name)\r\n .description(desc)\r\n .action(action)\r\n }\r\n return program\r\n}\r\n\r\nexport async function run(argv: string[]) {\r\n const command = new Command()\r\n const program = configureProgram(command)\r\n\r\n try {\r\n await program.parseAsync(argv)\r\n return 0\r\n }\r\n catch (err) {\r\n const message = err instanceof Error ? err.message : 'Unknown error'\r\n console.error(message)\r\n return 1\r\n }\r\n}\r\n","#!/usr/bin/env node\r\n\r\nimport { run } from './cli'\r\n\r\nprocess.exit(await run(process.argv))\r\n"],"x_google_ignoreList":[1],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@idlesummer/pen",
3
- "version": "0.2.2",
3
+ "version": "0.2.3",
4
4
  "description": "File-based routing for React Ink apps (experimental)",
5
5
  "keywords": [
6
6
  "cli",