@saulwade/swl-ses 1.4.1 → 1.5.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.
Files changed (136) hide show
  1. package/CLAUDE.md +3 -3
  2. package/README.md +561 -560
  3. package/agentes/nemesis-auditor-swl.md +161 -161
  4. package/bin/swl-mcp-server.js +49 -22
  5. package/bin/swl-ses.js +74 -0
  6. package/comandos/swl/.evolved.json +22 -22
  7. package/comandos/swl/contribuir.md +233 -233
  8. package/comandos/swl/ejecutar-fase.md +33 -4
  9. package/comandos/swl/metricas.md +72 -0
  10. package/comandos/swl/nemesis.md +122 -122
  11. package/gateway/lib/event-channel.js +191 -191
  12. package/habilidades/backend-production-resilience/SKILL.md +288 -288
  13. package/habilidades/benchmark-memoria/SKILL.md +186 -186
  14. package/habilidades/diagrama-arquitectura/assets/template.html +276 -276
  15. package/habilidades/discutir-fase/SKILL.md +50 -2
  16. package/habilidades/doubt-driven-review/SKILL.md +171 -171
  17. package/habilidades/doubt-driven-review/recursos/EXAMPLES.md +130 -130
  18. package/habilidades/ejecutar-task-iterativo/SKILL.md +278 -0
  19. package/habilidades/eval-framework/SKILL.md +212 -212
  20. package/habilidades/feynman-auditor-swl/SKILL.md +123 -123
  21. package/habilidades/feynman-auditor-swl/recursos/preguntas-language-agnostic.md +108 -108
  22. package/habilidades/harness-claude-code/SKILL.md +299 -299
  23. package/habilidades/infra-github-actions/SKILL.md +166 -166
  24. package/habilidades/legacy-code-rescue/SKILL.md +267 -267
  25. package/habilidades/manejo-errores/.evolved.json +8 -8
  26. package/habilidades/meta-skills-estandar/recursos/convencion-examples.md +93 -93
  27. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  28. package/habilidades/patrones-python/SKILL.md +229 -229
  29. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -469
  30. package/habilidades/planear-fase/SKILL.md +319 -319
  31. package/habilidades/protocolo-revision-swl/SKILL.md +276 -0
  32. package/habilidades/release-semver/.evolved.json +8 -8
  33. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +166 -166
  34. package/habilidades/state-inconsistency-auditor-swl/recursos/coupled-state-patterns.md +147 -147
  35. package/habilidades/testing-python/SKILL.md +340 -340
  36. package/habilidades/verificar-trabajo/SKILL.md +49 -5
  37. package/habilidades/web-fetcher-routing/SKILL.md +75 -75
  38. package/hooks/claudemd-bloat-detector.js +161 -161
  39. package/hooks/lib/agent-routing.js +107 -107
  40. package/hooks/lib/auto-consolidator.js +335 -335
  41. package/hooks/lib/error-classifier.js +308 -308
  42. package/hooks/lib/merkle-audit.js +96 -96
  43. package/hooks/lib/provenance-tracker.js +191 -191
  44. package/hooks/lib/rate-limit-tracker.js +253 -253
  45. package/hooks/lib/resource-quota.js +122 -122
  46. package/hooks/lib/retry-jitter.js +165 -165
  47. package/hooks/lib/security-net.js +201 -201
  48. package/hooks/lib/skill-auditor.js +588 -588
  49. package/hooks/lib/sync-status.js +228 -228
  50. package/hooks/lib/taint-tracker.js +107 -107
  51. package/hooks/lib/text-similarity.js +241 -241
  52. package/hooks/lib/toon-compressor.js +245 -245
  53. package/hooks/registro-turnos.js +209 -209
  54. package/hooks/sugerir-regenerar-inventario.js +170 -170
  55. package/hooks/validar-formato-post-subagente.js +140 -140
  56. package/hooks/validar-memoria-hook.js +218 -218
  57. package/instintos/prompt-appendices.yaml +57 -57
  58. package/manifiestos/agent-output-schemas.json +57 -57
  59. package/manifiestos/modulos.json +1321 -1262
  60. package/manifiestos/perfiles.json +2 -1
  61. package/manifiestos/skills-lock.json +1114 -1114
  62. package/package.json +3 -3
  63. package/plantillas/auditor-veto-template.md +105 -105
  64. package/plantillas/github-workflows/README.md +47 -47
  65. package/plantillas/github-workflows/release-please.yml +44 -44
  66. package/plantillas/github-workflows/swl-ci.yml +107 -107
  67. package/plantillas/github-workflows/swl-security.yml +51 -51
  68. package/plugin.json +351 -343
  69. package/reglas/analisis-previo-tareas-grandes.md +172 -172
  70. package/reglas/arreglar-al-detectar.md +147 -147
  71. package/reglas/fragmentos-compartidos.md +152 -152
  72. package/reglas/harness-claude-code.md +213 -213
  73. package/reglas/usar-context7.md +226 -226
  74. package/schemas/diary-entry.schema.json +80 -80
  75. package/scripts/audit-tools/audit-history.js +330 -330
  76. package/scripts/audit-tools/bundle-tracker.js +290 -290
  77. package/scripts/audit-tools/canary-monitor.js +352 -352
  78. package/scripts/audit-tools/code-profiler.js +605 -605
  79. package/scripts/audit-tools/dep-doctor.js +320 -320
  80. package/scripts/audit-tools/env-validator.js +206 -206
  81. package/scripts/audit-tools/lib/fs-walk.js +48 -48
  82. package/scripts/audit-tools/lib/output.js +23 -23
  83. package/scripts/audit-tools/migration-checker.js +392 -392
  84. package/scripts/audit-tools/pentest-scanner.js +1436 -1436
  85. package/scripts/benchmark-memoria.js +167 -167
  86. package/scripts/configurar-branch-protection.js +418 -418
  87. package/scripts/derivar-feature-list.js +489 -0
  88. package/scripts/detectar-aprendizajes-duplicados.js +151 -151
  89. package/scripts/doctor.js +31 -4
  90. package/scripts/field-report.js +199 -199
  91. package/scripts/generar-checklists-consolidados.js +273 -273
  92. package/scripts/generar-inventario.js +420 -420
  93. package/scripts/generar-matriz-lenguajes.js +271 -271
  94. package/scripts/instalador.js +56 -5
  95. package/scripts/lib/artefactos-python.js +43 -43
  96. package/scripts/lib/benchmark-metrics.js +160 -160
  97. package/scripts/lib/budget-enforcer.js +252 -252
  98. package/scripts/lib/configurar-ci.js +380 -380
  99. package/scripts/lib/contadores-inventario.js +217 -217
  100. package/scripts/lib/detectar-runtime.js +75 -9
  101. package/scripts/lib/detectar-stack-detallado.js +307 -307
  102. package/scripts/lib/diary-entry.js +234 -234
  103. package/scripts/lib/estado.js +13 -1
  104. package/scripts/lib/eval-metrics-store.js +218 -218
  105. package/scripts/lib/eval-quality.js +171 -171
  106. package/scripts/lib/eval-schemas.js +144 -144
  107. package/scripts/lib/eval-self-correct.js +106 -106
  108. package/scripts/lib/eval-validator.js +185 -185
  109. package/scripts/lib/expandir-targets.js +71 -0
  110. package/scripts/lib/jaccard-similarity.js +98 -98
  111. package/scripts/lib/longmemeval-runner.js +125 -125
  112. package/scripts/lib/manifiestos.js +42 -1
  113. package/scripts/lib/npm-version.js +261 -261
  114. package/scripts/lib/paquetes-conocidos.js +50 -50
  115. package/scripts/lib/parsear-opciones.js +3 -0
  116. package/scripts/lib/prompt-builder.js +264 -264
  117. package/scripts/lib/rrf-fusion.js +175 -175
  118. package/scripts/lib/scoring-instintos.js +277 -277
  119. package/scripts/lib/semantic-search.js +252 -252
  120. package/scripts/lib/toml-merge.js +204 -0
  121. package/scripts/lib/transformadores/base.js +43 -9
  122. package/scripts/lib/transformadores/codex.js +375 -115
  123. package/scripts/lib/transformadores/cursor.js +359 -0
  124. package/scripts/lib/transformadores/index.js +2 -0
  125. package/scripts/limpiar-artefactos-python.js +131 -131
  126. package/scripts/mcp-server/README.md +122 -80
  127. package/scripts/mcp-server/auth.js +105 -0
  128. package/scripts/mcp-server/cache.js +106 -0
  129. package/scripts/mcp-server/handlers.js +386 -206
  130. package/scripts/mcp-server/telemetry.js +78 -0
  131. package/scripts/migrar-csv-a-array.js +168 -168
  132. package/scripts/migrar-fase-dominio.js +201 -201
  133. package/scripts/publicar.js +511 -511
  134. package/scripts/run-eval.js +141 -141
  135. package/scripts/validar-manifest.js +231 -195
  136. package/scripts/validar-userland-vacio.js +110 -110
@@ -1,245 +1,245 @@
1
- 'use strict';
2
-
3
- /**
4
- * TOON Compressor — Compresión de schemas y documentos estructurados.
5
- *
6
- * Patrón adoptado de CC Workflow Studio (generate-toon-schema.ts).
7
- * Reduce el tamaño de JSON schemas y documentos estructurados ~20-25%
8
- * eliminando redundancia sin perder información semántica.
9
- *
10
- * Técnicas aplicadas:
11
- * 1. Eliminar whitespace y formateo innecesario
12
- * 2. Abreviar claves repetitivas con diccionario
13
- * 3. Colapsar descripciones a una línea
14
- * 4. Eliminar campos opcionales con valor default
15
- * 5. Usar notación compacta para tipos simples
16
- *
17
- * Zero dependencias externas.
18
- *
19
- * Uso:
20
- * const { comprimirSchema, descomprimirSchema, comprimirTexto } = require('./lib/toon-compressor');
21
- * const compacto = comprimirSchema(schemaJSON);
22
- * console.log(`Reducción: ${compacto.reduccionPorcentaje}%`);
23
- *
24
- * @module hooks/lib/toon-compressor
25
- */
26
-
27
- // ---------------------------------------------------------------------------
28
- // Diccionario de abreviaciones para claves JSON Schema
29
- // ---------------------------------------------------------------------------
30
-
31
- /**
32
- * Mapeo de claves largas a abreviaciones cortas.
33
- * Solo para claves que aparecen ≥3 veces en un schema típico.
34
- */
35
- const ABREVIACIONES = {
36
- description: 'desc',
37
- properties: 'props',
38
- required: 'req',
39
- additionalProperties: 'addl',
40
- type: 't',
41
- items: 'it',
42
- default: 'def',
43
- enum: 'en',
44
- maxLength: 'maxL',
45
- minLength: 'minL',
46
- minimum: 'min',
47
- maximum: 'max',
48
- pattern: 'pat',
49
- oneOf: '1of',
50
- anyOf: 'aof',
51
- allOf: 'allof',
52
- };
53
-
54
- /** Mapeo inverso para descompresión. */
55
- const ABREVIACIONES_INV = Object.fromEntries(
56
- Object.entries(ABREVIACIONES).map(([k, v]) => [v, k])
57
- );
58
-
59
- // ---------------------------------------------------------------------------
60
- // Funciones core
61
- // ---------------------------------------------------------------------------
62
-
63
- /**
64
- * Comprime un objeto JSON Schema reemplazando claves por abreviaciones.
65
- *
66
- * @param {object} obj - Objeto a comprimir (se clona internamente)
67
- * @returns {object} Objeto con claves abreviadas
68
- */
69
- function _abreviarClaves(obj) {
70
- if (Array.isArray(obj)) {
71
- return obj.map(_abreviarClaves);
72
- }
73
- if (obj !== null && typeof obj === 'object') {
74
- const resultado = {};
75
- for (const [clave, valor] of Object.entries(obj)) {
76
- const claveCorta = ABREVIACIONES[clave] || clave;
77
- resultado[claveCorta] = _abreviarClaves(valor);
78
- }
79
- return resultado;
80
- }
81
- return obj;
82
- }
83
-
84
- /**
85
- * Descomprime un objeto con claves abreviadas a sus nombres originales.
86
- *
87
- * @param {object} obj - Objeto con claves abreviadas
88
- * @returns {object} Objeto con claves originales
89
- */
90
- function _expandirClaves(obj) {
91
- if (Array.isArray(obj)) {
92
- return obj.map(_expandirClaves);
93
- }
94
- if (obj !== null && typeof obj === 'object') {
95
- const resultado = {};
96
- for (const [clave, valor] of Object.entries(obj)) {
97
- const claveLarga = ABREVIACIONES_INV[clave] || clave;
98
- resultado[claveLarga] = _expandirClaves(valor);
99
- }
100
- return resultado;
101
- }
102
- return obj;
103
- }
104
-
105
- /**
106
- * Elimina campos opcionales con valor default conocido.
107
- *
108
- * @param {object} obj - Schema JSON
109
- * @returns {object} Schema sin defaults redundantes
110
- */
111
- function _eliminarDefaults(obj) {
112
- if (Array.isArray(obj)) {
113
- return obj.map(_eliminarDefaults);
114
- }
115
- if (obj !== null && typeof obj === 'object') {
116
- const resultado = {};
117
- for (const [clave, valor] of Object.entries(obj)) {
118
- // Eliminar additionalProperties: true (es el default)
119
- if (clave === 'additionalProperties' && valor === true) continue;
120
- // Eliminar required: [] (vacío = sin requeridos)
121
- if (clave === 'required' && Array.isArray(valor) && valor.length === 0) continue;
122
- // Eliminar description vacía
123
- if (clave === 'description' && valor === '') continue;
124
- resultado[clave] = _eliminarDefaults(valor);
125
- }
126
- return resultado;
127
- }
128
- return obj;
129
- }
130
-
131
- /**
132
- * Colapsa descripciones multi-línea a una sola línea.
133
- *
134
- * @param {object} obj
135
- * @returns {object}
136
- */
137
- function _colapsarDescripciones(obj) {
138
- if (Array.isArray(obj)) {
139
- return obj.map(_colapsarDescripciones);
140
- }
141
- if (obj !== null && typeof obj === 'object') {
142
- const resultado = {};
143
- for (const [clave, valor] of Object.entries(obj)) {
144
- if (clave === 'description' && typeof valor === 'string') {
145
- resultado[clave] = valor.replace(/\s+/g, ' ').trim();
146
- } else {
147
- resultado[clave] = _colapsarDescripciones(valor);
148
- }
149
- }
150
- return resultado;
151
- }
152
- return obj;
153
- }
154
-
155
- // ---------------------------------------------------------------------------
156
- // API pública
157
- // ---------------------------------------------------------------------------
158
-
159
- /**
160
- * Comprime un JSON Schema aplicando todas las técnicas de reducción.
161
- *
162
- * @param {object|string} schema - JSON Schema (objeto o string JSON)
163
- * @returns {{ comprimido: string, original: number, reducido: number, reduccionPorcentaje: number }}
164
- */
165
- function comprimirSchema(schema) {
166
- const obj = typeof schema === 'string' ? JSON.parse(schema) : schema;
167
- const original = JSON.stringify(obj);
168
-
169
- let procesado = _eliminarDefaults(obj);
170
- procesado = _colapsarDescripciones(procesado);
171
- procesado = _abreviarClaves(procesado);
172
-
173
- const comprimido = JSON.stringify(procesado);
174
-
175
- const tamOriginal = original.length;
176
- const tamReducido = comprimido.length;
177
- const reduccion = ((tamOriginal - tamReducido) / tamOriginal) * 100;
178
-
179
- return {
180
- comprimido,
181
- original: tamOriginal,
182
- reducido: tamReducido,
183
- reduccionPorcentaje: Math.round(reduccion * 10) / 10,
184
- };
185
- }
186
-
187
- /**
188
- * Descomprime un JSON Schema con claves abreviadas.
189
- *
190
- * @param {string|object} comprimido - Schema comprimido
191
- * @returns {object} Schema original con claves expandidas
192
- */
193
- function descomprimirSchema(comprimido) {
194
- const obj = typeof comprimido === 'string' ? JSON.parse(comprimido) : comprimido;
195
- return _expandirClaves(obj);
196
- }
197
-
198
- /**
199
- * Comprime texto Markdown eliminando redundancia para reducir tokens.
200
- *
201
- * Técnicas:
202
- * - Colapsar múltiples líneas vacías a una
203
- * - Eliminar trailing whitespace
204
- * - Comprimir tablas (eliminar padding)
205
- * - Eliminar comentarios HTML
206
- *
207
- * @param {string} texto - Texto Markdown
208
- * @returns {{ comprimido: string, original: number, reducido: number, reduccionPorcentaje: number }}
209
- */
210
- function comprimirTexto(texto) {
211
- const original = texto.length;
212
-
213
- let resultado = texto;
214
- // Colapsar 3+ líneas vacías a 2
215
- resultado = resultado.replace(/\n{3,}/g, '\n\n');
216
- // Eliminar trailing whitespace
217
- resultado = resultado.replace(/[ \t]+$/gm, '');
218
- // Eliminar comentarios HTML
219
- resultado = resultado.replace(/<!--[\s\S]*?-->/g, '');
220
- // Comprimir padding en tablas (múltiples espacios → uno)
221
- resultado = resultado.replace(/\|[ \t]{2,}/g, '| ');
222
- resultado = resultado.replace(/[ \t]{2,}\|/g, ' |');
223
-
224
- const reducido = resultado.length;
225
- const reduccion = ((original - reducido) / original) * 100;
226
-
227
- return {
228
- comprimido: resultado,
229
- original,
230
- reducido,
231
- reduccionPorcentaje: Math.round(reduccion * 10) / 10,
232
- };
233
- }
234
-
235
- // ---------------------------------------------------------------------------
236
- // Exports
237
- // ---------------------------------------------------------------------------
238
-
239
- module.exports = {
240
- comprimirSchema,
241
- descomprimirSchema,
242
- comprimirTexto,
243
- // Exponer diccionario para tests
244
- ABREVIACIONES,
245
- };
1
+ 'use strict';
2
+
3
+ /**
4
+ * TOON Compressor — Compresión de schemas y documentos estructurados.
5
+ *
6
+ * Patrón adoptado de CC Workflow Studio (generate-toon-schema.ts).
7
+ * Reduce el tamaño de JSON schemas y documentos estructurados ~20-25%
8
+ * eliminando redundancia sin perder información semántica.
9
+ *
10
+ * Técnicas aplicadas:
11
+ * 1. Eliminar whitespace y formateo innecesario
12
+ * 2. Abreviar claves repetitivas con diccionario
13
+ * 3. Colapsar descripciones a una línea
14
+ * 4. Eliminar campos opcionales con valor default
15
+ * 5. Usar notación compacta para tipos simples
16
+ *
17
+ * Zero dependencias externas.
18
+ *
19
+ * Uso:
20
+ * const { comprimirSchema, descomprimirSchema, comprimirTexto } = require('./lib/toon-compressor');
21
+ * const compacto = comprimirSchema(schemaJSON);
22
+ * console.log(`Reducción: ${compacto.reduccionPorcentaje}%`);
23
+ *
24
+ * @module hooks/lib/toon-compressor
25
+ */
26
+
27
+ // ---------------------------------------------------------------------------
28
+ // Diccionario de abreviaciones para claves JSON Schema
29
+ // ---------------------------------------------------------------------------
30
+
31
+ /**
32
+ * Mapeo de claves largas a abreviaciones cortas.
33
+ * Solo para claves que aparecen ≥3 veces en un schema típico.
34
+ */
35
+ const ABREVIACIONES = {
36
+ description: 'desc',
37
+ properties: 'props',
38
+ required: 'req',
39
+ additionalProperties: 'addl',
40
+ type: 't',
41
+ items: 'it',
42
+ default: 'def',
43
+ enum: 'en',
44
+ maxLength: 'maxL',
45
+ minLength: 'minL',
46
+ minimum: 'min',
47
+ maximum: 'max',
48
+ pattern: 'pat',
49
+ oneOf: '1of',
50
+ anyOf: 'aof',
51
+ allOf: 'allof',
52
+ };
53
+
54
+ /** Mapeo inverso para descompresión. */
55
+ const ABREVIACIONES_INV = Object.fromEntries(
56
+ Object.entries(ABREVIACIONES).map(([k, v]) => [v, k])
57
+ );
58
+
59
+ // ---------------------------------------------------------------------------
60
+ // Funciones core
61
+ // ---------------------------------------------------------------------------
62
+
63
+ /**
64
+ * Comprime un objeto JSON Schema reemplazando claves por abreviaciones.
65
+ *
66
+ * @param {object} obj - Objeto a comprimir (se clona internamente)
67
+ * @returns {object} Objeto con claves abreviadas
68
+ */
69
+ function _abreviarClaves(obj) {
70
+ if (Array.isArray(obj)) {
71
+ return obj.map(_abreviarClaves);
72
+ }
73
+ if (obj !== null && typeof obj === 'object') {
74
+ const resultado = {};
75
+ for (const [clave, valor] of Object.entries(obj)) {
76
+ const claveCorta = ABREVIACIONES[clave] || clave;
77
+ resultado[claveCorta] = _abreviarClaves(valor);
78
+ }
79
+ return resultado;
80
+ }
81
+ return obj;
82
+ }
83
+
84
+ /**
85
+ * Descomprime un objeto con claves abreviadas a sus nombres originales.
86
+ *
87
+ * @param {object} obj - Objeto con claves abreviadas
88
+ * @returns {object} Objeto con claves originales
89
+ */
90
+ function _expandirClaves(obj) {
91
+ if (Array.isArray(obj)) {
92
+ return obj.map(_expandirClaves);
93
+ }
94
+ if (obj !== null && typeof obj === 'object') {
95
+ const resultado = {};
96
+ for (const [clave, valor] of Object.entries(obj)) {
97
+ const claveLarga = ABREVIACIONES_INV[clave] || clave;
98
+ resultado[claveLarga] = _expandirClaves(valor);
99
+ }
100
+ return resultado;
101
+ }
102
+ return obj;
103
+ }
104
+
105
+ /**
106
+ * Elimina campos opcionales con valor default conocido.
107
+ *
108
+ * @param {object} obj - Schema JSON
109
+ * @returns {object} Schema sin defaults redundantes
110
+ */
111
+ function _eliminarDefaults(obj) {
112
+ if (Array.isArray(obj)) {
113
+ return obj.map(_eliminarDefaults);
114
+ }
115
+ if (obj !== null && typeof obj === 'object') {
116
+ const resultado = {};
117
+ for (const [clave, valor] of Object.entries(obj)) {
118
+ // Eliminar additionalProperties: true (es el default)
119
+ if (clave === 'additionalProperties' && valor === true) continue;
120
+ // Eliminar required: [] (vacío = sin requeridos)
121
+ if (clave === 'required' && Array.isArray(valor) && valor.length === 0) continue;
122
+ // Eliminar description vacía
123
+ if (clave === 'description' && valor === '') continue;
124
+ resultado[clave] = _eliminarDefaults(valor);
125
+ }
126
+ return resultado;
127
+ }
128
+ return obj;
129
+ }
130
+
131
+ /**
132
+ * Colapsa descripciones multi-línea a una sola línea.
133
+ *
134
+ * @param {object} obj
135
+ * @returns {object}
136
+ */
137
+ function _colapsarDescripciones(obj) {
138
+ if (Array.isArray(obj)) {
139
+ return obj.map(_colapsarDescripciones);
140
+ }
141
+ if (obj !== null && typeof obj === 'object') {
142
+ const resultado = {};
143
+ for (const [clave, valor] of Object.entries(obj)) {
144
+ if (clave === 'description' && typeof valor === 'string') {
145
+ resultado[clave] = valor.replace(/\s+/g, ' ').trim();
146
+ } else {
147
+ resultado[clave] = _colapsarDescripciones(valor);
148
+ }
149
+ }
150
+ return resultado;
151
+ }
152
+ return obj;
153
+ }
154
+
155
+ // ---------------------------------------------------------------------------
156
+ // API pública
157
+ // ---------------------------------------------------------------------------
158
+
159
+ /**
160
+ * Comprime un JSON Schema aplicando todas las técnicas de reducción.
161
+ *
162
+ * @param {object|string} schema - JSON Schema (objeto o string JSON)
163
+ * @returns {{ comprimido: string, original: number, reducido: number, reduccionPorcentaje: number }}
164
+ */
165
+ function comprimirSchema(schema) {
166
+ const obj = typeof schema === 'string' ? JSON.parse(schema) : schema;
167
+ const original = JSON.stringify(obj);
168
+
169
+ let procesado = _eliminarDefaults(obj);
170
+ procesado = _colapsarDescripciones(procesado);
171
+ procesado = _abreviarClaves(procesado);
172
+
173
+ const comprimido = JSON.stringify(procesado);
174
+
175
+ const tamOriginal = original.length;
176
+ const tamReducido = comprimido.length;
177
+ const reduccion = ((tamOriginal - tamReducido) / tamOriginal) * 100;
178
+
179
+ return {
180
+ comprimido,
181
+ original: tamOriginal,
182
+ reducido: tamReducido,
183
+ reduccionPorcentaje: Math.round(reduccion * 10) / 10,
184
+ };
185
+ }
186
+
187
+ /**
188
+ * Descomprime un JSON Schema con claves abreviadas.
189
+ *
190
+ * @param {string|object} comprimido - Schema comprimido
191
+ * @returns {object} Schema original con claves expandidas
192
+ */
193
+ function descomprimirSchema(comprimido) {
194
+ const obj = typeof comprimido === 'string' ? JSON.parse(comprimido) : comprimido;
195
+ return _expandirClaves(obj);
196
+ }
197
+
198
+ /**
199
+ * Comprime texto Markdown eliminando redundancia para reducir tokens.
200
+ *
201
+ * Técnicas:
202
+ * - Colapsar múltiples líneas vacías a una
203
+ * - Eliminar trailing whitespace
204
+ * - Comprimir tablas (eliminar padding)
205
+ * - Eliminar comentarios HTML
206
+ *
207
+ * @param {string} texto - Texto Markdown
208
+ * @returns {{ comprimido: string, original: number, reducido: number, reduccionPorcentaje: number }}
209
+ */
210
+ function comprimirTexto(texto) {
211
+ const original = texto.length;
212
+
213
+ let resultado = texto;
214
+ // Colapsar 3+ líneas vacías a 2
215
+ resultado = resultado.replace(/\n{3,}/g, '\n\n');
216
+ // Eliminar trailing whitespace
217
+ resultado = resultado.replace(/[ \t]+$/gm, '');
218
+ // Eliminar comentarios HTML
219
+ resultado = resultado.replace(/<!--[\s\S]*?-->/g, '');
220
+ // Comprimir padding en tablas (múltiples espacios → uno)
221
+ resultado = resultado.replace(/\|[ \t]{2,}/g, '| ');
222
+ resultado = resultado.replace(/[ \t]{2,}\|/g, ' |');
223
+
224
+ const reducido = resultado.length;
225
+ const reduccion = ((original - reducido) / original) * 100;
226
+
227
+ return {
228
+ comprimido: resultado,
229
+ original,
230
+ reducido,
231
+ reduccionPorcentaje: Math.round(reduccion * 10) / 10,
232
+ };
233
+ }
234
+
235
+ // ---------------------------------------------------------------------------
236
+ // Exports
237
+ // ---------------------------------------------------------------------------
238
+
239
+ module.exports = {
240
+ comprimirSchema,
241
+ descomprimirSchema,
242
+ comprimirTexto,
243
+ // Exponer diccionario para tests
244
+ ABREVIACIONES,
245
+ };