versacompiler 2.6.0 → 2.6.1
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 +70 -54
- package/dist/compiler/compile.js +5 -0
- package/dist/main.js +0 -12
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -3,15 +3,16 @@
|
|
|
3
3
|
[](https://opensource.org/licenses/MIT)
|
|
4
4
|
[](https://www.typescriptlang.org/)
|
|
5
5
|
[](https://vuejs.org/)
|
|
6
|
+
[](https://github.com/kriollo/versaCompiler/releases/tag/v2.6.1)
|
|
6
7
|
|
|
7
|
-
> **🎯 Compilador rápido y eficiente para Vue.js, TypeScript y JavaScript con Hot Module Replacement (HMR)
|
|
8
|
+
> **🎯 Compilador rápido y eficiente para Vue.js, TypeScript y JavaScript con Hot Module Replacement (HMR) completo.**
|
|
8
9
|
|
|
9
10
|
**VersaCompiler** es una herramienta de compilación diseñada para proyectos Vue 3 con soporte completo para TypeScript, JavaScript y todas las funcionalidades modernas que necesitas para desarrollo web.
|
|
10
11
|
|
|
11
12
|
## 🌟 Características Principales
|
|
12
13
|
|
|
13
14
|
- ⚡ **Compilación ultra-rápida** - Workers paralelos y cache inteligente
|
|
14
|
-
- 🔥 **HMR
|
|
15
|
+
- 🔥 **HMR Completo (como Vite)** - Vue SFCs, librerías JS/TS y propagación en cascada sin recarga de página
|
|
15
16
|
- 🧩 **Soporte completo para Vue 3** - SFC, Composition API, script setup
|
|
16
17
|
- 📝 **TypeScript avanzado** - Language Service, decorators, validación de tipos
|
|
17
18
|
- 🔍 **Sistema de linting dual** - ESLint + OxLint con auto-fix
|
|
@@ -125,25 +126,37 @@ versacompiler --typeCheck --file src/types.ts
|
|
|
125
126
|
|
|
126
127
|
### 🔧 Archivo de configuración
|
|
127
128
|
|
|
128
|
-
Crea un archivo `versacompile.config.ts` en la raíz de tu proyecto:
|
|
129
|
+
Crea un archivo `versacompile.config.ts` en la raíz de tu proyecto usando `defineConfig` para autocompletado TypeScript:
|
|
129
130
|
|
|
130
131
|
```typescript
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
132
|
+
import { defineConfig } from 'versacompiler/config';
|
|
133
|
+
|
|
134
|
+
export default defineConfig({
|
|
135
|
+
root: './src',
|
|
136
|
+
build: {
|
|
136
137
|
outDir: './dist',
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
138
|
+
bundlers: [
|
|
139
|
+
{
|
|
140
|
+
name: 'appLoader',
|
|
141
|
+
fileInput: './public/module/appLoader.js',
|
|
142
|
+
fileOutput: './public/module/appLoader.prod.js',
|
|
143
|
+
},
|
|
144
|
+
],
|
|
145
|
+
},
|
|
146
|
+
resolve: {
|
|
147
|
+
alias: {
|
|
148
|
+
'@': 'src',
|
|
149
|
+
'P@': 'public',
|
|
140
150
|
},
|
|
141
151
|
},
|
|
142
|
-
|
|
152
|
+
server: {
|
|
143
153
|
proxyUrl: '',
|
|
144
154
|
assetsOmit: true,
|
|
155
|
+
watch: {
|
|
156
|
+
additional: ['./app/templates/**/*.twig'],
|
|
157
|
+
},
|
|
145
158
|
},
|
|
146
|
-
|
|
159
|
+
tsconfig: './tsconfig.json',
|
|
147
160
|
tailwindConfig: {
|
|
148
161
|
bin: './node_modules/.bin/tailwindcss',
|
|
149
162
|
input: './src/css/input.css',
|
|
@@ -165,62 +178,60 @@ export default {
|
|
|
165
178
|
paths: ['src/'],
|
|
166
179
|
},
|
|
167
180
|
],
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
fileOutput: './public/module/appLoader.prod.js',
|
|
173
|
-
},
|
|
174
|
-
],
|
|
175
|
-
};
|
|
181
|
+
typeCheckOptions: {
|
|
182
|
+
maxWorkers: 2,
|
|
183
|
+
},
|
|
184
|
+
});
|
|
176
185
|
```
|
|
177
186
|
|
|
178
187
|
### 📝 Opciones de configuración
|
|
179
188
|
|
|
180
|
-
#### `
|
|
189
|
+
#### `root` _(requerido)_
|
|
181
190
|
|
|
182
|
-
-
|
|
183
|
-
- `outDir`: Directorio de salida (por defecto: `'./dist'`)
|
|
184
|
-
- `pathsAlias`: Aliases para imports (ej: `'@/*': ['src/*']`)
|
|
191
|
+
- Directorio raíz de los archivos fuente (ej: `'./src'`)
|
|
185
192
|
|
|
186
|
-
#### `
|
|
193
|
+
#### `build` _(requerido)_
|
|
187
194
|
|
|
188
|
-
- `
|
|
189
|
-
- `
|
|
195
|
+
- `outDir`: Directorio de salida de los archivos compilados (ej: `'./dist'`)
|
|
196
|
+
- `bundlers`: Array de entradas de bundling post-compilación (opcional, `false` para deshabilitar)
|
|
197
|
+
- `name`: Nombre del bundle
|
|
198
|
+
- `fileInput`: Archivo de entrada
|
|
199
|
+
- `fileOutput`: Archivo de salida
|
|
200
|
+
|
|
201
|
+
#### `resolve`
|
|
202
|
+
|
|
203
|
+
- `alias`: Mapa de alias de imports. La clave es el prefijo del alias y el valor es la ruta que reemplaza (ej: `{ '@': 'src', 'P@': 'public' }`)
|
|
204
|
+
|
|
205
|
+
#### `server`
|
|
206
|
+
|
|
207
|
+
- `proxyUrl`: URL del proxy para desarrollo (ej: `'http://localhost:8000'`)
|
|
208
|
+
- `assetsOmit`: Omitir assets estáticos del proxy (`true`/`false`)
|
|
209
|
+
- `watch.additional`: Globs adicionales a vigilar que disparan recarga completa (ej: plantillas Twig, HTML)
|
|
210
|
+
|
|
211
|
+
#### `tsconfig`
|
|
212
|
+
|
|
213
|
+
- Ruta al `tsconfig.json` del proyecto (ej: `'./tsconfig.json'`)
|
|
190
214
|
|
|
191
215
|
#### `tailwindConfig`
|
|
192
216
|
|
|
193
217
|
- `bin`: Ruta al binario de TailwindCSS
|
|
194
|
-
- `input`: Archivo CSS de entrada
|
|
195
|
-
- `output`: Archivo CSS de salida
|
|
218
|
+
- `input`: Archivo CSS de entrada con directivas Tailwind
|
|
219
|
+
- `output`: Archivo CSS de salida compilado
|
|
220
|
+
- Usar `false` para deshabilitar completamente
|
|
196
221
|
|
|
197
222
|
#### `linter`
|
|
198
223
|
|
|
199
|
-
Array de configuraciones de linters
|
|
224
|
+
Array de configuraciones de linters. Usar `false` para deshabilitar todos:
|
|
200
225
|
|
|
201
226
|
- `name`: Nombre del linter (`'eslint'` o `'oxlint'`)
|
|
202
227
|
- `bin`: Ruta al binario del linter
|
|
203
228
|
- `configFile`: Archivo de configuración del linter
|
|
204
|
-
- `fix`: Auto-fix de errores detectados
|
|
205
|
-
- `paths`: Rutas específicas a analizar
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
- `formats`: Formatos de salida (`'json'`, `'stylish'`, `'compact'`)
|
|
211
|
-
- `oxlintConfig`: Configuración específica de OxLint
|
|
212
|
-
- `rules`: Reglas personalizadas
|
|
213
|
-
- `plugins`: Plugins de OxLint
|
|
214
|
-
- `deny`: Reglas a denegar
|
|
215
|
-
- `allow`: Reglas a permitir
|
|
216
|
-
|
|
217
|
-
#### `bundlers`
|
|
218
|
-
|
|
219
|
-
Array de configuraciones de bundling:
|
|
220
|
-
|
|
221
|
-
- `name`: Nombre del bundle
|
|
222
|
-
- `fileInput`: Archivo de entrada
|
|
223
|
-
- `fileOutput`: Archivo de salida
|
|
229
|
+
- `fix`: Auto-fix de errores detectados (`true`/`false`)
|
|
230
|
+
- `paths`: Rutas específicas a analizar (ej: `['src/']`)
|
|
231
|
+
|
|
232
|
+
#### `typeCheckOptions`
|
|
233
|
+
|
|
234
|
+
- `maxWorkers`: Máximo número de worker threads para verificación de tipos (por defecto: depende del número de CPUs)
|
|
224
235
|
|
|
225
236
|
## 🎯 Ejemplos de Uso
|
|
226
237
|
|
|
@@ -514,12 +525,17 @@ cat tsconfig.json | grep -A 10 "paths"
|
|
|
514
525
|
|
|
515
526
|
```typescript
|
|
516
527
|
// Verificar configuración en versacompile.config.ts
|
|
517
|
-
|
|
518
|
-
|
|
528
|
+
import { defineConfig } from 'versacompiler/config';
|
|
529
|
+
|
|
530
|
+
export default defineConfig({
|
|
531
|
+
root: './src',
|
|
532
|
+
build: { outDir: './dist' },
|
|
533
|
+
resolve: { alias: { '@': 'src' } },
|
|
534
|
+
server: {
|
|
519
535
|
proxyUrl: '', // Vacío si no usas proxy backend
|
|
520
536
|
assetsOmit: true,
|
|
521
537
|
},
|
|
522
|
-
};
|
|
538
|
+
});
|
|
523
539
|
```
|
|
524
540
|
|
|
525
541
|
```bash
|
package/dist/compiler/compile.js
CHANGED
|
@@ -1653,6 +1653,11 @@ function extractLocalImports(code) {
|
|
|
1653
1653
|
* Solo se llama cuando env.isPROD !== 'true' y la salida es un archivo .js.
|
|
1654
1654
|
*/
|
|
1655
1655
|
function injectHmrShim(code) {
|
|
1656
|
+
// Los scripts CLI con shebang no se ejecutan en browser: omitir el shim HMR
|
|
1657
|
+
// para evitar que el shebang quede desplazado y cause SyntaxError en Node.js
|
|
1658
|
+
if (code.startsWith('#!')) {
|
|
1659
|
+
return code;
|
|
1660
|
+
}
|
|
1656
1661
|
const localImports = extractLocalImports(code);
|
|
1657
1662
|
// Detecta si es un Vue SFC (el compilador Vue inyecta 'data-versa-hmr-component')
|
|
1658
1663
|
const isVueComponent = code.includes('data-versa-hmr-component');
|
package/dist/main.js
CHANGED
|
@@ -1,15 +1,3 @@
|
|
|
1
|
-
/* VersaCompiler HMR shim [dev] */
|
|
2
|
-
if (typeof window !== 'undefined' && window.__versaHMR) {
|
|
3
|
-
(() => {
|
|
4
|
-
const _id = new URL(import.meta.url).pathname;
|
|
5
|
-
import.meta.hot = {
|
|
6
|
-
accept(cb) { window.__versaHMR.accept(_id, typeof cb === 'function' ? cb : () => {}); },
|
|
7
|
-
invalidate() { window.__versaHMR._invalidate?.(_id); },
|
|
8
|
-
dispose(cb) { window.__versaHMR._onDispose?.(_id, cb); },
|
|
9
|
-
get data() { return window.__versaHMR._getHotData?.(_id) ?? {}; },
|
|
10
|
-
};
|
|
11
|
-
})();
|
|
12
|
-
}
|
|
13
1
|
#!/usr/bin/env node
|
|
14
2
|
import * as path from 'node:path';
|
|
15
3
|
import * as processModule from 'node:process';
|
package/package.json
CHANGED