xatriumcss 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md ADDED
File without changes
package/bin/xatriumcss ADDED
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ require('../src/cli.js');
package/index.js ADDED
@@ -0,0 +1,315 @@
1
+ /* tslint:disable */
2
+ /* eslint-disable */
3
+ /* prettier-ignore */
4
+
5
+ /* auto-generated by NAPI-RS */
6
+
7
+ const { existsSync, readFileSync } = require('fs')
8
+ const { join } = require('path')
9
+
10
+ const { platform, arch } = process
11
+
12
+ let nativeBinding = null
13
+ let localFileExisted = false
14
+ let loadError = null
15
+
16
+ function isMusl() {
17
+ // For Node 10
18
+ if (!process.report || typeof process.report.getReport !== 'function') {
19
+ try {
20
+ const lddPath = require('child_process').execSync('which ldd').toString().trim()
21
+ return readFileSync(lddPath, 'utf8').includes('musl')
22
+ } catch (e) {
23
+ return true
24
+ }
25
+ } else {
26
+ const { glibcVersionRuntime } = process.report.getReport().header
27
+ return !glibcVersionRuntime
28
+ }
29
+ }
30
+
31
+ switch (platform) {
32
+ case 'android':
33
+ switch (arch) {
34
+ case 'arm64':
35
+ localFileExisted = existsSync(join(__dirname, 'index.android-arm64.node'))
36
+ try {
37
+ if (localFileExisted) {
38
+ nativeBinding = require('./index.android-arm64.node')
39
+ } else {
40
+ nativeBinding = require('xatriumcss-android-arm64')
41
+ }
42
+ } catch (e) {
43
+ loadError = e
44
+ }
45
+ break
46
+ case 'arm':
47
+ localFileExisted = existsSync(join(__dirname, 'index.android-arm-eabi.node'))
48
+ try {
49
+ if (localFileExisted) {
50
+ nativeBinding = require('./index.android-arm-eabi.node')
51
+ } else {
52
+ nativeBinding = require('xatriumcss-android-arm-eabi')
53
+ }
54
+ } catch (e) {
55
+ loadError = e
56
+ }
57
+ break
58
+ default:
59
+ throw new Error(`Unsupported architecture on Android ${arch}`)
60
+ }
61
+ break
62
+ case 'win32':
63
+ switch (arch) {
64
+ case 'x64':
65
+ localFileExisted = existsSync(
66
+ join(__dirname, 'index.win32-x64-msvc.node')
67
+ )
68
+ try {
69
+ if (localFileExisted) {
70
+ nativeBinding = require('./index.win32-x64-msvc.node')
71
+ } else {
72
+ nativeBinding = require('xatriumcss-win32-x64-msvc')
73
+ }
74
+ } catch (e) {
75
+ loadError = e
76
+ }
77
+ break
78
+ case 'ia32':
79
+ localFileExisted = existsSync(
80
+ join(__dirname, 'index.win32-ia32-msvc.node')
81
+ )
82
+ try {
83
+ if (localFileExisted) {
84
+ nativeBinding = require('./index.win32-ia32-msvc.node')
85
+ } else {
86
+ nativeBinding = require('xatriumcss-win32-ia32-msvc')
87
+ }
88
+ } catch (e) {
89
+ loadError = e
90
+ }
91
+ break
92
+ case 'arm64':
93
+ localFileExisted = existsSync(
94
+ join(__dirname, 'index.win32-arm64-msvc.node')
95
+ )
96
+ try {
97
+ if (localFileExisted) {
98
+ nativeBinding = require('./index.win32-arm64-msvc.node')
99
+ } else {
100
+ nativeBinding = require('xatriumcss-win32-arm64-msvc')
101
+ }
102
+ } catch (e) {
103
+ loadError = e
104
+ }
105
+ break
106
+ default:
107
+ throw new Error(`Unsupported architecture on Windows: ${arch}`)
108
+ }
109
+ break
110
+ case 'darwin':
111
+ localFileExisted = existsSync(join(__dirname, 'index.darwin-universal.node'))
112
+ try {
113
+ if (localFileExisted) {
114
+ nativeBinding = require('./index.darwin-universal.node')
115
+ } else {
116
+ nativeBinding = require('xatriumcss-darwin-universal')
117
+ }
118
+ break
119
+ } catch {}
120
+ switch (arch) {
121
+ case 'x64':
122
+ localFileExisted = existsSync(join(__dirname, 'index.darwin-x64.node'))
123
+ try {
124
+ if (localFileExisted) {
125
+ nativeBinding = require('./index.darwin-x64.node')
126
+ } else {
127
+ nativeBinding = require('xatriumcss-darwin-x64')
128
+ }
129
+ } catch (e) {
130
+ loadError = e
131
+ }
132
+ break
133
+ case 'arm64':
134
+ localFileExisted = existsSync(
135
+ join(__dirname, 'index.darwin-arm64.node')
136
+ )
137
+ try {
138
+ if (localFileExisted) {
139
+ nativeBinding = require('./index.darwin-arm64.node')
140
+ } else {
141
+ nativeBinding = require('xatriumcss-darwin-arm64')
142
+ }
143
+ } catch (e) {
144
+ loadError = e
145
+ }
146
+ break
147
+ default:
148
+ throw new Error(`Unsupported architecture on macOS: ${arch}`)
149
+ }
150
+ break
151
+ case 'freebsd':
152
+ if (arch !== 'x64') {
153
+ throw new Error(`Unsupported architecture on FreeBSD: ${arch}`)
154
+ }
155
+ localFileExisted = existsSync(join(__dirname, 'index.freebsd-x64.node'))
156
+ try {
157
+ if (localFileExisted) {
158
+ nativeBinding = require('./index.freebsd-x64.node')
159
+ } else {
160
+ nativeBinding = require('xatriumcss-freebsd-x64')
161
+ }
162
+ } catch (e) {
163
+ loadError = e
164
+ }
165
+ break
166
+ case 'linux':
167
+ switch (arch) {
168
+ case 'x64':
169
+ if (isMusl()) {
170
+ localFileExisted = existsSync(
171
+ join(__dirname, 'index.linux-x64-musl.node')
172
+ )
173
+ try {
174
+ if (localFileExisted) {
175
+ nativeBinding = require('./index.linux-x64-musl.node')
176
+ } else {
177
+ nativeBinding = require('xatriumcss-linux-x64-musl')
178
+ }
179
+ } catch (e) {
180
+ loadError = e
181
+ }
182
+ } else {
183
+ localFileExisted = existsSync(
184
+ join(__dirname, 'index.linux-x64-gnu.node')
185
+ )
186
+ try {
187
+ if (localFileExisted) {
188
+ nativeBinding = require('./index.linux-x64-gnu.node')
189
+ } else {
190
+ nativeBinding = require('xatriumcss-linux-x64-gnu')
191
+ }
192
+ } catch (e) {
193
+ loadError = e
194
+ }
195
+ }
196
+ break
197
+ case 'arm64':
198
+ if (isMusl()) {
199
+ localFileExisted = existsSync(
200
+ join(__dirname, 'index.linux-arm64-musl.node')
201
+ )
202
+ try {
203
+ if (localFileExisted) {
204
+ nativeBinding = require('./index.linux-arm64-musl.node')
205
+ } else {
206
+ nativeBinding = require('xatriumcss-linux-arm64-musl')
207
+ }
208
+ } catch (e) {
209
+ loadError = e
210
+ }
211
+ } else {
212
+ localFileExisted = existsSync(
213
+ join(__dirname, 'index.linux-arm64-gnu.node')
214
+ )
215
+ try {
216
+ if (localFileExisted) {
217
+ nativeBinding = require('./index.linux-arm64-gnu.node')
218
+ } else {
219
+ nativeBinding = require('xatriumcss-linux-arm64-gnu')
220
+ }
221
+ } catch (e) {
222
+ loadError = e
223
+ }
224
+ }
225
+ break
226
+ case 'arm':
227
+ if (isMusl()) {
228
+ localFileExisted = existsSync(
229
+ join(__dirname, 'index.linux-arm-musleabihf.node')
230
+ )
231
+ try {
232
+ if (localFileExisted) {
233
+ nativeBinding = require('./index.linux-arm-musleabihf.node')
234
+ } else {
235
+ nativeBinding = require('xatriumcss-linux-arm-musleabihf')
236
+ }
237
+ } catch (e) {
238
+ loadError = e
239
+ }
240
+ } else {
241
+ localFileExisted = existsSync(
242
+ join(__dirname, 'index.linux-arm-gnueabihf.node')
243
+ )
244
+ try {
245
+ if (localFileExisted) {
246
+ nativeBinding = require('./index.linux-arm-gnueabihf.node')
247
+ } else {
248
+ nativeBinding = require('xatriumcss-linux-arm-gnueabihf')
249
+ }
250
+ } catch (e) {
251
+ loadError = e
252
+ }
253
+ }
254
+ break
255
+ case 'riscv64':
256
+ if (isMusl()) {
257
+ localFileExisted = existsSync(
258
+ join(__dirname, 'index.linux-riscv64-musl.node')
259
+ )
260
+ try {
261
+ if (localFileExisted) {
262
+ nativeBinding = require('./index.linux-riscv64-musl.node')
263
+ } else {
264
+ nativeBinding = require('xatriumcss-linux-riscv64-musl')
265
+ }
266
+ } catch (e) {
267
+ loadError = e
268
+ }
269
+ } else {
270
+ localFileExisted = existsSync(
271
+ join(__dirname, 'index.linux-riscv64-gnu.node')
272
+ )
273
+ try {
274
+ if (localFileExisted) {
275
+ nativeBinding = require('./index.linux-riscv64-gnu.node')
276
+ } else {
277
+ nativeBinding = require('xatriumcss-linux-riscv64-gnu')
278
+ }
279
+ } catch (e) {
280
+ loadError = e
281
+ }
282
+ }
283
+ break
284
+ case 's390x':
285
+ localFileExisted = existsSync(
286
+ join(__dirname, 'index.linux-s390x-gnu.node')
287
+ )
288
+ try {
289
+ if (localFileExisted) {
290
+ nativeBinding = require('./index.linux-s390x-gnu.node')
291
+ } else {
292
+ nativeBinding = require('xatriumcss-linux-s390x-gnu')
293
+ }
294
+ } catch (e) {
295
+ loadError = e
296
+ }
297
+ break
298
+ default:
299
+ throw new Error(`Unsupported architecture on Linux: ${arch}`)
300
+ }
301
+ break
302
+ default:
303
+ throw new Error(`Unsupported OS: ${platform}, architecture: ${arch}`)
304
+ }
305
+
306
+ if (!nativeBinding) {
307
+ if (loadError) {
308
+ throw loadError
309
+ }
310
+ throw new Error(`Failed to load native binding`)
311
+ }
312
+
313
+ const { Scanner } = nativeBinding
314
+
315
+ module.exports.Scanner = Scanner
Binary file
package/package.json ADDED
@@ -0,0 +1,44 @@
1
+ {
2
+ "name": "xatriumcss",
3
+ "version": "1.0.0",
4
+ "description": "Ultra-fast utility-first CSS framework",
5
+ "main": "src/index.js",
6
+ "files": [
7
+ "index.js",
8
+ "*.node",
9
+ "src/"
10
+ ],
11
+ "bin": {
12
+ "xatriumcss": "./bin/xatriumcss"
13
+ },
14
+ "exports": {
15
+ ".": "./src/index.js",
16
+ "./postcss": "./src/postcss.js",
17
+ "./vite": "./src/vite.js"
18
+ },
19
+ "scripts": {
20
+ "build": "napi build --platform --release",
21
+ "build:debug": "napi build --platform",
22
+ "prepublishOnly": "npm run build",
23
+ "install": "node scripts/install.js"
24
+ },
25
+ "napi": {
26
+ "binaryName": "xatriumcss"
27
+ },
28
+ "keywords": [
29
+ "css",
30
+ "tailwind",
31
+ "utility",
32
+ "framework",
33
+ "postcss",
34
+ "vite"
35
+ ],
36
+ "dependencies": {
37
+ "@parcel/watcher": "^2.4.0",
38
+ "glob": "^10.5.0"
39
+ },
40
+ "devDependencies": {
41
+ "@napi-rs/cli": "^2.18.0"
42
+ },
43
+ "license": "MIT"
44
+ }
package/src/cli.js ADDED
@@ -0,0 +1,184 @@
1
+ #!/usr/bin/env node
2
+
3
+ const { runParser, hasXatriumImport } = require('./parser');
4
+ const path = require('path');
5
+ const watcher = require('@parcel/watcher');
6
+ const fs = require('fs');
7
+
8
+ // Parse command line arguments
9
+ function parseArgs(argv) {
10
+ const args = {
11
+ '--input': null,
12
+ '--output': null,
13
+ '--watch': false
14
+ };
15
+
16
+ for (let i = 0; i < argv.length; i++) {
17
+ const arg = argv[i];
18
+
19
+ if (arg === '--watch' || arg === '-w') {
20
+ args['--watch'] = true;
21
+ } else if (arg === '--input' || arg === '-i') {
22
+ args['--input'] = argv[++i];
23
+ } else if (arg === '--output' || arg === '-o') {
24
+ args['--output'] = argv[++i];
25
+ }
26
+ }
27
+
28
+ return args;
29
+ }
30
+
31
+ const args = parseArgs(process.argv.slice(2));
32
+ const projectRoot = process.cwd();
33
+
34
+ // Default configuration (no config file needed)
35
+ const config = {
36
+ input: args['--input'] || './src/input.css',
37
+ content: ['./src/**/*.html', './src/**/*.jsx', './src/**/*.js', './src/**/*.ts', './src/**/*.tsx'],
38
+ output: args['--output'] || './dist/output.css'
39
+ };
40
+
41
+ // Resolve paths relative to project root
42
+ config.input = path.resolve(projectRoot, config.input);
43
+ config.output = path.resolve(projectRoot, config.output);
44
+
45
+ function build() {
46
+ const startTime = process.hrtime.bigint();
47
+
48
+ console.log('šŸ” Checking for @import "xatriumcss"...');
49
+
50
+ // Check if input CSS has the import
51
+ const hasImport = hasXatriumImport(config.input);
52
+
53
+ if (!hasImport) {
54
+ console.log('āš ļø No @import "xatriumcss" found - writing empty CSS');
55
+ const outputDir = path.dirname(config.output);
56
+ if (!fs.existsSync(outputDir)) {
57
+ fs.mkdirSync(outputDir, { recursive: true });
58
+ }
59
+ fs.writeFileSync(config.output, '', 'utf-8');
60
+
61
+ const endTime = process.hrtime.bigint();
62
+ const duration = endTime - startTime;
63
+ console.log(`āœ… Done in ${formatTime(duration)}`);
64
+ return;
65
+ }
66
+
67
+ runParser(config);
68
+
69
+ const endTime = process.hrtime.bigint();
70
+ const duration = endTime - startTime;
71
+
72
+ console.log(`āœ… Done in ${formatTime(duration)}`);
73
+ }
74
+
75
+ function formatTime(nanoseconds) {
76
+ const ms = Number(nanoseconds) / 1_000_000;
77
+
78
+ if (ms < 1000) return `${Math.round(ms)}ms`;
79
+ return `${(ms / 1000).toFixed(2)}s`;
80
+ }
81
+
82
+ // Initial build
83
+ (async () => {
84
+ try {
85
+ build();
86
+ } catch (error) {
87
+ console.error('āŒ Build failed:', error.message);
88
+ console.error('Stack:', error.stack);
89
+ process.exit(1);
90
+ }
91
+
92
+ // Watch mode
93
+ if (args['--watch']) {
94
+ console.log('\nšŸ‘€ Watch mode enabled\n');
95
+ console.log('\nšŸ‘€ Watching for changes...\n');
96
+
97
+ const changedFiles = new Set();
98
+ let rebuildTimer = null;
99
+
100
+ function scheduleRebuild() {
101
+ if (rebuildTimer) return;
102
+
103
+ rebuildTimer = setTimeout(() => {
104
+ const files = Array.from(changedFiles);
105
+ changedFiles.clear();
106
+ rebuildTimer = null;
107
+
108
+ try {
109
+ build();
110
+ } catch (error) {
111
+ console.error('āŒ Build error:', error.message);
112
+ }
113
+ }, 10);
114
+ }
115
+
116
+ // Get directories to watch
117
+ const watchDirs = new Set();
118
+ const contentPatterns = Array.isArray(config.content) ? config.content : [config.content];
119
+
120
+ for (const pattern of contentPatterns) {
121
+ const baseDir = pattern.split('**')[0].replace(/\*/g, '');
122
+ const resolvedDir = path.resolve(projectRoot, baseDir || '.');
123
+
124
+ if (fs.existsSync(resolvedDir)) {
125
+ watchDirs.add(resolvedDir);
126
+ }
127
+ }
128
+
129
+ // IMPORTANT: Watch the input CSS directory
130
+ const inputDir = path.dirname(config.input);
131
+ if (fs.existsSync(inputDir)) {
132
+ watchDirs.add(inputDir);
133
+ }
134
+
135
+ // Subscribe to file changes
136
+ const subscriptions = [];
137
+
138
+ for (const dir of watchDirs) {
139
+ const subscription = await watcher.subscribe(dir, (err, events) => {
140
+ if (err) {
141
+ console.error('āŒ Watcher error:', err);
142
+ return;
143
+ }
144
+
145
+ for (const event of events) {
146
+ if (event.type === 'delete') continue;
147
+
148
+ // CRITICAL: Ignore output file to prevent infinite loop
149
+ if (path.resolve(event.path) === path.resolve(config.output)) {
150
+ continue;
151
+ }
152
+
153
+ const ext = path.extname(event.path);
154
+ const isInputFile = path.resolve(event.path) === path.resolve(config.input);
155
+
156
+ // Watch input CSS and content files
157
+ if (isInputFile || ['.html', '.jsx', '.js', '.ts', '.tsx', '.vue', '.css'].includes(ext)) {
158
+ changedFiles.add(event.path);
159
+ console.log('šŸ“ Changed:', path.relative(projectRoot, event.path));
160
+ }
161
+ }
162
+
163
+ if (changedFiles.size > 0) {
164
+ scheduleRebuild();
165
+ }
166
+ });
167
+
168
+ subscriptions.push(subscription);
169
+ }
170
+
171
+ // Cleanup on exit
172
+ process.on('SIGINT', async () => {
173
+ console.log('\n\nšŸ‘‹ Shutting down...');
174
+
175
+ for (const sub of subscriptions) {
176
+ await sub.unsubscribe();
177
+ }
178
+
179
+ process.exit(0);
180
+ });
181
+
182
+ process.stdin.resume();
183
+ }
184
+ })();