@jotx-labs/cli 2.2.1 → 2.4.130
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/README.md +5 -5
- package/package.json +6 -3
- package/dist/cli.d.ts +0 -7
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js +0 -192
- package/dist/cli.js.map +0 -1
- package/src/cli.ts +0 -171
- package/tsconfig.json +0 -19
package/README.md
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
# @jotx/cli
|
|
1
|
+
# @jotx-labs/cli
|
|
2
2
|
|
|
3
3
|
Command-line interface for jotx - demonstrates platform independence.
|
|
4
4
|
|
|
5
5
|
## Installation
|
|
6
6
|
|
|
7
7
|
```bash
|
|
8
|
-
npm install -g @jotx/cli
|
|
8
|
+
npm install -g @jotx-labs/cli
|
|
9
9
|
```
|
|
10
10
|
|
|
11
11
|
## Usage
|
|
@@ -63,9 +63,9 @@ jotx parse notes.jot | jq .
|
|
|
63
63
|
|
|
64
64
|
The CLI demonstrates jotx's platform independence:
|
|
65
65
|
|
|
66
|
-
- Uses `@jotx/core` for parsing/validation
|
|
67
|
-
- Uses `NodePlatform` from `@jotx/adapters` for file I/O
|
|
68
|
-
- Uses `HTMLRenderer` from `@jotx/adapters` for output
|
|
66
|
+
- Uses `@jotx-labs/core` for parsing/validation
|
|
67
|
+
- Uses `NodePlatform` from `@jotx-labs/adapters` for file I/O
|
|
68
|
+
- Uses `HTMLRenderer` from `@jotx-labs/adapters` for output
|
|
69
69
|
- **Zero** VS Code dependencies
|
|
70
70
|
- **Zero** browser dependencies
|
|
71
71
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@jotx-labs/cli",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.4.130",
|
|
4
|
+
"files": [
|
|
5
|
+
"dist"
|
|
6
|
+
],
|
|
4
7
|
"description": "jotx command-line interface",
|
|
5
8
|
"main": "dist/index.js",
|
|
6
9
|
"bin": {
|
|
@@ -20,8 +23,8 @@
|
|
|
20
23
|
"author": "jotx",
|
|
21
24
|
"license": "Apache-2.0",
|
|
22
25
|
"dependencies": {
|
|
23
|
-
"@jotx/core": "
|
|
24
|
-
"@jotx/adapters": "
|
|
26
|
+
"@jotx-labs/core": "^2.4.130",
|
|
27
|
+
"@jotx-labs/adapters": "^2.4.130",
|
|
25
28
|
"commander": "^11.0.0",
|
|
26
29
|
"chalk": "^4.1.2"
|
|
27
30
|
},
|
package/dist/cli.d.ts
DELETED
package/dist/cli.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA;;;GAGG"}
|
package/dist/cli.js
DELETED
|
@@ -1,192 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
/**
|
|
4
|
-
* jotx CLI - Demonstrates platform independence
|
|
5
|
-
* Uses @jotx/core + NodePlatform
|
|
6
|
-
*/
|
|
7
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
|
-
if (k2 === undefined) k2 = k;
|
|
9
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
10
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
11
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
12
|
-
}
|
|
13
|
-
Object.defineProperty(o, k2, desc);
|
|
14
|
-
}) : (function(o, m, k, k2) {
|
|
15
|
-
if (k2 === undefined) k2 = k;
|
|
16
|
-
o[k2] = m[k];
|
|
17
|
-
}));
|
|
18
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
19
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
20
|
-
}) : function(o, v) {
|
|
21
|
-
o["default"] = v;
|
|
22
|
-
});
|
|
23
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
24
|
-
var ownKeys = function(o) {
|
|
25
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
26
|
-
var ar = [];
|
|
27
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
28
|
-
return ar;
|
|
29
|
-
};
|
|
30
|
-
return ownKeys(o);
|
|
31
|
-
};
|
|
32
|
-
return function (mod) {
|
|
33
|
-
if (mod && mod.__esModule) return mod;
|
|
34
|
-
var result = {};
|
|
35
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
36
|
-
__setModuleDefault(result, mod);
|
|
37
|
-
return result;
|
|
38
|
-
};
|
|
39
|
-
})();
|
|
40
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
-
const commander_1 = require("commander");
|
|
42
|
-
const fs = __importStar(require("fs/promises"));
|
|
43
|
-
const program = new commander_1.Command();
|
|
44
|
-
program
|
|
45
|
-
.name('jotx')
|
|
46
|
-
.description('jotx CLI - Parse, validate, and convert jotx files')
|
|
47
|
-
.version('1.0.22');
|
|
48
|
-
// Parse command
|
|
49
|
-
program
|
|
50
|
-
.command('parse <file>')
|
|
51
|
-
.description('Parse a .jot file and show AST')
|
|
52
|
-
.action(async (file) => {
|
|
53
|
-
try {
|
|
54
|
-
const text = await fs.readFile(file, 'utf-8');
|
|
55
|
-
const result = core.parseAndValidate(text);
|
|
56
|
-
if (result.isValid) {
|
|
57
|
-
console.log('✅ Parse successful!');
|
|
58
|
-
console.log(JSON.stringify(result.ast, null, 2));
|
|
59
|
-
}
|
|
60
|
-
else {
|
|
61
|
-
console.error('❌ Parse failed:');
|
|
62
|
-
result.validation.errors.forEach(err => {
|
|
63
|
-
console.error(` - ${err.message}`);
|
|
64
|
-
});
|
|
65
|
-
process.exit(1);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
catch (error) {
|
|
69
|
-
console.error('❌ Error:', error);
|
|
70
|
-
process.exit(1);
|
|
71
|
-
}
|
|
72
|
-
});
|
|
73
|
-
// Validate command
|
|
74
|
-
program
|
|
75
|
-
.command('validate <file>')
|
|
76
|
-
.description('Validate a .jot file')
|
|
77
|
-
.action(async (file) => {
|
|
78
|
-
try {
|
|
79
|
-
const text = await fs.readFile(file, 'utf-8');
|
|
80
|
-
const result = core.parseAndValidate(text);
|
|
81
|
-
if (result.isValid) {
|
|
82
|
-
console.log(`✅ ${file} is valid!`);
|
|
83
|
-
console.log(` Document: ${result.ast.document.id}`);
|
|
84
|
-
console.log(` Type: ${result.ast.document.documentType}`);
|
|
85
|
-
console.log(` Blocks: ${result.ast.document.blocks.length}`);
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
console.error(`❌ ${file} has errors:`);
|
|
89
|
-
result.validation.errors.forEach(err => {
|
|
90
|
-
console.error(` - ${err.message}`);
|
|
91
|
-
});
|
|
92
|
-
process.exit(1);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
catch (error) {
|
|
96
|
-
console.error('❌ Error:', error);
|
|
97
|
-
process.exit(1);
|
|
98
|
-
}
|
|
99
|
-
});
|
|
100
|
-
// Convert command
|
|
101
|
-
program
|
|
102
|
-
.command('convert <file>')
|
|
103
|
-
.description('Convert .jot file to HTML')
|
|
104
|
-
.option('-o, --output <file>', 'Output file (default: stdout)')
|
|
105
|
-
.action(async (file, options) => {
|
|
106
|
-
try {
|
|
107
|
-
const text = await fs.readFile(file, 'utf-8');
|
|
108
|
-
const result = core.parseAndValidate(text);
|
|
109
|
-
if (!result.isValid) {
|
|
110
|
-
console.error('❌ File has errors:');
|
|
111
|
-
result.validation.errors.forEach(err => {
|
|
112
|
-
console.error(` - ${err.message}`);
|
|
113
|
-
});
|
|
114
|
-
process.exit(1);
|
|
115
|
-
}
|
|
116
|
-
// Render to HTML
|
|
117
|
-
const html = renderer.render({
|
|
118
|
-
id: result.ast.document.id,
|
|
119
|
-
type: result.ast.document.documentType,
|
|
120
|
-
metadata: result.ast.document.metadata,
|
|
121
|
-
blocks: result.ast.document.blocks
|
|
122
|
-
});
|
|
123
|
-
// Wrap in full HTML document
|
|
124
|
-
const fullHtml = `<!DOCTYPE html>
|
|
125
|
-
<html lang="en">
|
|
126
|
-
<head>
|
|
127
|
-
<meta charset="UTF-8">
|
|
128
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
129
|
-
<title>${result.ast.document.metadata.title || 'jotx Document'}</title>
|
|
130
|
-
<style>
|
|
131
|
-
body { font-family: system-ui, -apple-system, sans-serif; max-width: 800px; margin: 40px auto; padding: 0 20px; }
|
|
132
|
-
h1 { font-size: 2em; margin-bottom: 0.5em; }
|
|
133
|
-
h2 { font-size: 1.5em; margin-top: 1.5em; }
|
|
134
|
-
h3 { font-size: 1.2em; margin-top: 1.2em; }
|
|
135
|
-
code { background: #f5f5f5; padding: 2px 6px; border-radius: 3px; }
|
|
136
|
-
pre { background: #f5f5f5; padding: 16px; border-radius: 6px; overflow-x: auto; }
|
|
137
|
-
blockquote { border-left: 4px solid #ddd; padding-left: 16px; margin-left: 0; color: #666; }
|
|
138
|
-
</style>
|
|
139
|
-
</head>
|
|
140
|
-
<body>
|
|
141
|
-
${html}
|
|
142
|
-
</body>
|
|
143
|
-
</html>`;
|
|
144
|
-
if (options.output) {
|
|
145
|
-
await fs.writeFile(options.output, fullHtml, 'utf-8');
|
|
146
|
-
console.log(`✅ Converted to ${options.output}`);
|
|
147
|
-
}
|
|
148
|
-
else {
|
|
149
|
-
console.log(fullHtml);
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
catch (error) {
|
|
153
|
-
console.error('❌ Error:', error);
|
|
154
|
-
process.exit(1);
|
|
155
|
-
}
|
|
156
|
-
});
|
|
157
|
-
// Info command
|
|
158
|
-
program
|
|
159
|
-
.command('info <file>')
|
|
160
|
-
.description('Show document information')
|
|
161
|
-
.action(async (file) => {
|
|
162
|
-
try {
|
|
163
|
-
const text = await fs.readFile(file, 'utf-8');
|
|
164
|
-
const result = core.parseAndValidate(text);
|
|
165
|
-
if (!result.isValid) {
|
|
166
|
-
console.error('❌ File has errors');
|
|
167
|
-
process.exit(1);
|
|
168
|
-
}
|
|
169
|
-
const doc = result.ast.document;
|
|
170
|
-
console.log('📄 Document Information');
|
|
171
|
-
console.log('─'.repeat(50));
|
|
172
|
-
console.log(`ID: ${doc.id}`);
|
|
173
|
-
console.log(`Type: ${doc.documentType}`);
|
|
174
|
-
console.log(`Title: ${doc.metadata.title || '(none)'}`);
|
|
175
|
-
console.log(`Blocks: ${doc.blocks.length}`);
|
|
176
|
-
console.log();
|
|
177
|
-
console.log('Block Types:');
|
|
178
|
-
const blockCounts = {};
|
|
179
|
-
doc.blocks.forEach(block => {
|
|
180
|
-
blockCounts[block.type] = (blockCounts[block.type] || 0) + 1;
|
|
181
|
-
});
|
|
182
|
-
Object.entries(blockCounts).forEach(([type, count]) => {
|
|
183
|
-
console.log(` - ${type}: ${count}`);
|
|
184
|
-
});
|
|
185
|
-
}
|
|
186
|
-
catch (error) {
|
|
187
|
-
console.error('❌ Error:', error);
|
|
188
|
-
process.exit(1);
|
|
189
|
-
}
|
|
190
|
-
});
|
|
191
|
-
program.parse();
|
|
192
|
-
//# sourceMappingURL=cli.js.map
|
package/dist/cli.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";;AACA;;;GAGG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,yCAAmC;AACnC,gDAAiC;AAIjC,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAA;AAE7B,OAAO;KACJ,IAAI,CAAC,MAAM,CAAC;KACZ,WAAW,CAAC,oDAAoD,CAAC;KACjE,OAAO,CAAC,QAAQ,CAAC,CAAA;AAEpB,gBAAgB;AAChB,OAAO;KACJ,OAAO,CAAC,cAAc,CAAC;KACvB,WAAW,CAAC,gCAAgC,CAAC;KAC7C,MAAM,CAAC,KAAK,EAAE,IAAY,EAAE,EAAE;IAC7B,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QAE1C,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAA;YAClC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAA;QAClD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;YAChC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACrC,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;YACrC,CAAC,CAAC,CAAA;YACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;QAChC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ,mBAAmB;AACnB,OAAO;KACJ,OAAO,CAAC,iBAAiB,CAAC;KAC1B,WAAW,CAAC,sBAAsB,CAAC;KACnC,MAAM,CAAC,KAAK,EAAE,IAAY,EAAE,EAAE;IAC7B,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QAE1C,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,YAAY,CAAC,CAAA;YAClC,OAAO,CAAC,GAAG,CAAC,gBAAgB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAA;YACrD,OAAO,CAAC,GAAG,CAAC,YAAY,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAA;YAC3D,OAAO,CAAC,GAAG,CAAC,cAAc,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAA;QAChE,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,KAAK,IAAI,cAAc,CAAC,CAAA;YACtC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACrC,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;YACrC,CAAC,CAAC,CAAA;YACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;QAChC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ,kBAAkB;AAClB,OAAO;KACJ,OAAO,CAAC,gBAAgB,CAAC;KACzB,WAAW,CAAC,2BAA2B,CAAC;KACxC,MAAM,CAAC,qBAAqB,EAAE,+BAA+B,CAAC;KAC9D,MAAM,CAAC,KAAK,EAAE,IAAY,EAAE,OAA4B,EAAE,EAAE;IAC3D,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QAE1C,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,OAAO,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAA;YACnC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACrC,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;YACrC,CAAC,CAAC,CAAA;YACF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,iBAAiB;QACjB,MAAM,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC3B,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAC1B,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,YAAY;YACtC,QAAQ,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ;YACtC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAa;SACnC,CAAC,CAAA;QAET,6BAA6B;QAC7B,MAAM,QAAQ,GAAG;;;;;WAKZ,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,IAAI,eAAe;;;;;;;;;;;;EAY9D,IAAI;;QAEE,CAAA;QAEF,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,MAAM,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAA;YACrD,OAAO,CAAC,GAAG,CAAC,kBAAkB,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;QACjD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACvB,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;QAChC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ,eAAe;AACf,OAAO;KACJ,OAAO,CAAC,aAAa,CAAC;KACtB,WAAW,CAAC,2BAA2B,CAAC;KACxC,MAAM,CAAC,KAAK,EAAE,IAAY,EAAE,EAAE;IAC7B,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;QAE1C,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;YAClC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACjB,CAAC;QAED,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAA;QAE/B,OAAO,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAA;QACtC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAA;QAC3B,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,CAAC,EAAE,EAAE,CAAC,CAAA;QAClC,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,CAAC,YAAY,EAAE,CAAC,CAAA;QAC5C,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,EAAE,CAAC,CAAA;QAC1D,OAAO,CAAC,GAAG,CAAC,aAAa,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAA;QAC7C,OAAO,CAAC,GAAG,EAAE,CAAA;QACb,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;QAE3B,MAAM,WAAW,GAA2B,EAAE,CAAA;QAC9C,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACzB,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;QAC9D,CAAC,CAAC,CAAA;QAEF,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE;YACpD,OAAO,CAAC,GAAG,CAAC,OAAO,IAAI,KAAK,KAAK,EAAE,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;QAChC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACjB,CAAC;AACH,CAAC,CAAC,CAAA;AAEJ,OAAO,CAAC,KAAK,EAAE,CAAA"}
|
package/src/cli.ts
DELETED
|
@@ -1,171 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* jotx CLI - Demonstrates platform independence
|
|
4
|
-
* Uses @jotx/core + NodePlatform
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { Command } from 'commander'
|
|
8
|
-
import * as fs from 'fs/promises'
|
|
9
|
-
import * as path from 'path'
|
|
10
|
-
import { jotToMarkdown, markdownToJot } from '@jotx-labs/core'
|
|
11
|
-
|
|
12
|
-
const program = new Command()
|
|
13
|
-
|
|
14
|
-
program
|
|
15
|
-
.name('jotx')
|
|
16
|
-
.description('jotx CLI - Parse, validate, and convert jotx files')
|
|
17
|
-
.version('1.0.22')
|
|
18
|
-
|
|
19
|
-
// Parse command
|
|
20
|
-
program
|
|
21
|
-
.command('parse <file>')
|
|
22
|
-
.description('Parse a .jot file and show AST')
|
|
23
|
-
.action(async (file: string) => {
|
|
24
|
-
try {
|
|
25
|
-
const text = await fs.readFile(file, 'utf-8')
|
|
26
|
-
const result = core.parseAndValidate(text)
|
|
27
|
-
|
|
28
|
-
if (result.isValid) {
|
|
29
|
-
console.log('✅ Parse successful!')
|
|
30
|
-
console.log(JSON.stringify(result.ast, null, 2))
|
|
31
|
-
} else {
|
|
32
|
-
console.error('❌ Parse failed:')
|
|
33
|
-
result.validation.errors.forEach(err => {
|
|
34
|
-
console.error(` - ${err.message}`)
|
|
35
|
-
})
|
|
36
|
-
process.exit(1)
|
|
37
|
-
}
|
|
38
|
-
} catch (error) {
|
|
39
|
-
console.error('❌ Error:', error)
|
|
40
|
-
process.exit(1)
|
|
41
|
-
}
|
|
42
|
-
})
|
|
43
|
-
|
|
44
|
-
// Validate command
|
|
45
|
-
program
|
|
46
|
-
.command('validate <file>')
|
|
47
|
-
.description('Validate a .jot file')
|
|
48
|
-
.action(async (file: string) => {
|
|
49
|
-
try {
|
|
50
|
-
const text = await fs.readFile(file, 'utf-8')
|
|
51
|
-
const result = core.parseAndValidate(text)
|
|
52
|
-
|
|
53
|
-
if (result.isValid) {
|
|
54
|
-
console.log(`✅ ${file} is valid!`)
|
|
55
|
-
console.log(` Document: ${result.ast.document.id}`)
|
|
56
|
-
console.log(` Type: ${result.ast.document.documentType}`)
|
|
57
|
-
console.log(` Blocks: ${result.ast.document.blocks.length}`)
|
|
58
|
-
} else {
|
|
59
|
-
console.error(`❌ ${file} has errors:`)
|
|
60
|
-
result.validation.errors.forEach(err => {
|
|
61
|
-
console.error(` - ${err.message}`)
|
|
62
|
-
})
|
|
63
|
-
process.exit(1)
|
|
64
|
-
}
|
|
65
|
-
} catch (error) {
|
|
66
|
-
console.error('❌ Error:', error)
|
|
67
|
-
process.exit(1)
|
|
68
|
-
}
|
|
69
|
-
})
|
|
70
|
-
|
|
71
|
-
// Convert command
|
|
72
|
-
program
|
|
73
|
-
.command('convert <file>')
|
|
74
|
-
.description('Convert .jot file to HTML')
|
|
75
|
-
.option('-o, --output <file>', 'Output file (default: stdout)')
|
|
76
|
-
.action(async (file: string, options: { output?: string }) => {
|
|
77
|
-
try {
|
|
78
|
-
const text = await fs.readFile(file, 'utf-8')
|
|
79
|
-
const result = core.parseAndValidate(text)
|
|
80
|
-
|
|
81
|
-
if (!result.isValid) {
|
|
82
|
-
console.error('❌ File has errors:')
|
|
83
|
-
result.validation.errors.forEach(err => {
|
|
84
|
-
console.error(` - ${err.message}`)
|
|
85
|
-
})
|
|
86
|
-
process.exit(1)
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
// Render to HTML
|
|
90
|
-
const html = renderer.render({
|
|
91
|
-
id: result.ast.document.id,
|
|
92
|
-
type: result.ast.document.documentType,
|
|
93
|
-
metadata: result.ast.document.metadata,
|
|
94
|
-
blocks: result.ast.document.blocks as any
|
|
95
|
-
} as any)
|
|
96
|
-
|
|
97
|
-
// Wrap in full HTML document
|
|
98
|
-
const fullHtml = `<!DOCTYPE html>
|
|
99
|
-
<html lang="en">
|
|
100
|
-
<head>
|
|
101
|
-
<meta charset="UTF-8">
|
|
102
|
-
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
103
|
-
<title>${result.ast.document.metadata.title || 'jotx Document'}</title>
|
|
104
|
-
<style>
|
|
105
|
-
body { font-family: system-ui, -apple-system, sans-serif; max-width: 800px; margin: 40px auto; padding: 0 20px; }
|
|
106
|
-
h1 { font-size: 2em; margin-bottom: 0.5em; }
|
|
107
|
-
h2 { font-size: 1.5em; margin-top: 1.5em; }
|
|
108
|
-
h3 { font-size: 1.2em; margin-top: 1.2em; }
|
|
109
|
-
code { background: #f5f5f5; padding: 2px 6px; border-radius: 3px; }
|
|
110
|
-
pre { background: #f5f5f5; padding: 16px; border-radius: 6px; overflow-x: auto; }
|
|
111
|
-
blockquote { border-left: 4px solid #ddd; padding-left: 16px; margin-left: 0; color: #666; }
|
|
112
|
-
</style>
|
|
113
|
-
</head>
|
|
114
|
-
<body>
|
|
115
|
-
${html}
|
|
116
|
-
</body>
|
|
117
|
-
</html>`
|
|
118
|
-
|
|
119
|
-
if (options.output) {
|
|
120
|
-
await fs.writeFile(options.output, fullHtml, 'utf-8')
|
|
121
|
-
console.log(`✅ Converted to ${options.output}`)
|
|
122
|
-
} else {
|
|
123
|
-
console.log(fullHtml)
|
|
124
|
-
}
|
|
125
|
-
} catch (error) {
|
|
126
|
-
console.error('❌ Error:', error)
|
|
127
|
-
process.exit(1)
|
|
128
|
-
}
|
|
129
|
-
})
|
|
130
|
-
|
|
131
|
-
// Info command
|
|
132
|
-
program
|
|
133
|
-
.command('info <file>')
|
|
134
|
-
.description('Show document information')
|
|
135
|
-
.action(async (file: string) => {
|
|
136
|
-
try {
|
|
137
|
-
const text = await fs.readFile(file, 'utf-8')
|
|
138
|
-
const result = core.parseAndValidate(text)
|
|
139
|
-
|
|
140
|
-
if (!result.isValid) {
|
|
141
|
-
console.error('❌ File has errors')
|
|
142
|
-
process.exit(1)
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
const doc = result.ast.document
|
|
146
|
-
|
|
147
|
-
console.log('📄 Document Information')
|
|
148
|
-
console.log('─'.repeat(50))
|
|
149
|
-
console.log(`ID: ${doc.id}`)
|
|
150
|
-
console.log(`Type: ${doc.documentType}`)
|
|
151
|
-
console.log(`Title: ${doc.metadata.title || '(none)'}`)
|
|
152
|
-
console.log(`Blocks: ${doc.blocks.length}`)
|
|
153
|
-
console.log()
|
|
154
|
-
console.log('Block Types:')
|
|
155
|
-
|
|
156
|
-
const blockCounts: Record<string, number> = {}
|
|
157
|
-
doc.blocks.forEach(block => {
|
|
158
|
-
blockCounts[block.type] = (blockCounts[block.type] || 0) + 1
|
|
159
|
-
})
|
|
160
|
-
|
|
161
|
-
Object.entries(blockCounts).forEach(([type, count]) => {
|
|
162
|
-
console.log(` - ${type}: ${count}`)
|
|
163
|
-
})
|
|
164
|
-
} catch (error) {
|
|
165
|
-
console.error('❌ Error:', error)
|
|
166
|
-
process.exit(1)
|
|
167
|
-
}
|
|
168
|
-
})
|
|
169
|
-
|
|
170
|
-
program.parse()
|
|
171
|
-
|
package/tsconfig.json
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"target": "ES2020",
|
|
4
|
-
"module": "commonjs",
|
|
5
|
-
"lib": ["ES2020"],
|
|
6
|
-
"outDir": "./dist",
|
|
7
|
-
"rootDir": "./src",
|
|
8
|
-
"strict": true,
|
|
9
|
-
"esModuleInterop": true,
|
|
10
|
-
"skipLibCheck": true,
|
|
11
|
-
"resolveJsonModule": true,
|
|
12
|
-
"declaration": true,
|
|
13
|
-
"declarationMap": true,
|
|
14
|
-
"sourceMap": true
|
|
15
|
-
},
|
|
16
|
-
"include": ["src/**/*.ts"],
|
|
17
|
-
"exclude": ["node_modules", "dist"]
|
|
18
|
-
}
|
|
19
|
-
|