@bemedev/codebase 1.2.1 → 1.3.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 +10 -16
- package/lib/functions/add.cjs +2 -3
- package/lib/functions/add.cjs.map +1 -1
- package/lib/functions/add.d.ts +1 -1
- package/lib/functions/add.d.ts.map +1 -1
- package/lib/functions/add.js +2 -3
- package/lib/functions/add.js.map +1 -1
- package/lib/functions/init.cjs +3 -17
- package/lib/functions/init.cjs.map +1 -1
- package/lib/functions/init.d.ts +1 -1
- package/lib/functions/init.d.ts.map +1 -1
- package/lib/functions/init.js +1 -15
- package/lib/functions/init.js.map +1 -1
- package/lib/functions/remove.cjs +2 -3
- package/lib/functions/remove.cjs.map +1 -1
- package/lib/functions/remove.d.ts +1 -1
- package/lib/functions/remove.d.ts.map +1 -1
- package/lib/functions/remove.js +2 -3
- package/lib/functions/remove.js.map +1 -1
- package/lib/imports.cjs +4 -1
- package/lib/imports.cjs.map +1 -1
- package/lib/imports.d.ts.map +1 -1
- package/lib/imports.js +4 -1
- package/lib/imports.js.map +1 -1
- package/lib/index.cjs +0 -2
- package/lib/index.d.ts +0 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +1 -2
- package/package.json +4 -4
- package/lib/config.cjs +0 -13
- package/lib/config.cjs.map +0 -1
- package/lib/config.d.ts +0 -8
- package/lib/config.d.ts.map +0 -1
- package/lib/config.js +0 -12
- package/lib/config.js.map +0 -1
package/README.md
CHANGED
|
@@ -102,24 +102,18 @@ init(analysis.CODEBASE_ANALYSIS, {
|
|
|
102
102
|
});
|
|
103
103
|
|
|
104
104
|
// Add files dynamically using regular slash-separated paths
|
|
105
|
-
add(
|
|
105
|
+
add(
|
|
106
|
+
analysis.CODEBASE_ANALYSIS,
|
|
107
|
+
'.project-codebase.json',
|
|
108
|
+
'nested/Tooltip',
|
|
109
|
+
);
|
|
106
110
|
|
|
107
111
|
// Remove files dynamically using regular slash-separated paths
|
|
108
|
-
remove(
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
You can also customize the global configuration used by the programmatic
|
|
114
|
-
API:
|
|
115
|
-
|
|
116
|
-
```typescript
|
|
117
|
-
import { config } from '@bemedev/codebase';
|
|
118
|
-
|
|
119
|
-
// Customize the configuration
|
|
120
|
-
config.json = '.my-custom-config.json';
|
|
121
|
-
config.tsConfigPath = '#custom/*';
|
|
122
|
-
config.codebase = '.my-custom-codebase.json';
|
|
112
|
+
remove(
|
|
113
|
+
analysis.CODEBASE_ANALYSIS,
|
|
114
|
+
'.project-codebase.json',
|
|
115
|
+
'nested/Tooltip',
|
|
116
|
+
);
|
|
123
117
|
```
|
|
124
118
|
|
|
125
119
|
## 📊 Output format
|
package/lib/functions/add.cjs
CHANGED
|
@@ -2,7 +2,6 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
|
2
2
|
const require_runtime = require("../_virtual/_rolldown/runtime.cjs");
|
|
3
3
|
const require_constants = require("../constants.cjs");
|
|
4
4
|
const require_helpers = require("../helpers.cjs");
|
|
5
|
-
const require_config = require("../config.cjs");
|
|
6
5
|
let path = require("path");
|
|
7
6
|
let edit_json_file = require("edit-json-file");
|
|
8
7
|
edit_json_file = require_runtime.__toESM(edit_json_file, 1);
|
|
@@ -35,11 +34,11 @@ const processFileAnalysis = (analysis, cwd, additionals, pathsEntries, files, CO
|
|
|
35
34
|
if (toAdd2.imports.length > 0) processFileAnalysis(toAdd2, cwd, additionals, pathsEntries, files, CODEBASE_ANALYSIS);
|
|
36
35
|
});
|
|
37
36
|
};
|
|
38
|
-
const add = (CODEBASE_ANALYSIS, ...paths) => {
|
|
37
|
+
const add = (CODEBASE_ANALYSIS, jsonConfigPath, ...paths) => {
|
|
39
38
|
if (paths.length === 0) return console.warn("No files specified for addition.");
|
|
40
39
|
try {
|
|
41
40
|
const cwd = process.cwd();
|
|
42
|
-
let file = (0, edit_json_file.default)((0, path.join)(cwd,
|
|
41
|
+
let file = (0, edit_json_file.default)((0, path.join)(cwd, jsonConfigPath));
|
|
43
42
|
if (!file) return;
|
|
44
43
|
const files = file.get(require_constants.FILES_PROPERTY);
|
|
45
44
|
const root = require_helpers.getFolderPath(file.get(require_constants.PATH_PROPERTY));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"add.cjs","names":["transformModule","
|
|
1
|
+
{"version":3,"file":"add.cjs","names":["transformModule","FILES_PROPERTY","getFolderPath","PATH_PROPERTY","writeFileAnalysis"],"sources":["../../src/functions/add.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { dirname, join, relative, resolve } from 'path';\nimport { FILES_PROPERTY, PATH_PROPERTY } from '../constants';\nimport {\n consoleStars,\n getFolderPath,\n transformModule,\n writeFileAnalysis,\n} from '../helpers';\nimport { CodebaseAnalysis, type FileAnalysis } from '../schemas';\nimport type { NOmit } from '../types';\n\nconst processFileAnalysis = (\n analysis: NOmit<FileAnalysis, 'exports'>,\n cwd: string,\n additionals: [string, NOmit<FileAnalysis, 'exports'>][],\n pathsEntries: [string, NOmit<FileAnalysis, 'exports'>][],\n files: string[],\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n) => {\n const relativePath = analysis.relativePath;\n\n const keys = Object.keys(CODEBASE_ANALYSIS);\n analysis.imports.forEach(({ moduleSpecifier }) => {\n const _path = relative(\n cwd,\n resolve(dirname(relativePath), moduleSpecifier),\n );\n\n const all = additionals\n .concat(pathsEntries)\n .map(([key]) => key)\n .concat(files);\n\n const canAdd = all.every(p => p !== _path);\n if (!canAdd) return;\n\n const toAdd =\n CODEBASE_ANALYSIS[_path] ?? CODEBASE_ANALYSIS[`${_path}.index`];\n if (!toAdd) return;\n\n additionals.push([_path, toAdd]);\n all.push(_path);\n\n const imports = toAdd.imports.filter(({ moduleSpecifier }) => {\n const _path = transformModule({\n cwd,\n relativePath: toAdd.relativePath,\n moduleSpecifier,\n });\n\n const array = [_path, `${_path}.index`].filter(p =>\n keys.includes(p),\n );\n\n if (array.length < 1) return false;\n\n return array.every(p => !all.includes(p));\n });\n\n const toAdd2 = { ...toAdd, imports };\n const canRecurse = toAdd2.imports.length > 0;\n\n if (canRecurse) {\n processFileAnalysis(\n toAdd2,\n cwd,\n additionals,\n pathsEntries,\n files,\n CODEBASE_ANALYSIS,\n );\n }\n });\n};\n\nexport const add = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n jsonConfigPath: string,\n ...paths: string[]\n) => {\n const isEmpty = paths.length === 0;\n if (isEmpty) return console.warn('No files specified for addition.');\n try {\n const cwd = process.cwd();\n const json = join(cwd, jsonConfigPath);\n let file: JsonEditor | undefined = edit(json);\n\n if (!file) return;\n\n const files = file.get(FILES_PROPERTY) as string[];\n const root = getFolderPath(file.get(PATH_PROPERTY) as string);\n\n // Release resources\n\n const additionals: [string, NOmit<FileAnalysis, 'exports'>][] = [];\n\n const pathsEntries = Object.entries(CODEBASE_ANALYSIS)\n .filter(([key]) => paths.some(p => key.startsWith(p)))\n .filter(([key]) => !files.includes(key));\n\n pathsEntries.forEach(([, analysis]) => {\n processFileAnalysis(\n analysis,\n cwd,\n additionals,\n pathsEntries,\n files,\n CODEBASE_ANALYSIS,\n );\n });\n\n const entries = new Set(\n pathsEntries.concat(additionals).filter(([, val]) => !!val),\n );\n\n consoleStars();\n console.log(`🔧 Creation of files (${entries.size} files)...`);\n\n let success = 0;\n const length = entries.size;\n\n entries.forEach(([, fileAnalysis]) => {\n const _path = writeFileAnalysis(fileAnalysis, root);\n if (_path) {\n files.push(_path);\n success++;\n }\n });\n\n file.set(FILES_PROPERTY, files);\n file.save();\n console.log(`✅ Files created! (${success}/${length})`);\n file = undefined;\n } catch {\n console.error(`❌ Error during file creation`);\n return false;\n }\n\n consoleStars();\n return true;\n};\n"],"mappings":";;;;;;;;AAYA,MAAM,uBACJ,UACA,KACA,aACA,cACA,OACA,sBACG;CACH,MAAM,eAAe,SAAS;CAE9B,MAAM,OAAO,OAAO,KAAK,iBAAiB;CAC1C,SAAS,QAAQ,SAAS,EAAE,sBAAsB;EAChD,MAAM,SAAA,GAAA,KAAA,SAAA,CACJ,MAAA,GAAA,KAAA,QAAA,EAAA,GAAA,KAAA,QAAA,CACgB,YAAY,GAAG,eAAe,CAChD;EAEA,MAAM,MAAM,YACT,OAAO,YAAY,CAAC,CACpB,KAAK,CAAC,SAAS,GAAG,CAAC,CACnB,OAAO,KAAK;EAGf,IAAI,CADW,IAAI,OAAM,MAAK,MAAM,KAC1B,GAAG;EAEb,MAAM,QACJ,kBAAkB,UAAU,kBAAkB,GAAG,MAAM;EACzD,IAAI,CAAC,OAAO;EAEZ,YAAY,KAAK,CAAC,OAAO,KAAK,CAAC;EAC/B,IAAI,KAAK,KAAK;EAEd,MAAM,UAAU,MAAM,QAAQ,QAAQ,EAAE,sBAAsB;GAC5D,MAAM,QAAQA,gBAAAA,gBAAgB;IAC5B;IACA,cAAc,MAAM;IACpB;GACF,CAAC;GAED,MAAM,QAAQ,CAAC,OAAO,GAAG,MAAM,OAAO,CAAC,CAAC,QAAO,MAC7C,KAAK,SAAS,CAAC,CACjB;GAEA,IAAI,MAAM,SAAS,GAAG,OAAO;GAE7B,OAAO,MAAM,OAAM,MAAK,CAAC,IAAI,SAAS,CAAC,CAAC;EAC1C,CAAC;EAED,MAAM,SAAS;GAAE,GAAG;GAAO;EAAQ;EAGnC,IAFmB,OAAO,QAAQ,SAAS,GAGzC,oBACE,QACA,KACA,aACA,cACA,OACA,iBACF;CAEJ,CAAC;AACH;AAEA,MAAa,OACX,mBACA,gBACA,GAAG,UACA;CAEH,IADgB,MAAM,WAAW,GACpB,OAAO,QAAQ,KAAK,kCAAkC;CACnE,IAAI;EACF,MAAM,MAAM,QAAQ,IAAI;EAExB,IAAI,QAAA,GAAA,eAAA,QAAA,EAAA,GAAA,KAAA,KAAA,CADc,KAAK,cACoB,CAAC;EAE5C,IAAI,CAAC,MAAM;EAEX,MAAM,QAAQ,KAAK,IAAIC,kBAAAA,cAAc;EACrC,MAAM,OAAOC,gBAAAA,cAAc,KAAK,IAAIC,kBAAAA,aAAa,CAAW;EAI5D,MAAM,cAA0D,CAAC;EAEjE,MAAM,eAAe,OAAO,QAAQ,iBAAiB,CAAC,CACnD,QAAQ,CAAC,SAAS,MAAM,MAAK,MAAK,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,CACrD,QAAQ,CAAC,SAAS,CAAC,MAAM,SAAS,GAAG,CAAC;EAEzC,aAAa,SAAS,GAAG,cAAc;GACrC,oBACE,UACA,KACA,aACA,cACA,OACA,iBACF;EACF,CAAC;EAED,MAAM,UAAU,IAAI,IAClB,aAAa,OAAO,WAAW,CAAC,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,GAAG,CAC5D;EAEA,gBAAA,aAAa;EACb,QAAQ,IAAI,yBAAyB,QAAQ,KAAK,WAAW;EAE7D,IAAI,UAAU;EACd,MAAM,SAAS,QAAQ;EAEvB,QAAQ,SAAS,GAAG,kBAAkB;GACpC,MAAM,QAAQC,gBAAAA,kBAAkB,cAAc,IAAI;GAClD,IAAI,OAAO;IACT,MAAM,KAAK,KAAK;IAChB;GACF;EACF,CAAC;EAED,KAAK,IAAIH,kBAAAA,gBAAgB,KAAK;EAC9B,KAAK,KAAK;EACV,QAAQ,IAAI,qBAAqB,QAAQ,GAAG,OAAO,EAAE;EACrD,OAAO,KAAA;CACT,QAAQ;EACN,QAAQ,MAAM,8BAA8B;EAC5C,OAAO;CACT;CAEA,gBAAA,aAAa;CACb,OAAO;AACT"}
|
package/lib/functions/add.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { CodebaseAnalysis } from '../schemas';
|
|
2
|
-
export declare const add: (CODEBASE_ANALYSIS: CodebaseAnalysis, ...paths: string[]) => boolean | void;
|
|
2
|
+
export declare const add: (CODEBASE_ANALYSIS: CodebaseAnalysis, jsonConfigPath: string, ...paths: string[]) => boolean | void;
|
|
3
3
|
//# sourceMappingURL=add.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"add.d.ts","sourceRoot":"","sources":["../../src/functions/add.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"add.d.ts","sourceRoot":"","sources":["../../src/functions/add.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,gBAAgB,EAAqB,MAAM,YAAY,CAAC;AAmEjE,eAAO,MAAM,GAAG,GACd,mBAAmB,gBAAgB,EACnC,gBAAgB,MAAM,EACtB,GAAG,OAAO,MAAM,EAAE,mBA8DnB,CAAC"}
|
package/lib/functions/add.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { FILES_PROPERTY, PATH_PROPERTY } from "../constants.js";
|
|
2
2
|
import { consoleStars, getFolderPath, transformModule, writeFileAnalysis } from "../helpers.js";
|
|
3
|
-
import { config } from "../config.js";
|
|
4
3
|
import { dirname, join, relative, resolve } from "path";
|
|
5
4
|
import edit from "edit-json-file";
|
|
6
5
|
//#region src/functions/add.ts
|
|
@@ -32,11 +31,11 @@ const processFileAnalysis = (analysis, cwd, additionals, pathsEntries, files, CO
|
|
|
32
31
|
if (toAdd2.imports.length > 0) processFileAnalysis(toAdd2, cwd, additionals, pathsEntries, files, CODEBASE_ANALYSIS);
|
|
33
32
|
});
|
|
34
33
|
};
|
|
35
|
-
const add = (CODEBASE_ANALYSIS, ...paths) => {
|
|
34
|
+
const add = (CODEBASE_ANALYSIS, jsonConfigPath, ...paths) => {
|
|
36
35
|
if (paths.length === 0) return console.warn("No files specified for addition.");
|
|
37
36
|
try {
|
|
38
37
|
const cwd = process.cwd();
|
|
39
|
-
let file = edit(join(cwd,
|
|
38
|
+
let file = edit(join(cwd, jsonConfigPath));
|
|
40
39
|
if (!file) return;
|
|
41
40
|
const files = file.get(FILES_PROPERTY);
|
|
42
41
|
const root = getFolderPath(file.get(PATH_PROPERTY));
|
package/lib/functions/add.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"add.js","names":[],"sources":["../../src/functions/add.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { dirname, join, relative, resolve } from 'path';\nimport {
|
|
1
|
+
{"version":3,"file":"add.js","names":[],"sources":["../../src/functions/add.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { dirname, join, relative, resolve } from 'path';\nimport { FILES_PROPERTY, PATH_PROPERTY } from '../constants';\nimport {\n consoleStars,\n getFolderPath,\n transformModule,\n writeFileAnalysis,\n} from '../helpers';\nimport { CodebaseAnalysis, type FileAnalysis } from '../schemas';\nimport type { NOmit } from '../types';\n\nconst processFileAnalysis = (\n analysis: NOmit<FileAnalysis, 'exports'>,\n cwd: string,\n additionals: [string, NOmit<FileAnalysis, 'exports'>][],\n pathsEntries: [string, NOmit<FileAnalysis, 'exports'>][],\n files: string[],\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n) => {\n const relativePath = analysis.relativePath;\n\n const keys = Object.keys(CODEBASE_ANALYSIS);\n analysis.imports.forEach(({ moduleSpecifier }) => {\n const _path = relative(\n cwd,\n resolve(dirname(relativePath), moduleSpecifier),\n );\n\n const all = additionals\n .concat(pathsEntries)\n .map(([key]) => key)\n .concat(files);\n\n const canAdd = all.every(p => p !== _path);\n if (!canAdd) return;\n\n const toAdd =\n CODEBASE_ANALYSIS[_path] ?? CODEBASE_ANALYSIS[`${_path}.index`];\n if (!toAdd) return;\n\n additionals.push([_path, toAdd]);\n all.push(_path);\n\n const imports = toAdd.imports.filter(({ moduleSpecifier }) => {\n const _path = transformModule({\n cwd,\n relativePath: toAdd.relativePath,\n moduleSpecifier,\n });\n\n const array = [_path, `${_path}.index`].filter(p =>\n keys.includes(p),\n );\n\n if (array.length < 1) return false;\n\n return array.every(p => !all.includes(p));\n });\n\n const toAdd2 = { ...toAdd, imports };\n const canRecurse = toAdd2.imports.length > 0;\n\n if (canRecurse) {\n processFileAnalysis(\n toAdd2,\n cwd,\n additionals,\n pathsEntries,\n files,\n CODEBASE_ANALYSIS,\n );\n }\n });\n};\n\nexport const add = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n jsonConfigPath: string,\n ...paths: string[]\n) => {\n const isEmpty = paths.length === 0;\n if (isEmpty) return console.warn('No files specified for addition.');\n try {\n const cwd = process.cwd();\n const json = join(cwd, jsonConfigPath);\n let file: JsonEditor | undefined = edit(json);\n\n if (!file) return;\n\n const files = file.get(FILES_PROPERTY) as string[];\n const root = getFolderPath(file.get(PATH_PROPERTY) as string);\n\n // Release resources\n\n const additionals: [string, NOmit<FileAnalysis, 'exports'>][] = [];\n\n const pathsEntries = Object.entries(CODEBASE_ANALYSIS)\n .filter(([key]) => paths.some(p => key.startsWith(p)))\n .filter(([key]) => !files.includes(key));\n\n pathsEntries.forEach(([, analysis]) => {\n processFileAnalysis(\n analysis,\n cwd,\n additionals,\n pathsEntries,\n files,\n CODEBASE_ANALYSIS,\n );\n });\n\n const entries = new Set(\n pathsEntries.concat(additionals).filter(([, val]) => !!val),\n );\n\n consoleStars();\n console.log(`🔧 Creation of files (${entries.size} files)...`);\n\n let success = 0;\n const length = entries.size;\n\n entries.forEach(([, fileAnalysis]) => {\n const _path = writeFileAnalysis(fileAnalysis, root);\n if (_path) {\n files.push(_path);\n success++;\n }\n });\n\n file.set(FILES_PROPERTY, files);\n file.save();\n console.log(`✅ Files created! (${success}/${length})`);\n file = undefined;\n } catch {\n console.error(`❌ Error during file creation`);\n return false;\n }\n\n consoleStars();\n return true;\n};\n"],"mappings":";;;;;AAYA,MAAM,uBACJ,UACA,KACA,aACA,cACA,OACA,sBACG;CACH,MAAM,eAAe,SAAS;CAE9B,MAAM,OAAO,OAAO,KAAK,iBAAiB;CAC1C,SAAS,QAAQ,SAAS,EAAE,sBAAsB;EAChD,MAAM,QAAQ,SACZ,KACA,QAAQ,QAAQ,YAAY,GAAG,eAAe,CAChD;EAEA,MAAM,MAAM,YACT,OAAO,YAAY,CAAC,CACpB,KAAK,CAAC,SAAS,GAAG,CAAC,CACnB,OAAO,KAAK;EAGf,IAAI,CADW,IAAI,OAAM,MAAK,MAAM,KAC1B,GAAG;EAEb,MAAM,QACJ,kBAAkB,UAAU,kBAAkB,GAAG,MAAM;EACzD,IAAI,CAAC,OAAO;EAEZ,YAAY,KAAK,CAAC,OAAO,KAAK,CAAC;EAC/B,IAAI,KAAK,KAAK;EAEd,MAAM,UAAU,MAAM,QAAQ,QAAQ,EAAE,sBAAsB;GAC5D,MAAM,QAAQ,gBAAgB;IAC5B;IACA,cAAc,MAAM;IACpB;GACF,CAAC;GAED,MAAM,QAAQ,CAAC,OAAO,GAAG,MAAM,OAAO,CAAC,CAAC,QAAO,MAC7C,KAAK,SAAS,CAAC,CACjB;GAEA,IAAI,MAAM,SAAS,GAAG,OAAO;GAE7B,OAAO,MAAM,OAAM,MAAK,CAAC,IAAI,SAAS,CAAC,CAAC;EAC1C,CAAC;EAED,MAAM,SAAS;GAAE,GAAG;GAAO;EAAQ;EAGnC,IAFmB,OAAO,QAAQ,SAAS,GAGzC,oBACE,QACA,KACA,aACA,cACA,OACA,iBACF;CAEJ,CAAC;AACH;AAEA,MAAa,OACX,mBACA,gBACA,GAAG,UACA;CAEH,IADgB,MAAM,WAAW,GACpB,OAAO,QAAQ,KAAK,kCAAkC;CACnE,IAAI;EACF,MAAM,MAAM,QAAQ,IAAI;EAExB,IAAI,OAA+B,KADtB,KAAK,KAAK,cACoB,CAAC;EAE5C,IAAI,CAAC,MAAM;EAEX,MAAM,QAAQ,KAAK,IAAI,cAAc;EACrC,MAAM,OAAO,cAAc,KAAK,IAAI,aAAa,CAAW;EAI5D,MAAM,cAA0D,CAAC;EAEjE,MAAM,eAAe,OAAO,QAAQ,iBAAiB,CAAC,CACnD,QAAQ,CAAC,SAAS,MAAM,MAAK,MAAK,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,CACrD,QAAQ,CAAC,SAAS,CAAC,MAAM,SAAS,GAAG,CAAC;EAEzC,aAAa,SAAS,GAAG,cAAc;GACrC,oBACE,UACA,KACA,aACA,cACA,OACA,iBACF;EACF,CAAC;EAED,MAAM,UAAU,IAAI,IAClB,aAAa,OAAO,WAAW,CAAC,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC,GAAG,CAC5D;EAEA,aAAa;EACb,QAAQ,IAAI,yBAAyB,QAAQ,KAAK,WAAW;EAE7D,IAAI,UAAU;EACd,MAAM,SAAS,QAAQ;EAEvB,QAAQ,SAAS,GAAG,kBAAkB;GACpC,MAAM,QAAQ,kBAAkB,cAAc,IAAI;GAClD,IAAI,OAAO;IACT,MAAM,KAAK,KAAK;IAChB;GACF;EACF,CAAC;EAED,KAAK,IAAI,gBAAgB,KAAK;EAC9B,KAAK,KAAK;EACV,QAAQ,IAAI,qBAAqB,QAAQ,GAAG,OAAO,EAAE;EACrD,OAAO,KAAA;CACT,QAAQ;EACN,QAAQ,MAAM,8BAA8B;EAC5C,OAAO;CACT;CAEA,aAAa;CACb,OAAO;AACT"}
|
package/lib/functions/init.cjs
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
2
|
const require_constants = require("../constants.cjs");
|
|
3
3
|
const require_helpers = require("../helpers.cjs");
|
|
4
|
-
const require_config = require("../config.cjs");
|
|
5
4
|
let path = require("path");
|
|
6
5
|
let fs = require("fs");
|
|
7
6
|
//#region src/functions/init.ts
|
|
@@ -18,20 +17,7 @@ const createTypesStructure = (folderPath, CODEBASE_ANALYSIS) => {
|
|
|
18
17
|
console.log(`✅ Types structure successfully created!`);
|
|
19
18
|
return PATHS;
|
|
20
19
|
};
|
|
21
|
-
const
|
|
22
|
-
require_config.config.bin = bin;
|
|
23
|
-
require_config.config.json = json;
|
|
24
|
-
require_config.config.tsConfigPath = path$1;
|
|
25
|
-
require_config.config.root = root;
|
|
26
|
-
return {
|
|
27
|
-
root,
|
|
28
|
-
json,
|
|
29
|
-
path: path$1,
|
|
30
|
-
bin
|
|
31
|
-
};
|
|
32
|
-
};
|
|
33
|
-
const init = (CODEBASE_ANALYSIS, options) => {
|
|
34
|
-
const { root, json, path: path$2, bin } = initConfig(options);
|
|
20
|
+
const init = (CODEBASE_ANALYSIS, { root, json, path: path$1 = require_constants.DEFAULT_PATH_KEY, bin = require_constants.DEFAULT_CLI_NAME }) => {
|
|
35
21
|
const cwd = process.cwd();
|
|
36
22
|
const configFile = (0, path.join)(cwd, json);
|
|
37
23
|
if ((0, fs.existsSync)(configFile)) return true;
|
|
@@ -57,9 +43,9 @@ const init = (CODEBASE_ANALYSIS, options) => {
|
|
|
57
43
|
if (!tsconfig.compilerOptions) tsconfig.compilerOptions = {};
|
|
58
44
|
if (!tsconfig.compilerOptions.paths) tsconfig.compilerOptions.paths = {};
|
|
59
45
|
const relativePath = (0, path.relative)(process.cwd(), folderPath);
|
|
60
|
-
tsconfig.compilerOptions.paths[path$
|
|
46
|
+
tsconfig.compilerOptions.paths[path$1] = [`./${relativePath}/*`];
|
|
61
47
|
(0, fs.writeFileSync)(tsconfigPath, JSON.stringify(tsconfig, null, 2), "utf8");
|
|
62
|
-
console.log(`✅ Path ${path$
|
|
48
|
+
console.log(`✅ Path ${path$1} added to tsconfig.json`);
|
|
63
49
|
} catch (error) {
|
|
64
50
|
console.error(`❌ Error updating tsconfig.json:`, error);
|
|
65
51
|
return false;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.cjs","names":["writeFileAnalysis","DEFAULT_PATH_KEY","DEFAULT_CLI_NAME","
|
|
1
|
+
{"version":3,"file":"init.cjs","names":["writeFileAnalysis","DEFAULT_PATH_KEY","DEFAULT_CLI_NAME","getFolderPath","path","PROPERTIES"],"sources":["../../src/functions/init.ts"],"sourcesContent":["import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';\nimport { join, relative } from 'path';\nimport {\n DEFAULT_CLI_NAME,\n DEFAULT_PATH_KEY,\n PROPERTIES,\n} from '../constants';\nimport { getFolderPath, writeFileAnalysis } from '../helpers';\nimport { CodebaseAnalysis } from '../schemas';\n\nexport interface InitOptions {\n /**\n * Custom location for the .bemedev folder\n * Default: 'src/.bemedev' if src exists, otherwise '.bemedev' at the root\n */\n root: string;\n json: string;\n path?: string;\n bin?: string;\n}\n\nexport const createTypesStructure = (\n folderPath: string,\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n) => {\n const entries = Object.entries(CODEBASE_ANALYSIS).filter(([key]) => {\n return key.endsWith('types') || key.endsWith('constants');\n });\n\n const PATHS: string[] = [];\n\n console.log(\n `🔧 Creating types structure (${entries.length} files)...`,\n );\n\n for (const [, fileAnalysis] of entries) {\n const file = writeFileAnalysis(fileAnalysis, folderPath);\n if (file) PATHS.push(file);\n }\n\n console.log(`✅ Types structure successfully created!`);\n return PATHS;\n};\n\nexport const init = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n {\n root,\n json,\n path = DEFAULT_PATH_KEY,\n bin = DEFAULT_CLI_NAME,\n }: InitOptions,\n) => {\n const cwd = process.cwd();\n const configFile = join(cwd, json);\n const configExists = existsSync(configFile);\n if (configExists) return true;\n const folderPath = getFolderPath(root);\n\n // 1. Create the folder\n try {\n mkdirSync(folderPath, { recursive: true });\n console.log(`✅ Folder ${bin} created in: ${root}`);\n } catch (error) {\n console.error(`❌ Error creating the folder ${bin}:`, error);\n return false;\n }\n\n // eslint-disable-next-line no-useless-assignment\n let files: string[] = [];\n // 1.5. Create the types files structure\n try {\n files = createTypesStructure(folderPath, CODEBASE_ANALYSIS);\n } catch {\n console.error(`❌ Error creating the types structure:`);\n return false;\n }\n\n // 2. Update tsconfig.json\n const tsconfigPath = join(cwd, 'tsconfig.json');\n\n if (existsSync(tsconfigPath)) {\n try {\n const tsconfigContent = readFileSync(tsconfigPath, 'utf8');\n const tsconfig = JSON.parse(tsconfigContent);\n\n // Initialize compilerOptions and paths if they do not exist\n if (!tsconfig.compilerOptions) {\n tsconfig.compilerOptions = {};\n }\n\n if (!tsconfig.compilerOptions.paths) {\n tsconfig.compilerOptions.paths = {};\n }\n\n // Add the path #bemedev/*\n const relativePath = relative(process.cwd(), folderPath);\n\n tsconfig.compilerOptions.paths[path] = [`./${relativePath}/*`];\n\n writeFileSync(\n tsconfigPath,\n JSON.stringify(tsconfig, null, 2),\n 'utf8',\n );\n console.log(`✅ Path ${path} added to tsconfig.json`);\n } catch (error) {\n console.error(`❌ Error updating tsconfig.json:`, error);\n return false;\n }\n } else {\n console.warn(`⚠️ File tsconfig.json not found, path not added`);\n }\n\n // 3. Create the .bemedev.json file at the root\n\n const jsonConfig = {\n version: '1.0.0',\n [PROPERTIES.PATH]: root,\n [PROPERTIES.FILES]: files,\n };\n\n try {\n writeFileSync(\n configFile,\n JSON.stringify(jsonConfig, null, 2),\n 'utf8',\n );\n console.log(`✅ File ${json} created at the root of the project`);\n } catch (error) {\n console.error(`❌ Error creating the file ${json}:`, error);\n return false;\n }\n\n console.log(`🎉 Bemedev initialization completed successfully!`);\n return true;\n};\n"],"mappings":";;;;;;AAqBA,MAAa,wBACX,YACA,sBACG;CACH,MAAM,UAAU,OAAO,QAAQ,iBAAiB,CAAC,CAAC,QAAQ,CAAC,SAAS;EAClE,OAAO,IAAI,SAAS,OAAO,KAAK,IAAI,SAAS,WAAW;CAC1D,CAAC;CAED,MAAM,QAAkB,CAAC;CAEzB,QAAQ,IACN,gCAAgC,QAAQ,OAAO,WACjD;CAEA,KAAK,MAAM,GAAG,iBAAiB,SAAS;EACtC,MAAM,OAAOA,gBAAAA,kBAAkB,cAAc,UAAU;EACvD,IAAI,MAAM,MAAM,KAAK,IAAI;CAC3B;CAEA,QAAQ,IAAI,yCAAyC;CACrD,OAAO;AACT;AAEA,MAAa,QACX,mBACA,EACE,MACA,MACA,MAAA,SAAOC,kBAAAA,kBACP,MAAMC,kBAAAA,uBAEL;CACH,MAAM,MAAM,QAAQ,IAAI;CACxB,MAAM,cAAA,GAAA,KAAA,KAAA,CAAkB,KAAK,IAAI;CAEjC,KAAA,GAAA,GAAA,WAAA,CADgC,UACjB,GAAG,OAAO;CACzB,MAAM,aAAaC,gBAAAA,cAAc,IAAI;CAGrC,IAAI;EACF,CAAA,GAAA,GAAA,UAAA,CAAU,YAAY,EAAE,WAAW,KAAK,CAAC;EACzC,QAAQ,IAAI,YAAY,IAAI,eAAe,MAAM;CACnD,SAAS,OAAO;EACd,QAAQ,MAAM,+BAA+B,IAAI,IAAI,KAAK;EAC1D,OAAO;CACT;CAGA,IAAI,QAAkB,CAAC;CAEvB,IAAI;EACF,QAAQ,qBAAqB,YAAY,iBAAiB;CAC5D,QAAQ;EACN,QAAQ,MAAM,uCAAuC;EACrD,OAAO;CACT;CAGA,MAAM,gBAAA,GAAA,KAAA,KAAA,CAAoB,KAAK,eAAe;CAE9C,KAAA,GAAA,GAAA,WAAA,CAAe,YAAY,GACzB,IAAI;EACF,MAAM,mBAAA,GAAA,GAAA,aAAA,CAA+B,cAAc,MAAM;EACzD,MAAM,WAAW,KAAK,MAAM,eAAe;EAG3C,IAAI,CAAC,SAAS,iBACZ,SAAS,kBAAkB,CAAC;EAG9B,IAAI,CAAC,SAAS,gBAAgB,OAC5B,SAAS,gBAAgB,QAAQ,CAAC;EAIpC,MAAM,gBAAA,GAAA,KAAA,SAAA,CAAwB,QAAQ,IAAI,GAAG,UAAU;EAEvD,SAAS,gBAAgB,MAAMC,UAAQ,CAAC,KAAK,aAAa,GAAG;EAE7D,CAAA,GAAA,GAAA,cAAA,CACE,cACA,KAAK,UAAU,UAAU,MAAM,CAAC,GAChC,MACF;EACA,QAAQ,IAAI,UAAUA,OAAK,wBAAwB;CACrD,SAAS,OAAO;EACd,QAAQ,MAAM,mCAAmC,KAAK;EACtD,OAAO;CACT;MAEA,QAAQ,KAAK,iDAAiD;CAKhE,MAAM,aAAa;EACjB,SAAS;GACRC,kBAAAA,WAAW,OAAO;GAClBA,kBAAAA,WAAW,QAAQ;CACtB;CAEA,IAAI;EACF,CAAA,GAAA,GAAA,cAAA,CACE,YACA,KAAK,UAAU,YAAY,MAAM,CAAC,GAClC,MACF;EACA,QAAQ,IAAI,UAAU,KAAK,oCAAoC;CACjE,SAAS,OAAO;EACd,QAAQ,MAAM,6BAA6B,KAAK,IAAI,KAAK;EACzD,OAAO;CACT;CAEA,QAAQ,IAAI,mDAAmD;CAC/D,OAAO;AACT"}
|
package/lib/functions/init.d.ts
CHANGED
|
@@ -10,5 +10,5 @@ export interface InitOptions {
|
|
|
10
10
|
bin?: string;
|
|
11
11
|
}
|
|
12
12
|
export declare const createTypesStructure: (folderPath: string, CODEBASE_ANALYSIS: CodebaseAnalysis) => string[];
|
|
13
|
-
export declare const init: (CODEBASE_ANALYSIS: CodebaseAnalysis,
|
|
13
|
+
export declare const init: (CODEBASE_ANALYSIS: CodebaseAnalysis, { root, json, path, bin, }: InitOptions) => boolean;
|
|
14
14
|
//# sourceMappingURL=init.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/functions/init.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/functions/init.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,MAAM,WAAW,WAAW;IAC1B;;;OAGG;IACH,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED,eAAO,MAAM,oBAAoB,GAC/B,YAAY,MAAM,EAClB,mBAAmB,gBAAgB,aAmBpC,CAAC;AAEF,eAAO,MAAM,IAAI,GACf,mBAAmB,gBAAgB,EACnC,4BAKG,WAAW,YAqFf,CAAC"}
|
package/lib/functions/init.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { DEFAULT_CLI_NAME, DEFAULT_PATH_KEY, PROPERTIES } from "../constants.js";
|
|
2
2
|
import { getFolderPath, writeFileAnalysis } from "../helpers.js";
|
|
3
|
-
import { config } from "../config.js";
|
|
4
3
|
import { join, relative } from "path";
|
|
5
4
|
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "fs";
|
|
6
5
|
//#region src/functions/init.ts
|
|
@@ -17,20 +16,7 @@ const createTypesStructure = (folderPath, CODEBASE_ANALYSIS) => {
|
|
|
17
16
|
console.log(`✅ Types structure successfully created!`);
|
|
18
17
|
return PATHS;
|
|
19
18
|
};
|
|
20
|
-
const
|
|
21
|
-
config.bin = bin;
|
|
22
|
-
config.json = json;
|
|
23
|
-
config.tsConfigPath = path;
|
|
24
|
-
config.root = root;
|
|
25
|
-
return {
|
|
26
|
-
root,
|
|
27
|
-
json,
|
|
28
|
-
path,
|
|
29
|
-
bin
|
|
30
|
-
};
|
|
31
|
-
};
|
|
32
|
-
const init = (CODEBASE_ANALYSIS, options) => {
|
|
33
|
-
const { root, json, path, bin } = initConfig(options);
|
|
19
|
+
const init = (CODEBASE_ANALYSIS, { root, json, path = DEFAULT_PATH_KEY, bin = DEFAULT_CLI_NAME }) => {
|
|
34
20
|
const cwd = process.cwd();
|
|
35
21
|
const configFile = join(cwd, json);
|
|
36
22
|
if (existsSync(configFile)) return true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","names":[],"sources":["../../src/functions/init.ts"],"sourcesContent":["import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';\nimport { join, relative } from 'path';\nimport {
|
|
1
|
+
{"version":3,"file":"init.js","names":[],"sources":["../../src/functions/init.ts"],"sourcesContent":["import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';\nimport { join, relative } from 'path';\nimport {\n DEFAULT_CLI_NAME,\n DEFAULT_PATH_KEY,\n PROPERTIES,\n} from '../constants';\nimport { getFolderPath, writeFileAnalysis } from '../helpers';\nimport { CodebaseAnalysis } from '../schemas';\n\nexport interface InitOptions {\n /**\n * Custom location for the .bemedev folder\n * Default: 'src/.bemedev' if src exists, otherwise '.bemedev' at the root\n */\n root: string;\n json: string;\n path?: string;\n bin?: string;\n}\n\nexport const createTypesStructure = (\n folderPath: string,\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n) => {\n const entries = Object.entries(CODEBASE_ANALYSIS).filter(([key]) => {\n return key.endsWith('types') || key.endsWith('constants');\n });\n\n const PATHS: string[] = [];\n\n console.log(\n `🔧 Creating types structure (${entries.length} files)...`,\n );\n\n for (const [, fileAnalysis] of entries) {\n const file = writeFileAnalysis(fileAnalysis, folderPath);\n if (file) PATHS.push(file);\n }\n\n console.log(`✅ Types structure successfully created!`);\n return PATHS;\n};\n\nexport const init = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n {\n root,\n json,\n path = DEFAULT_PATH_KEY,\n bin = DEFAULT_CLI_NAME,\n }: InitOptions,\n) => {\n const cwd = process.cwd();\n const configFile = join(cwd, json);\n const configExists = existsSync(configFile);\n if (configExists) return true;\n const folderPath = getFolderPath(root);\n\n // 1. Create the folder\n try {\n mkdirSync(folderPath, { recursive: true });\n console.log(`✅ Folder ${bin} created in: ${root}`);\n } catch (error) {\n console.error(`❌ Error creating the folder ${bin}:`, error);\n return false;\n }\n\n // eslint-disable-next-line no-useless-assignment\n let files: string[] = [];\n // 1.5. Create the types files structure\n try {\n files = createTypesStructure(folderPath, CODEBASE_ANALYSIS);\n } catch {\n console.error(`❌ Error creating the types structure:`);\n return false;\n }\n\n // 2. Update tsconfig.json\n const tsconfigPath = join(cwd, 'tsconfig.json');\n\n if (existsSync(tsconfigPath)) {\n try {\n const tsconfigContent = readFileSync(tsconfigPath, 'utf8');\n const tsconfig = JSON.parse(tsconfigContent);\n\n // Initialize compilerOptions and paths if they do not exist\n if (!tsconfig.compilerOptions) {\n tsconfig.compilerOptions = {};\n }\n\n if (!tsconfig.compilerOptions.paths) {\n tsconfig.compilerOptions.paths = {};\n }\n\n // Add the path #bemedev/*\n const relativePath = relative(process.cwd(), folderPath);\n\n tsconfig.compilerOptions.paths[path] = [`./${relativePath}/*`];\n\n writeFileSync(\n tsconfigPath,\n JSON.stringify(tsconfig, null, 2),\n 'utf8',\n );\n console.log(`✅ Path ${path} added to tsconfig.json`);\n } catch (error) {\n console.error(`❌ Error updating tsconfig.json:`, error);\n return false;\n }\n } else {\n console.warn(`⚠️ File tsconfig.json not found, path not added`);\n }\n\n // 3. Create the .bemedev.json file at the root\n\n const jsonConfig = {\n version: '1.0.0',\n [PROPERTIES.PATH]: root,\n [PROPERTIES.FILES]: files,\n };\n\n try {\n writeFileSync(\n configFile,\n JSON.stringify(jsonConfig, null, 2),\n 'utf8',\n );\n console.log(`✅ File ${json} created at the root of the project`);\n } catch (error) {\n console.error(`❌ Error creating the file ${json}:`, error);\n return false;\n }\n\n console.log(`🎉 Bemedev initialization completed successfully!`);\n return true;\n};\n"],"mappings":";;;;;AAqBA,MAAa,wBACX,YACA,sBACG;CACH,MAAM,UAAU,OAAO,QAAQ,iBAAiB,CAAC,CAAC,QAAQ,CAAC,SAAS;EAClE,OAAO,IAAI,SAAS,OAAO,KAAK,IAAI,SAAS,WAAW;CAC1D,CAAC;CAED,MAAM,QAAkB,CAAC;CAEzB,QAAQ,IACN,gCAAgC,QAAQ,OAAO,WACjD;CAEA,KAAK,MAAM,GAAG,iBAAiB,SAAS;EACtC,MAAM,OAAO,kBAAkB,cAAc,UAAU;EACvD,IAAI,MAAM,MAAM,KAAK,IAAI;CAC3B;CAEA,QAAQ,IAAI,yCAAyC;CACrD,OAAO;AACT;AAEA,MAAa,QACX,mBACA,EACE,MACA,MACA,OAAO,kBACP,MAAM,uBAEL;CACH,MAAM,MAAM,QAAQ,IAAI;CACxB,MAAM,aAAa,KAAK,KAAK,IAAI;CAEjC,IADqB,WAAW,UACjB,GAAG,OAAO;CACzB,MAAM,aAAa,cAAc,IAAI;CAGrC,IAAI;EACF,UAAU,YAAY,EAAE,WAAW,KAAK,CAAC;EACzC,QAAQ,IAAI,YAAY,IAAI,eAAe,MAAM;CACnD,SAAS,OAAO;EACd,QAAQ,MAAM,+BAA+B,IAAI,IAAI,KAAK;EAC1D,OAAO;CACT;CAGA,IAAI,QAAkB,CAAC;CAEvB,IAAI;EACF,QAAQ,qBAAqB,YAAY,iBAAiB;CAC5D,QAAQ;EACN,QAAQ,MAAM,uCAAuC;EACrD,OAAO;CACT;CAGA,MAAM,eAAe,KAAK,KAAK,eAAe;CAE9C,IAAI,WAAW,YAAY,GACzB,IAAI;EACF,MAAM,kBAAkB,aAAa,cAAc,MAAM;EACzD,MAAM,WAAW,KAAK,MAAM,eAAe;EAG3C,IAAI,CAAC,SAAS,iBACZ,SAAS,kBAAkB,CAAC;EAG9B,IAAI,CAAC,SAAS,gBAAgB,OAC5B,SAAS,gBAAgB,QAAQ,CAAC;EAIpC,MAAM,eAAe,SAAS,QAAQ,IAAI,GAAG,UAAU;EAEvD,SAAS,gBAAgB,MAAM,QAAQ,CAAC,KAAK,aAAa,GAAG;EAE7D,cACE,cACA,KAAK,UAAU,UAAU,MAAM,CAAC,GAChC,MACF;EACA,QAAQ,IAAI,UAAU,KAAK,wBAAwB;CACrD,SAAS,OAAO;EACd,QAAQ,MAAM,mCAAmC,KAAK;EACtD,OAAO;CACT;MAEA,QAAQ,KAAK,iDAAiD;CAKhE,MAAM,aAAa;EACjB,SAAS;GACR,WAAW,OAAO;GAClB,WAAW,QAAQ;CACtB;CAEA,IAAI;EACF,cACE,YACA,KAAK,UAAU,YAAY,MAAM,CAAC,GAClC,MACF;EACA,QAAQ,IAAI,UAAU,KAAK,oCAAoC;CACjE,SAAS,OAAO;EACd,QAAQ,MAAM,6BAA6B,KAAK,IAAI,KAAK;EACzD,OAAO;CACT;CAEA,QAAQ,IAAI,mDAAmD;CAC/D,OAAO;AACT"}
|
package/lib/functions/remove.cjs
CHANGED
|
@@ -2,7 +2,6 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
|
2
2
|
const require_runtime = require("../_virtual/_rolldown/runtime.cjs");
|
|
3
3
|
const require_constants = require("../constants.cjs");
|
|
4
4
|
const require_helpers = require("../helpers.cjs");
|
|
5
|
-
const require_config = require("../config.cjs");
|
|
6
5
|
let path = require("path");
|
|
7
6
|
let fs = require("fs");
|
|
8
7
|
let edit_json_file = require("edit-json-file");
|
|
@@ -25,10 +24,10 @@ const transformModules = (entries, ...files) => {
|
|
|
25
24
|
return [key, Array.from(new Set(specifiers))];
|
|
26
25
|
});
|
|
27
26
|
};
|
|
28
|
-
const remove = (CODEBASE_ANALYSIS, ...paths) => {
|
|
27
|
+
const remove = (CODEBASE_ANALYSIS, jsonConfigPath, ...paths) => {
|
|
29
28
|
if (paths.length === 0) return console.warn("No files specified for removal.");
|
|
30
29
|
try {
|
|
31
|
-
let file = (0, edit_json_file.default)((0, path.join)(process.cwd(),
|
|
30
|
+
let file = (0, edit_json_file.default)((0, path.join)(process.cwd(), jsonConfigPath));
|
|
32
31
|
if (!file) return;
|
|
33
32
|
const root = require_helpers.getFolderPath(file.get(require_constants.PATH_PROPERTY));
|
|
34
33
|
const files = file.get(require_constants.FILES_PROPERTY);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"remove.cjs","names":["transformModule","
|
|
1
|
+
{"version":3,"file":"remove.cjs","names":["transformModule","getFolderPath","PATH_PROPERTY","FILES_PROPERTY","consoleStars","path"],"sources":["../../src/functions/remove.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { unlinkSync } from 'fs';\nimport { join } from 'path';\nimport { FILES_PROPERTY, PATH_PROPERTY } from '../constants';\nimport { consoleStars, getFolderPath, transformModule } from '#helpers';\nimport { CodebaseAnalysis, FileAnalysis } from '../schemas';\n\nconst transformModules = (\n entries: [string, FileAnalysis][],\n ...files: string[]\n) => {\n const cwd = process.cwd();\n const out = entries\n .map(\n ([key, { imports, relativePath }]) =>\n [key, relativePath, imports] as const,\n )\n .map(([key, relativePath, imports]) => {\n const specifiers = imports\n .map(({ moduleSpecifier }) => {\n return transformModule({\n cwd,\n relativePath,\n moduleSpecifier,\n });\n })\n .map(_path => [_path, `${_path}.index`]) // Add .index variants\n .flat()\n .filter(s => files.includes(s));\n\n return [key, Array.from(new Set(specifiers))] as const;\n });\n\n return out;\n};\n\nexport const remove = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n jsonConfigPath: string,\n ...paths: string[]\n) => {\n const isEmpty = paths.length === 0;\n if (isEmpty) return console.warn('No files specified for removal.');\n try {\n const cwd = process.cwd();\n const json = join(cwd, jsonConfigPath);\n let file: JsonEditor | undefined = edit(json);\n\n if (!file) return;\n\n const root = getFolderPath(file.get(PATH_PROPERTY) as string);\n const files = file.get(FILES_PROPERTY) as string[];\n\n const entries2 = Object.entries(CODEBASE_ANALYSIS).filter(([key]) =>\n files.includes(key),\n );\n\n const entries = entries2.filter(([key]) =>\n paths.some(p => key.startsWith(p)),\n );\n\n // Check dependencies before deletion\n const safesToRemove: string[] = [];\n const cannotsRemove: [string, string[]][] = [];\n\n entries.forEach(([key]) => {\n const modules = transformModules(entries2, ...files);\n const importedFroms = modules\n .filter(([, specifiers]) => specifiers.includes(key))\n .map(([k]) => k);\n\n const check = importedFroms.length > 0;\n\n console.log('modules', '=>', importedFroms);\n console.log('key', '=>', key);\n\n if (check) return cannotsRemove.push([key, importedFroms]);\n return safesToRemove.push(key);\n });\n\n consoleStars();\n console.log(`🔧 Deletion of files (${entries.length} files)...`);\n\n // Display files that cannot be deleted\n if (cannotsRemove.length > 0) {\n const len = cannotsRemove.length;\n const one = 'file cannot be deleted (imported in other files)';\n const many = 'files cannot be deleted (imported in other files)';\n\n console.warn(`⚠️ ${len} ${len === 1 ? one : many} :`);\n cannotsRemove.forEach(([key, modules]) => {\n console.warn(` - ⚠️ ${key} imported by:`);\n modules.forEach(m => console.warn(` -> 📌 ${m}`));\n });\n }\n\n if (safesToRemove.length === 0) {\n console.warn('❌ No files can be deleted.');\n return consoleStars();\n }\n\n const formatteds = safesToRemove.map(key => {\n const _path = CODEBASE_ANALYSIS[key].relativePath;\n const absolute = join(root, _path);\n return [key, absolute] as const;\n });\n\n console.log(`🗑️ Deleting files (${safesToRemove.length} files)...`);\n\n let success = 0;\n const length = formatteds.length;\n\n formatteds.forEach(([key, path]) => {\n try {\n unlinkSync(path);\n console.log(` - 🗑️ ${key}`);\n file?.set(\n FILES_PROPERTY,\n files.filter(key1 => key1 !== key),\n );\n success++;\n } catch {\n console.error(` - ❌ Error, ${key} :`);\n }\n });\n\n file.save();\n console.log(`🗑️ Files deleted! (${success}/${length})`);\n file = undefined;\n } catch {\n console.error(`❌ Error while deleting files`);\n consoleStars();\n return false;\n }\n consoleStars();\n return true;\n};\n"],"mappings":"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"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { CodebaseAnalysis } from '../schemas';
|
|
2
|
-
export declare const remove: (CODEBASE_ANALYSIS: CodebaseAnalysis, ...paths: string[]) => boolean | void;
|
|
2
|
+
export declare const remove: (CODEBASE_ANALYSIS: CodebaseAnalysis, jsonConfigPath: string, ...paths: string[]) => boolean | void;
|
|
3
3
|
//# sourceMappingURL=remove.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"remove.d.ts","sourceRoot":"","sources":["../../src/functions/remove.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"remove.d.ts","sourceRoot":"","sources":["../../src/functions/remove.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAgB,MAAM,YAAY,CAAC;AA+B5D,eAAO,MAAM,MAAM,GACjB,mBAAmB,gBAAgB,EACnC,gBAAgB,MAAM,EACtB,GAAG,OAAO,MAAM,EAAE,mBAiGnB,CAAC"}
|
package/lib/functions/remove.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { FILES_PROPERTY, PATH_PROPERTY } from "../constants.js";
|
|
2
2
|
import { consoleStars, getFolderPath, transformModule } from "../helpers.js";
|
|
3
|
-
import { config } from "../config.js";
|
|
4
3
|
import { join } from "path";
|
|
5
4
|
import { unlinkSync } from "fs";
|
|
6
5
|
import edit from "edit-json-file";
|
|
@@ -22,10 +21,10 @@ const transformModules = (entries, ...files) => {
|
|
|
22
21
|
return [key, Array.from(new Set(specifiers))];
|
|
23
22
|
});
|
|
24
23
|
};
|
|
25
|
-
const remove = (CODEBASE_ANALYSIS, ...paths) => {
|
|
24
|
+
const remove = (CODEBASE_ANALYSIS, jsonConfigPath, ...paths) => {
|
|
26
25
|
if (paths.length === 0) return console.warn("No files specified for removal.");
|
|
27
26
|
try {
|
|
28
|
-
let file = edit(join(process.cwd(),
|
|
27
|
+
let file = edit(join(process.cwd(), jsonConfigPath));
|
|
29
28
|
if (!file) return;
|
|
30
29
|
const root = getFolderPath(file.get(PATH_PROPERTY));
|
|
31
30
|
const files = file.get(FILES_PROPERTY);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"remove.js","names":[],"sources":["../../src/functions/remove.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { unlinkSync } from 'fs';\nimport { join } from 'path';\nimport {
|
|
1
|
+
{"version":3,"file":"remove.js","names":[],"sources":["../../src/functions/remove.ts"],"sourcesContent":["import edit, { JsonEditor } from 'edit-json-file';\nimport { unlinkSync } from 'fs';\nimport { join } from 'path';\nimport { FILES_PROPERTY, PATH_PROPERTY } from '../constants';\nimport { consoleStars, getFolderPath, transformModule } from '#helpers';\nimport { CodebaseAnalysis, FileAnalysis } from '../schemas';\n\nconst transformModules = (\n entries: [string, FileAnalysis][],\n ...files: string[]\n) => {\n const cwd = process.cwd();\n const out = entries\n .map(\n ([key, { imports, relativePath }]) =>\n [key, relativePath, imports] as const,\n )\n .map(([key, relativePath, imports]) => {\n const specifiers = imports\n .map(({ moduleSpecifier }) => {\n return transformModule({\n cwd,\n relativePath,\n moduleSpecifier,\n });\n })\n .map(_path => [_path, `${_path}.index`]) // Add .index variants\n .flat()\n .filter(s => files.includes(s));\n\n return [key, Array.from(new Set(specifiers))] as const;\n });\n\n return out;\n};\n\nexport const remove = (\n CODEBASE_ANALYSIS: CodebaseAnalysis,\n jsonConfigPath: string,\n ...paths: string[]\n) => {\n const isEmpty = paths.length === 0;\n if (isEmpty) return console.warn('No files specified for removal.');\n try {\n const cwd = process.cwd();\n const json = join(cwd, jsonConfigPath);\n let file: JsonEditor | undefined = edit(json);\n\n if (!file) return;\n\n const root = getFolderPath(file.get(PATH_PROPERTY) as string);\n const files = file.get(FILES_PROPERTY) as string[];\n\n const entries2 = Object.entries(CODEBASE_ANALYSIS).filter(([key]) =>\n files.includes(key),\n );\n\n const entries = entries2.filter(([key]) =>\n paths.some(p => key.startsWith(p)),\n );\n\n // Check dependencies before deletion\n const safesToRemove: string[] = [];\n const cannotsRemove: [string, string[]][] = [];\n\n entries.forEach(([key]) => {\n const modules = transformModules(entries2, ...files);\n const importedFroms = modules\n .filter(([, specifiers]) => specifiers.includes(key))\n .map(([k]) => k);\n\n const check = importedFroms.length > 0;\n\n console.log('modules', '=>', importedFroms);\n console.log('key', '=>', key);\n\n if (check) return cannotsRemove.push([key, importedFroms]);\n return safesToRemove.push(key);\n });\n\n consoleStars();\n console.log(`🔧 Deletion of files (${entries.length} files)...`);\n\n // Display files that cannot be deleted\n if (cannotsRemove.length > 0) {\n const len = cannotsRemove.length;\n const one = 'file cannot be deleted (imported in other files)';\n const many = 'files cannot be deleted (imported in other files)';\n\n console.warn(`⚠️ ${len} ${len === 1 ? one : many} :`);\n cannotsRemove.forEach(([key, modules]) => {\n console.warn(` - ⚠️ ${key} imported by:`);\n modules.forEach(m => console.warn(` -> 📌 ${m}`));\n });\n }\n\n if (safesToRemove.length === 0) {\n console.warn('❌ No files can be deleted.');\n return consoleStars();\n }\n\n const formatteds = safesToRemove.map(key => {\n const _path = CODEBASE_ANALYSIS[key].relativePath;\n const absolute = join(root, _path);\n return [key, absolute] as const;\n });\n\n console.log(`🗑️ Deleting files (${safesToRemove.length} files)...`);\n\n let success = 0;\n const length = formatteds.length;\n\n formatteds.forEach(([key, path]) => {\n try {\n unlinkSync(path);\n console.log(` - 🗑️ ${key}`);\n file?.set(\n FILES_PROPERTY,\n files.filter(key1 => key1 !== key),\n );\n success++;\n } catch {\n console.error(` - ❌ Error, ${key} :`);\n }\n });\n\n file.save();\n console.log(`🗑️ Files deleted! (${success}/${length})`);\n file = undefined;\n } catch {\n console.error(`❌ Error while deleting files`);\n consoleStars();\n return false;\n }\n consoleStars();\n return true;\n};\n"],"mappings":";;;;;;AAOA,MAAM,oBACJ,SACA,GAAG,UACA;CACH,MAAM,MAAM,QAAQ,IAAI;CAsBxB,OArBY,QACT,KACE,CAAC,KAAK,EAAE,SAAS,oBAChB;EAAC;EAAK;EAAc;CAAO,CAC/B,CAAC,CACA,KAAK,CAAC,KAAK,cAAc,aAAa;EACrC,MAAM,aAAa,QAChB,KAAK,EAAE,sBAAsB;GAC5B,OAAO,gBAAgB;IACrB;IACA;IACA;GACF,CAAC;EACH,CAAC,CAAC,CACD,KAAI,UAAS,CAAC,OAAO,GAAG,MAAM,OAAO,CAAC,CAAC,CACvC,KAAK,CAAC,CACN,QAAO,MAAK,MAAM,SAAS,CAAC,CAAC;EAEhC,OAAO,CAAC,KAAK,MAAM,KAAK,IAAI,IAAI,UAAU,CAAC,CAAC;CAC9C,CAEO;AACX;AAEA,MAAa,UACX,mBACA,gBACA,GAAG,UACA;CAEH,IADgB,MAAM,WAAW,GACpB,OAAO,QAAQ,KAAK,iCAAiC;CAClE,IAAI;EAGF,IAAI,OAA+B,KADtB,KADD,QAAQ,IACA,GAAG,cACoB,CAAC;EAE5C,IAAI,CAAC,MAAM;EAEX,MAAM,OAAO,cAAc,KAAK,IAAI,aAAa,CAAW;EAC5D,MAAM,QAAQ,KAAK,IAAI,cAAc;EAErC,MAAM,WAAW,OAAO,QAAQ,iBAAiB,CAAC,CAAC,QAAQ,CAAC,SAC1D,MAAM,SAAS,GAAG,CACpB;EAEA,MAAM,UAAU,SAAS,QAAQ,CAAC,SAChC,MAAM,MAAK,MAAK,IAAI,WAAW,CAAC,CAAC,CACnC;EAGA,MAAM,gBAA0B,CAAC;EACjC,MAAM,gBAAsC,CAAC;EAE7C,QAAQ,SAAS,CAAC,SAAS;GAEzB,MAAM,gBADU,iBAAiB,UAAU,GAAG,KAClB,CAAC,CAC1B,QAAQ,GAAG,gBAAgB,WAAW,SAAS,GAAG,CAAC,CAAC,CACpD,KAAK,CAAC,OAAO,CAAC;GAEjB,MAAM,QAAQ,cAAc,SAAS;GAErC,QAAQ,IAAI,WAAW,MAAM,aAAa;GAC1C,QAAQ,IAAI,OAAO,MAAM,GAAG;GAE5B,IAAI,OAAO,OAAO,cAAc,KAAK,CAAC,KAAK,aAAa,CAAC;GACzD,OAAO,cAAc,KAAK,GAAG;EAC/B,CAAC;EAED,aAAa;EACb,QAAQ,IAAI,yBAAyB,QAAQ,OAAO,WAAW;EAG/D,IAAI,cAAc,SAAS,GAAG;GAC5B,MAAM,MAAM,cAAc;GAI1B,QAAQ,KAAK,OAAO,IAAI,GAAG,QAAQ,IAAI,qDAAM,oDAAK,GAAG;GACrD,cAAc,SAAS,CAAC,KAAK,aAAa;IACxC,QAAQ,KAAK,WAAW,IAAI,cAAc;IAC1C,QAAQ,SAAQ,MAAK,QAAQ,KAAK,aAAa,GAAG,CAAC;GACrD,CAAC;EACH;EAEA,IAAI,cAAc,WAAW,GAAG;GAC9B,QAAQ,KAAK,4BAA4B;GACzC,OAAO,aAAa;EACtB;EAEA,MAAM,aAAa,cAAc,KAAI,QAAO;GAC1C,MAAM,QAAQ,kBAAkB,IAAI,CAAC;GAErC,OAAO,CAAC,KADS,KAAK,MAAM,KACR,CAAC;EACvB,CAAC;EAED,QAAQ,IAAI,uBAAuB,cAAc,OAAO,WAAW;EAEnE,IAAI,UAAU;EACd,MAAM,SAAS,WAAW;EAE1B,WAAW,SAAS,CAAC,KAAK,UAAU;GAClC,IAAI;IACF,WAAW,IAAI;IACf,QAAQ,IAAI,WAAW,KAAK;IAC5B,MAAM,IACJ,gBACA,MAAM,QAAO,SAAQ,SAAS,GAAG,CACnC;IACA;GACF,QAAQ;IACN,QAAQ,MAAM,gBAAgB,IAAI,GAAG;GACvC;EACF,CAAC;EAED,KAAK,KAAK;EACV,QAAQ,IAAI,uBAAuB,QAAQ,GAAG,OAAO,EAAE;EACvD,OAAO,KAAA;CACT,QAAQ;EACN,QAAQ,MAAM,8BAA8B;EAC5C,aAAa;EACb,OAAO;CACT;CACA,aAAa;CACb,OAAO;AACT"}
|
package/lib/imports.cjs
CHANGED
|
@@ -5,7 +5,7 @@ let ts_morph = require("ts-morph");
|
|
|
5
5
|
/**
|
|
6
6
|
* Resolves the moduleSpecifier using the tsconfig paths if it starts with "#"
|
|
7
7
|
*/
|
|
8
|
-
const
|
|
8
|
+
const _resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
9
9
|
const paths = sourceFile.getProject().getCompilerOptions().paths;
|
|
10
10
|
if (!paths) return moduleSpecifier;
|
|
11
11
|
const baseUrl = sourceFile.getProject().getCompilerOptions().baseUrl;
|
|
@@ -24,6 +24,9 @@ const resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
|
24
24
|
}
|
|
25
25
|
return moduleSpecifier;
|
|
26
26
|
};
|
|
27
|
+
const resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
28
|
+
return _resolveModuleSpecifier(sourceFile, moduleSpecifier).replace(/\.tsx?$/, "");
|
|
29
|
+
};
|
|
27
30
|
/**
|
|
28
31
|
* Analyzes a file's imports
|
|
29
32
|
*/
|
package/lib/imports.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imports.cjs","names":["SyntaxKind"],"sources":["../src/imports.ts"],"sourcesContent":["import { join, relative } from 'path';\nimport { SourceFile, SyntaxKind } from 'ts-morph';\nimport type { ImportInfo } from './schemas';\n\n/**\n * Resolves the moduleSpecifier using the tsconfig paths if it starts with \"#\"\n */\nconst
|
|
1
|
+
{"version":3,"file":"imports.cjs","names":["SyntaxKind"],"sources":["../src/imports.ts"],"sourcesContent":["import { join, relative } from 'path';\nimport { SourceFile, SyntaxKind } from 'ts-morph';\nimport type { ImportInfo } from './schemas';\n\n/**\n * Resolves the moduleSpecifier using the tsconfig paths if it starts with \"#\"\n */\nconst _resolveModuleSpecifier = (\n sourceFile: SourceFile,\n moduleSpecifier: string,\n): string => {\n const paths = sourceFile.getProject().getCompilerOptions().paths;\n\n if (!paths) return moduleSpecifier;\n\n const baseUrl = sourceFile.getProject().getCompilerOptions().baseUrl;\n const paths2 = Object.entries(paths);\n\n // Find the match in paths\n for (const [pattern, mappings] of paths2) {\n // Replace * with a regex to match\n const regexPattern = pattern.replace(/\\*/g, '(.*)');\n const regex = new RegExp(`^${regexPattern}$`);\n const match = moduleSpecifier.match(regex);\n\n if (match) {\n // Take the first available mapping\n const first = mappings[0];\n\n // Resolve the absolute path\n let relativedPath = baseUrl ? join(baseUrl, first) : first;\n\n if (match[1]) {\n relativedPath = relativedPath.replace('*', match[1]);\n }\n\n // Calculate the relative path from the current source file\n const sourceFileDir = relative(\n process.cwd(),\n sourceFile.getDirectoryPath(),\n );\n const relativePath = relative(sourceFileDir, relativedPath);\n\n // Make sure the relative path starts with ./ or ../\n const resolved = relativePath.startsWith('.')\n ? relativePath\n : `./${relativePath}`;\n\n return resolved;\n }\n }\n\n return moduleSpecifier;\n};\n\nconst resolveModuleSpecifier = (\n sourceFile: SourceFile,\n moduleSpecifier: string,\n): string => {\n return _resolveModuleSpecifier(sourceFile, moduleSpecifier).replace(\n /\\.tsx?$/,\n '',\n );\n};\n\n/**\n * Analyzes a file's imports\n */\nexport const analyzeImports = (\n sourceFile: SourceFile,\n): ImportInfo[] => {\n const imports: ImportInfo[] = [];\n\n // Import declarations (import ... from '...')\n sourceFile.getImportDeclarations().forEach(importDecl => {\n // Determine if this is a type-only import\n const isTypeOnly = importDecl.isTypeOnly();\n\n const rawModuleSpecifier = importDecl.getModuleSpecifierValue();\n const moduleSpecifier = resolveModuleSpecifier(\n sourceFile,\n rawModuleSpecifier,\n );\n\n // Import default\n const defaultImport = importDecl.getDefaultImport();\n if (defaultImport) {\n imports.push({\n moduleSpecifier,\n kind: 'default',\n default: defaultImport.getText(),\n isTypeOnly,\n });\n }\n\n // Import namespace (* as name)\n const namespaceImport = importDecl.getNamespaceImport();\n if (namespaceImport) {\n imports.push({\n moduleSpecifier,\n kind: 'namespace',\n default: namespaceImport.getText(),\n isTypeOnly,\n });\n }\n\n // Named imports ({ name1, name2 })\n const namedImports = importDecl.getNamedImports();\n if (namedImports.length > 0) {\n imports.push({\n moduleSpecifier,\n kind: 'named',\n namedImports: namedImports.map(ni => ni.getName()),\n isTypeOnly,\n });\n }\n\n // Side-effect import (import '...')\n if (\n !defaultImport &&\n !namespaceImport &&\n namedImports.length === 0\n ) {\n imports.push({\n moduleSpecifier,\n kind: 'side-effect',\n isTypeOnly,\n });\n }\n });\n\n // Dynamic imports (import('...'))\n sourceFile\n .getDescendantsOfKind(SyntaxKind.CallExpression)\n .forEach(callExpr => {\n if (\n callExpr.getExpression().getKind() === SyntaxKind.ImportKeyword\n ) {\n const arg = callExpr.getArguments()[0];\n if (arg && arg.getKind() === SyntaxKind.StringLiteral) {\n const rawModuleSpecifier = arg.getText().replace(/['\"]/g, '');\n const moduleSpecifier = resolveModuleSpecifier(\n sourceFile,\n rawModuleSpecifier,\n );\n imports.push({\n moduleSpecifier,\n kind: 'side-effect',\n isDynamic: true,\n });\n }\n }\n });\n\n return imports;\n};\n\nexport const buildImportStrings = (imports: ImportInfo[]) => {\n return imports.map(imp => {\n switch (imp.kind) {\n case 'named': {\n const namedImports = imp.namedImports?.join(', ') || '';\n return `import ${imp.isTypeOnly ? 'type ' : ''}{ ${namedImports} } from '${imp.moduleSpecifier}';`;\n }\n case 'namespace':\n return `import ${imp.isTypeOnly ? 'type ' : ''}* as ${imp.default} from '${imp.moduleSpecifier}';`;\n case 'side-effect': {\n if (imp.isDynamic) {\n return `// Dynamic import: import('${imp.moduleSpecifier}')`;\n }\n return `import '${imp.moduleSpecifier}';`;\n }\n\n case 'default':\n return `import ${imp.isTypeOnly ? 'type ' : ''}${imp.default} from '${imp.moduleSpecifier}';`;\n default:\n return '';\n }\n });\n};\n"],"mappings":"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"}
|
package/lib/imports.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imports.d.ts","sourceRoot":"","sources":["../src/imports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAc,MAAM,UAAU,CAAC;AAClD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"imports.d.ts","sourceRoot":"","sources":["../src/imports.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAc,MAAM,UAAU,CAAC;AAClD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AA+D5C;;GAEG;AACH,eAAO,MAAM,cAAc,GACzB,YAAY,UAAU,KACrB,UAAU,EAqFZ,CAAC;AAEF,eAAO,MAAM,kBAAkB,GAAI,SAAS,UAAU,EAAE,aAsBvD,CAAC"}
|
package/lib/imports.js
CHANGED
|
@@ -4,7 +4,7 @@ import { SyntaxKind } from "ts-morph";
|
|
|
4
4
|
/**
|
|
5
5
|
* Resolves the moduleSpecifier using the tsconfig paths if it starts with "#"
|
|
6
6
|
*/
|
|
7
|
-
const
|
|
7
|
+
const _resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
8
8
|
const paths = sourceFile.getProject().getCompilerOptions().paths;
|
|
9
9
|
if (!paths) return moduleSpecifier;
|
|
10
10
|
const baseUrl = sourceFile.getProject().getCompilerOptions().baseUrl;
|
|
@@ -23,6 +23,9 @@ const resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
|
23
23
|
}
|
|
24
24
|
return moduleSpecifier;
|
|
25
25
|
};
|
|
26
|
+
const resolveModuleSpecifier = (sourceFile, moduleSpecifier) => {
|
|
27
|
+
return _resolveModuleSpecifier(sourceFile, moduleSpecifier).replace(/\.tsx?$/, "");
|
|
28
|
+
};
|
|
26
29
|
/**
|
|
27
30
|
* Analyzes a file's imports
|
|
28
31
|
*/
|
package/lib/imports.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"imports.js","names":[],"sources":["../src/imports.ts"],"sourcesContent":["import { join, relative } from 'path';\nimport { SourceFile, SyntaxKind } from 'ts-morph';\nimport type { ImportInfo } from './schemas';\n\n/**\n * Resolves the moduleSpecifier using the tsconfig paths if it starts with \"#\"\n */\nconst
|
|
1
|
+
{"version":3,"file":"imports.js","names":[],"sources":["../src/imports.ts"],"sourcesContent":["import { join, relative } from 'path';\nimport { SourceFile, SyntaxKind } from 'ts-morph';\nimport type { ImportInfo } from './schemas';\n\n/**\n * Resolves the moduleSpecifier using the tsconfig paths if it starts with \"#\"\n */\nconst _resolveModuleSpecifier = (\n sourceFile: SourceFile,\n moduleSpecifier: string,\n): string => {\n const paths = sourceFile.getProject().getCompilerOptions().paths;\n\n if (!paths) return moduleSpecifier;\n\n const baseUrl = sourceFile.getProject().getCompilerOptions().baseUrl;\n const paths2 = Object.entries(paths);\n\n // Find the match in paths\n for (const [pattern, mappings] of paths2) {\n // Replace * with a regex to match\n const regexPattern = pattern.replace(/\\*/g, '(.*)');\n const regex = new RegExp(`^${regexPattern}$`);\n const match = moduleSpecifier.match(regex);\n\n if (match) {\n // Take the first available mapping\n const first = mappings[0];\n\n // Resolve the absolute path\n let relativedPath = baseUrl ? join(baseUrl, first) : first;\n\n if (match[1]) {\n relativedPath = relativedPath.replace('*', match[1]);\n }\n\n // Calculate the relative path from the current source file\n const sourceFileDir = relative(\n process.cwd(),\n sourceFile.getDirectoryPath(),\n );\n const relativePath = relative(sourceFileDir, relativedPath);\n\n // Make sure the relative path starts with ./ or ../\n const resolved = relativePath.startsWith('.')\n ? relativePath\n : `./${relativePath}`;\n\n return resolved;\n }\n }\n\n return moduleSpecifier;\n};\n\nconst resolveModuleSpecifier = (\n sourceFile: SourceFile,\n moduleSpecifier: string,\n): string => {\n return _resolveModuleSpecifier(sourceFile, moduleSpecifier).replace(\n /\\.tsx?$/,\n '',\n );\n};\n\n/**\n * Analyzes a file's imports\n */\nexport const analyzeImports = (\n sourceFile: SourceFile,\n): ImportInfo[] => {\n const imports: ImportInfo[] = [];\n\n // Import declarations (import ... from '...')\n sourceFile.getImportDeclarations().forEach(importDecl => {\n // Determine if this is a type-only import\n const isTypeOnly = importDecl.isTypeOnly();\n\n const rawModuleSpecifier = importDecl.getModuleSpecifierValue();\n const moduleSpecifier = resolveModuleSpecifier(\n sourceFile,\n rawModuleSpecifier,\n );\n\n // Import default\n const defaultImport = importDecl.getDefaultImport();\n if (defaultImport) {\n imports.push({\n moduleSpecifier,\n kind: 'default',\n default: defaultImport.getText(),\n isTypeOnly,\n });\n }\n\n // Import namespace (* as name)\n const namespaceImport = importDecl.getNamespaceImport();\n if (namespaceImport) {\n imports.push({\n moduleSpecifier,\n kind: 'namespace',\n default: namespaceImport.getText(),\n isTypeOnly,\n });\n }\n\n // Named imports ({ name1, name2 })\n const namedImports = importDecl.getNamedImports();\n if (namedImports.length > 0) {\n imports.push({\n moduleSpecifier,\n kind: 'named',\n namedImports: namedImports.map(ni => ni.getName()),\n isTypeOnly,\n });\n }\n\n // Side-effect import (import '...')\n if (\n !defaultImport &&\n !namespaceImport &&\n namedImports.length === 0\n ) {\n imports.push({\n moduleSpecifier,\n kind: 'side-effect',\n isTypeOnly,\n });\n }\n });\n\n // Dynamic imports (import('...'))\n sourceFile\n .getDescendantsOfKind(SyntaxKind.CallExpression)\n .forEach(callExpr => {\n if (\n callExpr.getExpression().getKind() === SyntaxKind.ImportKeyword\n ) {\n const arg = callExpr.getArguments()[0];\n if (arg && arg.getKind() === SyntaxKind.StringLiteral) {\n const rawModuleSpecifier = arg.getText().replace(/['\"]/g, '');\n const moduleSpecifier = resolveModuleSpecifier(\n sourceFile,\n rawModuleSpecifier,\n );\n imports.push({\n moduleSpecifier,\n kind: 'side-effect',\n isDynamic: true,\n });\n }\n }\n });\n\n return imports;\n};\n\nexport const buildImportStrings = (imports: ImportInfo[]) => {\n return imports.map(imp => {\n switch (imp.kind) {\n case 'named': {\n const namedImports = imp.namedImports?.join(', ') || '';\n return `import ${imp.isTypeOnly ? 'type ' : ''}{ ${namedImports} } from '${imp.moduleSpecifier}';`;\n }\n case 'namespace':\n return `import ${imp.isTypeOnly ? 'type ' : ''}* as ${imp.default} from '${imp.moduleSpecifier}';`;\n case 'side-effect': {\n if (imp.isDynamic) {\n return `// Dynamic import: import('${imp.moduleSpecifier}')`;\n }\n return `import '${imp.moduleSpecifier}';`;\n }\n\n case 'default':\n return `import ${imp.isTypeOnly ? 'type ' : ''}${imp.default} from '${imp.moduleSpecifier}';`;\n default:\n return '';\n }\n });\n};\n"],"mappings":"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"}
|
package/lib/index.cjs
CHANGED
|
@@ -2,7 +2,6 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
|
2
2
|
const require_schemas = require("./schemas.cjs");
|
|
3
3
|
const require_helpers = require("./helpers.cjs");
|
|
4
4
|
const require_analyse = require("./analyse.cjs");
|
|
5
|
-
const require_config = require("./config.cjs");
|
|
6
5
|
const require_functions_add = require("./functions/add.cjs");
|
|
7
6
|
const require_functions_generate = require("./functions/generate.cjs");
|
|
8
7
|
const require_functions_init = require("./functions/init.cjs");
|
|
@@ -17,7 +16,6 @@ exports.FileAnalysisSchema = require_schemas.FileAnalysisSchema;
|
|
|
17
16
|
exports.ImportInfoSchema = require_schemas.ImportInfoSchema;
|
|
18
17
|
exports.add = require_functions_add.add;
|
|
19
18
|
exports.analyze = require_analyse.analyze;
|
|
20
|
-
exports.config = require_config.config;
|
|
21
19
|
exports.consoleStars = require_helpers.consoleStars;
|
|
22
20
|
exports.createTypesStructure = require_functions_init.createTypesStructure;
|
|
23
21
|
exports.generate = require_functions_generate.generate;
|
package/lib/index.d.ts
CHANGED
package/lib/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AACxD,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
package/lib/index.js
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { AnalysisStatsSchema, CodeAnalysisFileSchema, CodebaseAnalysisSchema, DeclarationKindSchema, ExportInfoSchema, FileAnalysisSchema, ImportInfoSchema } from "./schemas.js";
|
|
2
2
|
import { consoleStars, getFolderPath } from "./helpers.js";
|
|
3
3
|
import { analyze } from "./analyse.js";
|
|
4
|
-
import { config } from "./config.js";
|
|
5
4
|
import { add } from "./functions/add.js";
|
|
6
5
|
import { generate, transformJSON } from "./functions/generate.js";
|
|
7
6
|
import { createTypesStructure, init } from "./functions/init.js";
|
|
8
7
|
import { remove } from "./functions/remove.js";
|
|
9
8
|
import "./functions/index.js";
|
|
10
|
-
export { AnalysisStatsSchema, CodeAnalysisFileSchema, CodebaseAnalysisSchema, DeclarationKindSchema, ExportInfoSchema, FileAnalysisSchema, ImportInfoSchema, add, analyze,
|
|
9
|
+
export { AnalysisStatsSchema, CodeAnalysisFileSchema, CodebaseAnalysisSchema, DeclarationKindSchema, ExportInfoSchema, FileAnalysisSchema, ImportInfoSchema, add, analyze, consoleStars, createTypesStructure, generate, getFolderPath, init, remove, transformJSON };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bemedev/codebase",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.3.0",
|
|
4
4
|
"description": "The CLI for to generate codebase, and import partially a library. From @bemedev.",
|
|
5
5
|
"author": {
|
|
6
6
|
"email": "bri_lvi@icloud.com",
|
|
@@ -72,10 +72,10 @@
|
|
|
72
72
|
}
|
|
73
73
|
],
|
|
74
74
|
"devDependencies": {
|
|
75
|
-
"@bemedev/dev-utils": "^0.8.
|
|
75
|
+
"@bemedev/dev-utils": "^0.8.2",
|
|
76
76
|
"@size-limit/file": "^12.1.0",
|
|
77
|
-
"@types/node": "^
|
|
78
|
-
"rolldown": "1.1.
|
|
77
|
+
"@types/node": "^26.0.1",
|
|
78
|
+
"rolldown": "1.1.3",
|
|
79
79
|
"size-limit": "^12.1.0",
|
|
80
80
|
"tsx": "^4.22.4",
|
|
81
81
|
"typescript": "^6.0.3"
|
package/lib/config.cjs
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_constants = require("./constants.cjs");
|
|
3
|
-
//#region src/config.ts
|
|
4
|
-
const config = {
|
|
5
|
-
bin: require_constants.DEFAULT_CLI_NAME,
|
|
6
|
-
json: require_constants.DEFAULT_JSON_FILE_NAME,
|
|
7
|
-
tsConfigPath: require_constants.DEFAULT_PATH_KEY,
|
|
8
|
-
codebase: require_constants.DEFAULT_CODEBASE_FILE
|
|
9
|
-
};
|
|
10
|
-
//#endregion
|
|
11
|
-
exports.config = config;
|
|
12
|
-
|
|
13
|
-
//# sourceMappingURL=config.cjs.map
|
package/lib/config.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.cjs","names":["DEFAULT_CLI_NAME","DEFAULT_JSON_FILE_NAME","DEFAULT_PATH_KEY","DEFAULT_CODEBASE_FILE"],"sources":["../src/config.ts"],"sourcesContent":["import {\n DEFAULT_CLI_NAME,\n DEFAULT_CODEBASE_FILE,\n DEFAULT_JSON_FILE_NAME,\n DEFAULT_PATH_KEY,\n} from './constants';\n\nexport const config: {\n bin: string;\n json: string;\n tsConfigPath: string;\n root?: string;\n codebase: string;\n} = {\n bin: DEFAULT_CLI_NAME,\n json: DEFAULT_JSON_FILE_NAME,\n tsConfigPath: DEFAULT_PATH_KEY,\n codebase: DEFAULT_CODEBASE_FILE,\n};\n"],"mappings":";;;AAOA,MAAa,SAMT;CACF,KAAKA,kBAAAA;CACL,MAAMC,kBAAAA;CACN,cAAcC,kBAAAA;CACd,UAAUC,kBAAAA;AACZ"}
|
package/lib/config.d.ts
DELETED
package/lib/config.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,MAAM,EAAE;IACnB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CAMlB,CAAC"}
|
package/lib/config.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { DEFAULT_CLI_NAME, DEFAULT_CODEBASE_FILE, DEFAULT_JSON_FILE_NAME, DEFAULT_PATH_KEY } from "./constants.js";
|
|
2
|
-
//#region src/config.ts
|
|
3
|
-
const config = {
|
|
4
|
-
bin: DEFAULT_CLI_NAME,
|
|
5
|
-
json: DEFAULT_JSON_FILE_NAME,
|
|
6
|
-
tsConfigPath: DEFAULT_PATH_KEY,
|
|
7
|
-
codebase: DEFAULT_CODEBASE_FILE
|
|
8
|
-
};
|
|
9
|
-
//#endregion
|
|
10
|
-
export { config };
|
|
11
|
-
|
|
12
|
-
//# sourceMappingURL=config.js.map
|
package/lib/config.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","names":[],"sources":["../src/config.ts"],"sourcesContent":["import {\n DEFAULT_CLI_NAME,\n DEFAULT_CODEBASE_FILE,\n DEFAULT_JSON_FILE_NAME,\n DEFAULT_PATH_KEY,\n} from './constants';\n\nexport const config: {\n bin: string;\n json: string;\n tsConfigPath: string;\n root?: string;\n codebase: string;\n} = {\n bin: DEFAULT_CLI_NAME,\n json: DEFAULT_JSON_FILE_NAME,\n tsConfigPath: DEFAULT_PATH_KEY,\n codebase: DEFAULT_CODEBASE_FILE,\n};\n"],"mappings":";;AAOA,MAAa,SAMT;CACF,KAAK;CACL,MAAM;CACN,cAAc;CACd,UAAU;AACZ"}
|