From 695ca391957ad82486b6ade593561d1e903dec2b Mon Sep 17 00:00:00 2001 From: Sasha Date: Tue, 24 Sep 2024 16:56:31 +0200 Subject: [PATCH] chore: lint run (#1332) --- biome.json | 3 + .../ethers/v6/big-numbers/.codemodrc.json | 6 +- .../ethers/v6/big-numbers/package.json | 8 +- .../ethers/v6/big-numbers/src/index.ts | 80 +- .../ethers/v6/big-numbers/test/test.ts | 44 +- .../ethers/v6/big-numbers/tsconfig.json | 7 +- .../ethers/v6/big-numbers/vitest.config.ts | 6 +- .../.codemodrc.json | 7 +- .../contracts-ambiguous-methods/package.json | 8 +- .../contracts-ambiguous-methods/src/index.ts | 16 +- .../contracts-ambiguous-methods/test/test.ts | 44 +- .../contracts-ambiguous-methods/tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../contracts-other-methods/.codemodrc.json | 7 +- .../v6/contracts-other-methods/package.json | 8 +- .../v6/contracts-other-methods/src/index.ts | 69 +- .../v6/contracts-other-methods/test/test.ts | 116 +- .../v6/contracts-other-methods/tsconfig.json | 7 +- .../contracts-other-methods/vitest.config.ts | 6 +- .../ethers/v6/importing/.codemodrc.json | 7 +- .../codemods/ethers/v6/importing/package.json | 8 +- .../codemods/ethers/v6/importing/src/index.ts | 35 +- .../codemods/ethers/v6/importing/test/test.ts | 68 +- .../ethers/v6/importing/tsconfig.json | 7 +- .../ethers/v6/importing/vitest.config.ts | 6 +- .../v6/migration-recipe/.codemodrc.json | 36 +- .../ethers/v6/providers/.codemodrc.json | 7 +- .../codemods/ethers/v6/providers/package.json | 8 +- .../codemods/ethers/v6/providers/src/index.ts | 134 +- .../codemods/ethers/v6/providers/test/test.ts | 116 +- .../ethers/v6/providers/tsconfig.json | 7 +- .../ethers/v6/providers/vitest.config.ts | 6 +- .../ethers/v6/singatures/.codemodrc.json | 7 +- .../ethers/v6/singatures/package.json | 8 +- .../ethers/v6/singatures/src/index.ts | 88 +- .../ethers/v6/singatures/test/test.ts | 68 +- .../ethers/v6/singatures/tsconfig.json | 7 +- .../ethers/v6/singatures/vitest.config.ts | 6 +- .../ethers/v6/transactions/.codemodrc.json | 7 +- .../ethers/v6/transactions/package.json | 8 +- .../ethers/v6/transactions/src/index.ts | 44 +- .../ethers/v6/transactions/test/test.ts | 92 +- .../ethers/v6/transactions/tsconfig.json | 7 +- .../ethers/v6/transactions/vitest.config.ts | 6 +- .../ethers/v6/utilities/.codemodrc.json | 7 +- .../codemods/ethers/v6/utilities/package.json | 8 +- .../codemods/ethers/v6/utilities/src/index.ts | 335 +++-- .../codemods/ethers/v6/utilities/test/test.ts | 188 ++- .../ethers/v6/utilities/tsconfig.json | 7 +- .../ethers/v6/utilities/vitest.config.ts | 6 +- .../5.0/handling_env-execute/package.json | 8 +- .../5.0/handling_env-execute/src/index.ts | 37 +- .../5.0/handling_env-execute/test/test.ts | 44 +- .../5.0/handling_env-execute/tsconfig.json | 7 +- .../5.0/handling_env-execute/vitest.config.ts | 6 +- .../5.0/node-boot-removal/package.json | 8 +- .../5.0/node-boot-removal/src/index.ts | 45 +- .../5.0/node-boot-removal/test/test.ts | 44 +- .../5.0/node-boot-removal/tsconfig.json | 7 +- .../5.0/node-boot-removal/vitest.config.ts | 6 +- .../python/eliminate-async-io/.codemodrc.json | 8 +- .../.codemodrc.json | 5 +- .../src/index.ts | 86 +- .../4/asynchronous-api/.codemodrc.json | 5 +- .../4/asynchronous-api/src/index.ts | 124 +- .../4/format-helpers/.codemodrc.json | 5 +- .../4/format-helpers/src/index.ts | 70 +- .../4/formatting-options/.codemodrc.json | 5 +- .../4/formatting-options/src/index.ts | 126 +- .../4/hook-api-actions/.codemodrc.json | 5 +- .../4/hook-api-actions/src/index.ts | 116 +- .../4/hook-api-file-header/.codemodrc.json | 5 +- .../4/hook-api-file-header/src/index.ts | 78 +- .../4/hook-api-filters/.codemodrc.json | 5 +- .../4/hook-api-filters/src/index.ts | 74 +- .../4/hook-api-formats/.codemodrc.json | 5 +- .../4/hook-api-formats/src/index.ts | 140 +-- .../4/hook-api-parsers/.codemodrc.json | 5 +- .../4/hook-api-parsers/src/index.ts | 239 ++-- .../4/hook-api-preprocessors/.codemodrc.json | 5 +- .../4/hook-api-preprocessors/src/index.ts | 101 +- .../hook-api-transform-groups/.codemodrc.json | 5 +- .../4/hook-api-transform-groups/src/index.ts | 78 +- .../4/hook-api-transform/.codemodrc.json | 5 +- .../4/hook-api-transform/src/index.ts | 150 ++- .../.codemodrc.json | 5 +- .../src/index.ts | 192 +-- .../styledictionary/4/logging/.codemodrc.json | 5 +- .../styledictionary/4/logging/src/index.ts | 51 +- .../4/migration-recipe/.codemodrc.json | 5 +- .../4/module-common-js/.codemodrc.json | 5 +- .../4/module-common-js/src/index.ts | 41 +- .../4/reference-utils/.codemodrc.json | 5 +- .../4/reference-utils/src/index.ts | 166 +-- .../styledictionary/4/type/.codemodrc.json | 5 +- .../styledictionary/4/type/src/index.ts | 75 +- .../.codemodrc.json | 5 +- .../src/index.ts | 93 +- .../.codemodrc.json | 9 +- .../src/index.ts | 289 ++--- .../.codemodrc.json | 9 +- .../src/index.ts | 223 ++-- .../5/components-as-functions/.codemodrc.json | 9 +- .../5/components-as-functions/src/index.ts | 170 ++- .../svelte/5/is-where-scoping/.codemodrc.json | 9 +- .../svelte/5/is-where-scoping/src/index.ts | 132 +- .../svelte/5/migration-recipe/.codemodrc.json | 9 +- .../5/server-api-changes/.codemodrc.json | 9 +- .../svelte/5/server-api-changes/src/index.ts | 183 +-- .../svelte-element-expression/.codemodrc.json | 9 +- .../5/svelte-element-expression/src/index.ts | 45 +- .../deactivate-to-disconnect/.codemodrc.json | 8 +- .../deactivate-to-disconnect/package.json | 8 +- .../deactivate-to-disconnect/src/index.ts | 59 +- .../deactivate-to-disconnect/test/test.ts | 68 +- .../deactivate-to-disconnect/tsconfig.json | 7 +- .../deactivate-to-disconnect/vitest.config.ts | 6 +- .../drag-controls-to-connect/.codemodrc.json | 8 +- .../drag-controls-to-connect/package.json | 8 +- .../drag-controls-to-connect/src/index.ts | 42 +- .../drag-controls-to-connect/test/test.ts | 68 +- .../drag-controls-to-connect/tsconfig.json | 7 +- .../drag-controls-to-connect/vitest.config.ts | 6 +- .../.codemodrc.json | 8 +- .../package.json | 8 +- .../src/index.ts | 21 +- .../test/test.ts | 92 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../.codemodrc.json | 8 +- .../package.json | 8 +- .../src/index.ts | 64 +- .../test/test.ts | 92 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../.codemodrc.json | 8 +- .../package.json | 8 +- .../src/index.ts | 19 +- .../test/test.ts | 68 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../.codemodrc.json | 8 +- .../package.json | 8 +- .../src/index.ts | 17 +- .../test/test.ts | 68 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../three_migration_recipe/.codemodrc.json | 37 +- .../transform_logluvloader/.codemodrc.json | 8 +- .../r168/transform_logluvloader/package.json | 8 +- .../r168/transform_logluvloader/src/index.ts | 72 +- .../r168/transform_logluvloader/test/test.ts | 44 +- .../r168/transform_logluvloader/tsconfig.json | 7 +- .../transform_logluvloader/vitest.config.ts | 6 +- .../uniforms-to-uniformarray/.codemodrc.json | 8 +- .../uniforms-to-uniformarray/package.json | 8 +- .../uniforms-to-uniformarray/src/index.ts | 24 +- .../uniforms-to-uniformarray/test/test.ts | 44 +- .../uniforms-to-uniformarray/tsconfig.json | 7 +- .../uniforms-to-uniformarray/vitest.config.ts | 6 +- .../.codemodrc.json | 4 +- .../package.json | 8 +- .../src/index.ts | 22 +- .../test/test.ts | 92 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../.codemodrc.json | 4 +- .../package.json | 8 +- .../src/index.ts | 115 +- .../test/test.ts | 116 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- .../v5/migration-recipe/.codemodrc.json | 38 +- .../webpack/v5/migration-recipe/package.json | 1 - .../.codemodrc.json | 4 +- .../package.json | 8 +- .../src/index.ts | 84 +- .../test/test.ts | 116 +- .../tsconfig.json | 7 +- .../vitest.config.ts | 6 +- pnpm-lock.yaml | 1075 ++++++++++++++++- 181 files changed, 4818 insertions(+), 3266 deletions(-) diff --git a/biome.json b/biome.json index cb4c9d38e..1a74cb057 100644 --- a/biome.json +++ b/biome.json @@ -9,6 +9,7 @@ "*.d.ts", "*.js", "dist", + "cdmd_dist", "build", "pnpm-lock.yaml", "node_modules", @@ -116,6 +117,7 @@ "input.js", "output.js", "dist", + "cdmd_dist", "build", "pnpm-lock.yaml", "node_modules", @@ -133,6 +135,7 @@ "ignore": [ "node_modules", "dist", + "cdmd_dist", "build", ".next", ".vscode", diff --git a/packages/codemods/ethers/v6/big-numbers/.codemodrc.json b/packages/codemods/ethers/v6/big-numbers/.codemodrc.json index eba983685..8e24526b6 100644 --- a/packages/codemods/ethers/v6/big-numbers/.codemodrc.json +++ b/packages/codemods/ethers/v6/big-numbers/.codemodrc.json @@ -6,8 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js" - ] + "tags": ["ethers.js"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/big-numbers/package.json b/packages/codemods/ethers/v6/big-numbers/package.json index dce6d64ec..16fecf51c 100644 --- a/packages/codemods/ethers/v6/big-numbers/package.json +++ b/packages/codemods/ethers/v6/big-numbers/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/big-numbers/src/index.ts b/packages/codemods/ethers/v6/big-numbers/src/index.ts index 315d44480..ed5887d66 100644 --- a/packages/codemods/ethers/v6/big-numbers/src/index.ts +++ b/packages/codemods/ethers/v6/big-numbers/src/index.ts @@ -4,45 +4,53 @@ export default function transform(file, api) { let dirtyFlag = false; // Transform BigNumber.from('1000') to BigInt('1000') - root.find(j.CallExpression, { - callee: { - object: { name: 'BigNumber' }, - property: { name: 'from' } - } - }).forEach(path => { - if (j.Literal.check(path.node.arguments[0])) { - path.replace(j.callExpression(j.identifier('BigInt'), [path.node.arguments[0]])); - dirtyFlag = true; - } - }); + root + .find(j.CallExpression, { + callee: { + object: { name: "BigNumber" }, + property: { name: "from" }, + }, + }) + .forEach((path) => { + if (j.Literal.check(path.node.arguments[0])) { + path.replace( + j.callExpression(j.identifier("BigInt"), [path.node.arguments[0]]), + ); + dirtyFlag = true; + } + }); // Transform value1.add(value2) to value1 + value2 - root.find(j.CallExpression, { - callee: { - property: { name: 'add' } - } - }).forEach(path => { - const { object } = path.node.callee; - const args = path.node.arguments; - if (args && args.length === 1) { - path.replace(j.binaryExpression('+', object, args[0])); - dirtyFlag = true; - } - }); + root + .find(j.CallExpression, { + callee: { + property: { name: "add" }, + }, + }) + .forEach((path) => { + const { object } = path.node.callee; + const args = path.node.arguments; + if (args && args.length === 1) { + path.replace(j.binaryExpression("+", object, args[0])); + dirtyFlag = true; + } + }); // Transform value1.eq(value2) to value1 == value2 - root.find(j.CallExpression, { - callee: { - property: { name: 'eq' } - } - }).forEach(path => { - const { object } = path.node.callee; - const args = path.node.arguments; - if (args && args.length === 1) { - path.replace(j.binaryExpression('==', object, args[0])); - dirtyFlag = true; - } - }); + root + .find(j.CallExpression, { + callee: { + property: { name: "eq" }, + }, + }) + .forEach((path) => { + const { object } = path.node.callee; + const args = path.node.arguments; + if (args && args.length === 1) { + path.replace(j.binaryExpression("==", object, args[0])); + dirtyFlag = true; + } + }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/big-numbers/test/test.ts b/packages/codemods/ethers/v6/big-numbers/test/test.ts index e6070920f..c1eb663f5 100644 --- a/packages/codemods/ethers/v6/big-numbers/test/test.ts +++ b/packages/codemods/ethers/v6/big-numbers/test/test.ts @@ -1,40 +1,48 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethereumjs/1/big-number-to-big-int-and-operator-transformations', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethereumjs/1/big-number-to-big-int-and-operator-transformations", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/big-numbers/tsconfig.json b/packages/codemods/ethers/v6/big-numbers/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/big-numbers/tsconfig.json +++ b/packages/codemods/ethers/v6/big-numbers/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/big-numbers/vitest.config.ts b/packages/codemods/ethers/v6/big-numbers/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/big-numbers/vitest.config.ts +++ b/packages/codemods/ethers/v6/big-numbers/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/.codemodrc.json b/packages/codemods/ethers/v6/contracts-ambiguous-methods/.codemodrc.json index f088aea66..3a9977484 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/.codemodrc.json +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "Migration" - ] + "tags": ["ethers.js", "Migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/package.json b/packages/codemods/ethers/v6/contracts-ambiguous-methods/package.json index 63be692d8..60746201c 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/package.json +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/src/index.ts b/packages/codemods/ethers/v6/contracts-ambiguous-methods/src/index.ts index f66e42ab3..dc2a2e5c0 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/src/index.ts +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/src/index.ts @@ -4,16 +4,22 @@ export default function transform(file, api) { let dirtyFlag = false; // Find all call expressions - root.find(j.CallExpression).forEach(path => { + root.find(j.CallExpression).forEach((path) => { const { callee, arguments: args } = path.node; // Check if the callee is a member expression and the object is 'contract' and property is 'foo' - if (j.MemberExpression.check(callee) && j.Identifier.check(callee.object) && callee.object.name === 'contract' && j.Identifier.check(callee.property) && callee.property.name === 'foo') { + if ( + j.MemberExpression.check(callee) && + j.Identifier.check(callee.object) && + callee.object.name === "contract" && + j.Identifier.check(callee.property) && + callee.property.name === "foo" + ) { // Wrap the first argument with Typed.address if (args.length > 0) { path.node.arguments[0] = j.callExpression( - j.memberExpression(j.identifier('Typed'), j.identifier('address')), - [args[0]] + j.memberExpression(j.identifier("Typed"), j.identifier("address")), + [args[0]], ); dirtyFlag = true; } @@ -21,4 +27,4 @@ export default function transform(file, api) { }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/test/test.ts b/packages/codemods/ethers/v6/contracts-ambiguous-methods/test/test.ts index 3555c55ce..637c3bb4f 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/test/test.ts +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/test/test.ts @@ -1,40 +1,48 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('contract-to-typed-address-wrapper', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("contract-to-typed-address-wrapper", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/tsconfig.json b/packages/codemods/ethers/v6/contracts-ambiguous-methods/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/tsconfig.json +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-ambiguous-methods/vitest.config.ts b/packages/codemods/ethers/v6/contracts-ambiguous-methods/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/contracts-ambiguous-methods/vitest.config.ts +++ b/packages/codemods/ethers/v6/contracts-ambiguous-methods/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/contracts-other-methods/.codemodrc.json b/packages/codemods/ethers/v6/contracts-other-methods/.codemodrc.json index 8d303e233..d53000d0c 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/.codemodrc.json +++ b/packages/codemods/ethers/v6/contracts-other-methods/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "Migration" - ] + "tags": ["ethers.js", "Migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-other-methods/package.json b/packages/codemods/ethers/v6/contracts-other-methods/package.json index 4245d4eac..672c3a5bb 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/package.json +++ b/packages/codemods/ethers/v6/contracts-other-methods/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-other-methods/src/index.ts b/packages/codemods/ethers/v6/contracts-other-methods/src/index.ts index 6856b8600..49918637b 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/src/index.ts +++ b/packages/codemods/ethers/v6/contracts-other-methods/src/index.ts @@ -6,10 +6,13 @@ export default function transform(file, api, options) { // Helper function to transform the method calls function transformMethodCall(path, newMethod) { const { object, property } = path.value.callee; - if (j.MemberExpression.check(object) && j.Identifier.check(object.property)) { + if ( + j.MemberExpression.check(object) && + j.Identifier.check(object.property) + ) { const newCallee = j.memberExpression( j.memberExpression(object.object, property), - j.identifier(newMethod) + j.identifier(newMethod), ); path.value.callee = newCallee; dirtyFlag = true; @@ -17,32 +20,52 @@ export default function transform(file, api, options) { } // Transform contract.functions.foo(addr) to contract.foo.staticCallResult(addr) - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'contract' }, property: { name: 'functions' } } - } - }).forEach(path => transformMethodCall(path, 'staticCallResult')); + root + .find(j.CallExpression, { + callee: { + object: { + object: { name: "contract" }, + property: { name: "functions" }, + }, + }, + }) + .forEach((path) => transformMethodCall(path, "staticCallResult")); // Transform contract.callStatic.foo(addr) to contract.foo.staticCall(addr) - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'contract' }, property: { name: 'callStatic' } } - } - }).forEach(path => transformMethodCall(path, 'staticCall')); + root + .find(j.CallExpression, { + callee: { + object: { + object: { name: "contract" }, + property: { name: "callStatic" }, + }, + }, + }) + .forEach((path) => transformMethodCall(path, "staticCall")); // Transform contract.estimateGas.foo(addr) to contract.foo.estimateGas(addr) - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'contract' }, property: { name: 'estimateGas' } } - } - }).forEach(path => transformMethodCall(path, 'estimateGas')); + root + .find(j.CallExpression, { + callee: { + object: { + object: { name: "contract" }, + property: { name: "estimateGas" }, + }, + }, + }) + .forEach((path) => transformMethodCall(path, "estimateGas")); // Transform contract.populateTransaction.foo(addr) to contract.foo.populateTransaction(addr) - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'contract' }, property: { name: 'populateTransaction' } } - } - }).forEach(path => transformMethodCall(path, 'populateTransaction')); + root + .find(j.CallExpression, { + callee: { + object: { + object: { name: "contract" }, + property: { name: "populateTransaction" }, + }, + }, + }) + .forEach((path) => transformMethodCall(path, "populateTransaction")); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-other-methods/test/test.ts b/packages/codemods/ethers/v6/contracts-other-methods/test/test.ts index 029e8e04e..8d11ce12c 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/test/test.ts +++ b/packages/codemods/ethers/v6/contracts-other-methods/test/test.ts @@ -1,91 +1,123 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethers/5/contract-methods-refactor', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethers/5/contract-methods-refactor", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #3', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.output.ts'), 'utf-8'); + it("test #3", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #4', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.output.ts'), 'utf-8'); + it("test #4", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/contracts-other-methods/tsconfig.json b/packages/codemods/ethers/v6/contracts-other-methods/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/tsconfig.json +++ b/packages/codemods/ethers/v6/contracts-other-methods/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/contracts-other-methods/vitest.config.ts b/packages/codemods/ethers/v6/contracts-other-methods/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/contracts-other-methods/vitest.config.ts +++ b/packages/codemods/ethers/v6/contracts-other-methods/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/importing/.codemodrc.json b/packages/codemods/ethers/v6/importing/.codemodrc.json index bec65974d..531887dbc 100644 --- a/packages/codemods/ethers/v6/importing/.codemodrc.json +++ b/packages/codemods/ethers/v6/importing/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "migration" - ] + "tags": ["ethers.js", "migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/importing/package.json b/packages/codemods/ethers/v6/importing/package.json index deca78944..6b8d011e1 100644 --- a/packages/codemods/ethers/v6/importing/package.json +++ b/packages/codemods/ethers/v6/importing/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/importing/src/index.ts b/packages/codemods/ethers/v6/importing/src/index.ts index 123f56571..3cf24d8fe 100644 --- a/packages/codemods/ethers/v6/importing/src/index.ts +++ b/packages/codemods/ethers/v6/importing/src/index.ts @@ -4,29 +4,42 @@ export default function transform(file, api) { let dirtyFlag = false; // Transform import statements - root.find(j.ImportDeclaration).forEach(path => { - if (j.Literal.check(path.node.source) && path.node.source.value === '@ethersproject/providers') { - path.node.source.value = 'ethers/providers'; + root.find(j.ImportDeclaration).forEach((path) => { + if ( + j.Literal.check(path.node.source) && + path.node.source.value === "@ethersproject/providers" + ) { + path.node.source.value = "ethers/providers"; dirtyFlag = true; } }); // Transform destructured InfuraProvider from providers object - root.find(j.VariableDeclarator).forEach(path => { - if (j.ObjectPattern.check(path.node.id) && path.node.init && j.Identifier.check(path.node.init) && path.node.init.name === 'providers') { - path.node.id.properties.forEach(property => { - if (j.Identifier.check(property.key) && property.key.name === 'InfuraProvider') { + root.find(j.VariableDeclarator).forEach((path) => { + if ( + j.ObjectPattern.check(path.node.id) && + path.node.init && + j.Identifier.check(path.node.init) && + path.node.init.name === "providers" + ) { + path.node.id.properties.forEach((property) => { + if ( + j.Identifier.check(property.key) && + property.key.name === "InfuraProvider" + ) { // Remove the entire variable declaration if it only contains InfuraProvider if (path.node.id.properties.length === 1) { j(path).remove(); } else { // Remove the destructured InfuraProvider - path.node.id.properties = path.node.id.properties.filter(prop => prop.key.name !== 'InfuraProvider'); + path.node.id.properties = path.node.id.properties.filter( + (prop) => prop.key.name !== "InfuraProvider", + ); } // Add import statement for InfuraProvider from 'ethers' const importDeclaration = j.importDeclaration( - [j.importSpecifier(j.identifier('InfuraProvider'))], - j.literal('ethers') + [j.importSpecifier(j.identifier("InfuraProvider"))], + j.literal("ethers"), ); root.get().node.program.body.unshift(importDeclaration); dirtyFlag = true; @@ -36,4 +49,4 @@ export default function transform(file, api) { }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/importing/test/test.ts b/packages/codemods/ethers/v6/importing/test/test.ts index c167a826b..3ad139e6d 100644 --- a/packages/codemods/ethers/v6/importing/test/test.ts +++ b/packages/codemods/ethers/v6/importing/test/test.ts @@ -1,57 +1,73 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethers/5/import-infura-provider-refactor', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethers/5/import-infura-provider-refactor", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/importing/tsconfig.json b/packages/codemods/ethers/v6/importing/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/importing/tsconfig.json +++ b/packages/codemods/ethers/v6/importing/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/importing/vitest.config.ts b/packages/codemods/ethers/v6/importing/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/importing/vitest.config.ts +++ b/packages/codemods/ethers/v6/importing/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/migration-recipe/.codemodrc.json b/packages/codemods/ethers/v6/migration-recipe/.codemodrc.json index 20d033520..1335c7483 100644 --- a/packages/codemods/ethers/v6/migration-recipe/.codemodrc.json +++ b/packages/codemods/ethers/v6/migration-recipe/.codemodrc.json @@ -4,40 +4,14 @@ "version": "1.0.1", "engine": "recipe", "private": false, - "include": [ - "**/*.js", - "**/*.jsx", - "**/*.ts", - "**/*.tsx", - "**/*.vue" - ], + "include": ["**/*.js", "**/*.jsx", "**/*.ts", "**/*.tsx", "**/*.vue"], "applicability": { - "from": [ - [ - "ethers", - ">=", - "5.0.0" - ], - [ - "ethers", - "<", - "6.0.0" - ] - ], - "to": [ - [ - "ethers", - ">=", - "6.0.0" - ] - ] + "from": [["ethers", ">=", "5.0.0"], ["ethers", "<", "6.0.0"]], + "to": [["ethers", ">=", "6.0.0"]] }, "arguments": [], "meta": { - "tags": [ - "migration", - "ethers" - ], + "tags": ["migration", "ethers"], "git": "https://github.com/Yugal41735/codemod.git" }, "names": [ @@ -50,4 +24,4 @@ "Ethers/6/Contracts/Ambigous-Methods", "Ethers/6/Contracts/Other-Method-Operations" ] -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/providers/.codemodrc.json b/packages/codemods/ethers/v6/providers/.codemodrc.json index a28606cde..998c7caa3 100644 --- a/packages/codemods/ethers/v6/providers/.codemodrc.json +++ b/packages/codemods/ethers/v6/providers/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "migration" - ] + "tags": ["ethers.js", "migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/providers/package.json b/packages/codemods/ethers/v6/providers/package.json index 53feb1eee..1500faaca 100644 --- a/packages/codemods/ethers/v6/providers/package.json +++ b/packages/codemods/ethers/v6/providers/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/providers/src/index.ts b/packages/codemods/ethers/v6/providers/src/index.ts index e73bee2a0..b47179459 100644 --- a/packages/codemods/ethers/v6/providers/src/index.ts +++ b/packages/codemods/ethers/v6/providers/src/index.ts @@ -4,76 +4,84 @@ export default function transform(file, api) { let dirtyFlag = false; // Transform `new ethers.providers.Web3Provider(window.ethereum)` to `new ethers.BrowserProvider(window.ethereum)` - root.find(j.NewExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'providers' } }, - property: { name: 'Web3Provider' } - } - }).forEach(path => { - path.node.callee = j.memberExpression( - j.identifier('ethers'), - j.identifier('BrowserProvider') - ); - dirtyFlag = true; - }); + root + .find(j.NewExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "providers" } }, + property: { name: "Web3Provider" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("BrowserProvider"), + ); + dirtyFlag = true; + }); // Transform `provider.sendTransaction(signedTx)` to `provider.broadcastTransaction(signedTx)` - root.find(j.CallExpression, { - callee: { - object: { name: 'provider' }, - property: { name: 'sendTransaction' } - } - }).forEach(path => { - path.node.callee.property.name = 'broadcastTransaction'; - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { name: "provider" }, + property: { name: "sendTransaction" }, + }, + }) + .forEach((path) => { + path.node.callee.property.name = "broadcastTransaction"; + dirtyFlag = true; + }); // Transform `new StaticJsonRpcProvider(url, network)` to `new JsonRpcProvider(url, network, { staticNetwork: network })` - root.find(j.NewExpression, { - callee: { name: 'StaticJsonRpcProvider' } - }).forEach(path => { - const [url, network] = path.node.arguments; - path.node.callee = j.identifier('JsonRpcProvider'); - path.node.arguments = [ - url, - network, - j.objectExpression([ - j.property.from({ - kind: 'init', - key: j.identifier('staticNetwork'), - value: network, - shorthand: true - }) - ]) - ]; - dirtyFlag = true; - }); + root + .find(j.NewExpression, { + callee: { name: "StaticJsonRpcProvider" }, + }) + .forEach((path) => { + const [url, network] = path.node.arguments; + path.node.callee = j.identifier("JsonRpcProvider"); + path.node.arguments = [ + url, + network, + j.objectExpression([ + j.property.from({ + kind: "init", + key: j.identifier("staticNetwork"), + value: network, + shorthand: true, + }), + ]), + ]; + dirtyFlag = true; + }); // Transform `await provider.getGasPrice()` to `(await provider.getFeeData()).gasPrice` - root.find(j.AwaitExpression, { - argument: { - callee: { - object: { name: 'provider' }, - property: { name: 'getGasPrice' } - } - } - }).forEach(path => { - path.replace( - j.memberExpression( - j.awaitExpression( - j.callExpression( - j.memberExpression( - j.identifier('provider'), - j.identifier('getFeeData') + root + .find(j.AwaitExpression, { + argument: { + callee: { + object: { name: "provider" }, + property: { name: "getGasPrice" }, + }, + }, + }) + .forEach((path) => { + path.replace( + j.memberExpression( + j.awaitExpression( + j.callExpression( + j.memberExpression( + j.identifier("provider"), + j.identifier("getFeeData"), + ), + [], ), - [] - ) + ), + j.identifier("gasPrice"), ), - j.identifier('gasPrice') - ) - ); - dirtyFlag = true; - }); + ); + dirtyFlag = true; + }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/providers/test/test.ts b/packages/codemods/ethers/v6/providers/test/test.ts index 770e53db0..6386fdae2 100644 --- a/packages/codemods/ethers/v6/providers/test/test.ts +++ b/packages/codemods/ethers/v6/providers/test/test.ts @@ -1,91 +1,123 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethers/5/provider-methods-update', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethers/5/provider-methods-update", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #3', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.output.ts'), 'utf-8'); + it("test #3", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #4', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.output.ts'), 'utf-8'); + it("test #4", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/providers/tsconfig.json b/packages/codemods/ethers/v6/providers/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/providers/tsconfig.json +++ b/packages/codemods/ethers/v6/providers/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/providers/vitest.config.ts b/packages/codemods/ethers/v6/providers/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/providers/vitest.config.ts +++ b/packages/codemods/ethers/v6/providers/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/singatures/.codemodrc.json b/packages/codemods/ethers/v6/singatures/.codemodrc.json index b5466681f..4be4a44c3 100644 --- a/packages/codemods/ethers/v6/singatures/.codemodrc.json +++ b/packages/codemods/ethers/v6/singatures/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "migration" - ] + "tags": ["ethers.js", "migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/singatures/package.json b/packages/codemods/ethers/v6/singatures/package.json index 9315d7717..000921c91 100644 --- a/packages/codemods/ethers/v6/singatures/package.json +++ b/packages/codemods/ethers/v6/singatures/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/singatures/src/index.ts b/packages/codemods/ethers/v6/singatures/src/index.ts index 514fb9def..2c696afe6 100644 --- a/packages/codemods/ethers/v6/singatures/src/index.ts +++ b/packages/codemods/ethers/v6/singatures/src/index.ts @@ -4,47 +4,57 @@ export default function transform(file, api) { let dirtyFlag = false; // Replace splitSignature with ethers.Signature.from - root.find(j.AssignmentExpression, { - right: { - type: 'CallExpression', - callee: { name: 'splitSignature' } - } - }).forEach(path => { - const { node } = path; - if (j.Identifier.check(node.left) && node.left.name === 'splitSig') { - node.right = j.callExpression( - j.memberExpression( - j.memberExpression(j.identifier('ethers'), j.identifier('Signature')), - j.identifier('from') - ), - node.right.arguments - ); - dirtyFlag = true; - } - }); + root + .find(j.AssignmentExpression, { + right: { + type: "CallExpression", + callee: { name: "splitSignature" }, + }, + }) + .forEach((path) => { + const { node } = path; + if (j.Identifier.check(node.left) && node.left.name === "splitSig") { + node.right = j.callExpression( + j.memberExpression( + j.memberExpression( + j.identifier("ethers"), + j.identifier("Signature"), + ), + j.identifier("from"), + ), + node.right.arguments, + ); + dirtyFlag = true; + } + }); // Replace joinSignature with ethers.Signature.from and access serialized property - root.find(j.AssignmentExpression, { - right: { - type: 'CallExpression', - callee: { name: 'joinSignature' } - } - }).forEach(path => { - const { node } = path; - if (j.Identifier.check(node.left) && node.left.name === 'sigBytes') { - node.right = j.memberExpression( - j.callExpression( - j.memberExpression( - j.memberExpression(j.identifier('ethers'), j.identifier('Signature')), - j.identifier('from') + root + .find(j.AssignmentExpression, { + right: { + type: "CallExpression", + callee: { name: "joinSignature" }, + }, + }) + .forEach((path) => { + const { node } = path; + if (j.Identifier.check(node.left) && node.left.name === "sigBytes") { + node.right = j.memberExpression( + j.callExpression( + j.memberExpression( + j.memberExpression( + j.identifier("ethers"), + j.identifier("Signature"), + ), + j.identifier("from"), + ), + node.right.arguments, ), - node.right.arguments - ), - j.identifier('serialized') - ); - dirtyFlag = true; - } - }); + j.identifier("serialized"), + ); + dirtyFlag = true; + } + }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/singatures/test/test.ts b/packages/codemods/ethers/v6/singatures/test/test.ts index 427044ee5..d30cc9c06 100644 --- a/packages/codemods/ethers/v6/singatures/test/test.ts +++ b/packages/codemods/ethers/v6/singatures/test/test.ts @@ -1,57 +1,73 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethers/5/replace-split-join-signature', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethers/5/replace-split-join-signature", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/singatures/tsconfig.json b/packages/codemods/ethers/v6/singatures/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/singatures/tsconfig.json +++ b/packages/codemods/ethers/v6/singatures/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/singatures/vitest.config.ts b/packages/codemods/ethers/v6/singatures/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/singatures/vitest.config.ts +++ b/packages/codemods/ethers/v6/singatures/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/transactions/.codemodrc.json b/packages/codemods/ethers/v6/transactions/.codemodrc.json index eff90b6e4..46efd588a 100644 --- a/packages/codemods/ethers/v6/transactions/.codemodrc.json +++ b/packages/codemods/ethers/v6/transactions/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "migration" - ] + "tags": ["ethers.js", "migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/transactions/package.json b/packages/codemods/ethers/v6/transactions/package.json index d6180f5b1..7049c2c7b 100644 --- a/packages/codemods/ethers/v6/transactions/package.json +++ b/packages/codemods/ethers/v6/transactions/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/transactions/src/index.ts b/packages/codemods/ethers/v6/transactions/src/index.ts index 4459f7bbb..96763b371 100644 --- a/packages/codemods/ethers/v6/transactions/src/index.ts +++ b/packages/codemods/ethers/v6/transactions/src/index.ts @@ -4,31 +4,39 @@ export default function transform(file, api, options) { let dirtyFlag = false; // Replace parseTransaction(txBytes) with Transaction.from(txBytes) - root.find(j.CallExpression, { callee: { name: 'parseTransaction' } }) - .forEach(path => { + root + .find(j.CallExpression, { callee: { name: "parseTransaction" } }) + .forEach((path) => { if (path.node.arguments.length === 1) { path.replace( j.callExpression( - j.memberExpression(j.identifier('Transaction'), j.identifier('from')), - path.node.arguments - ) + j.memberExpression( + j.identifier("Transaction"), + j.identifier("from"), + ), + path.node.arguments, + ), ); dirtyFlag = true; } }); // Replace serializeTransaction(tx) and serializeTransaction(tx, sig) with Transaction.from(tx).serialized - root.find(j.CallExpression, { callee: { name: 'serializeTransaction' } }) - .forEach(path => { + root + .find(j.CallExpression, { callee: { name: "serializeTransaction" } }) + .forEach((path) => { if (path.node.arguments.length >= 1) { path.replace( j.memberExpression( j.callExpression( - j.memberExpression(j.identifier('Transaction'), j.identifier('from')), - [path.node.arguments[0]] + j.memberExpression( + j.identifier("Transaction"), + j.identifier("from"), + ), + [path.node.arguments[0]], ), - j.identifier('serialized') - ) + j.identifier("serialized"), + ), ); dirtyFlag = true; } @@ -36,10 +44,14 @@ export default function transform(file, api, options) { // Remove any import statements for 'Transaction' from 'anotherlib' if (dirtyFlag) { - root.find(j.ImportDeclaration, { source: { value: 'anotherlib' } }) - .forEach(path => { - path.node.specifiers = path.node.specifiers.filter(specifier => { - return !(j.ImportSpecifier.check(specifier) && specifier.imported.name === 'Transaction'); + root + .find(j.ImportDeclaration, { source: { value: "anotherlib" } }) + .forEach((path) => { + path.node.specifiers = path.node.specifiers.filter((specifier) => { + return !( + j.ImportSpecifier.check(specifier) && + specifier.imported.name === "Transaction" + ); }); if (path.node.specifiers.length === 0) { j(path).remove(); @@ -48,4 +60,4 @@ export default function transform(file, api, options) { } return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/transactions/test/test.ts b/packages/codemods/ethers/v6/transactions/test/test.ts index e60922490..2e0fae2f6 100644 --- a/packages/codemods/ethers/v6/transactions/test/test.ts +++ b/packages/codemods/ethers/v6/transactions/test/test.ts @@ -1,74 +1,98 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('transaction-methods-refactoring', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("transaction-methods-refactoring", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #3', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.output.ts'), 'utf-8'); + it("test #3", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/transactions/tsconfig.json b/packages/codemods/ethers/v6/transactions/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/transactions/tsconfig.json +++ b/packages/codemods/ethers/v6/transactions/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/transactions/vitest.config.ts b/packages/codemods/ethers/v6/transactions/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/transactions/vitest.config.ts +++ b/packages/codemods/ethers/v6/transactions/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/utilities/.codemodrc.json b/packages/codemods/ethers/v6/utilities/.codemodrc.json index 870abf317..f53a03e9e 100644 --- a/packages/codemods/ethers/v6/utilities/.codemodrc.json +++ b/packages/codemods/ethers/v6/utilities/.codemodrc.json @@ -6,9 +6,6 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "ethers.js", - "migration" - ] + "tags": ["ethers.js", "migration"] } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/utilities/package.json b/packages/codemods/ethers/v6/utilities/package.json index 98283efc0..defc16722 100644 --- a/packages/codemods/ethers/v6/utilities/package.json +++ b/packages/codemods/ethers/v6/utilities/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/utilities/src/index.ts b/packages/codemods/ethers/v6/utilities/src/index.ts index d996274bb..020324ac2 100644 --- a/packages/codemods/ethers/v6/utilities/src/index.ts +++ b/packages/codemods/ethers/v6/utilities/src/index.ts @@ -4,160 +4,237 @@ export default function transform(file, api) { let dirtyFlag = false; // Replace ethers.utils.formatBytes32String with ethers.encodeBytes32String - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'formatBytes32String' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('encodeBytes32String')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "formatBytes32String" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("encodeBytes32String"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.parseBytes32String with ethers.decodeBytes32String - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'parseBytes32String' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('decodeBytes32String')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "parseBytes32String" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("decodeBytes32String"), + ); + dirtyFlag = true; + }); // Replace ethers.constants.AddressZero with ethers.ZeroAddress - root.find(j.MemberExpression, { - object: { object: { name: 'ethers' }, property: { name: 'constants' } }, - property: { name: 'AddressZero' } - }).forEach(path => { - path.node.object = j.identifier('ethers'); - path.node.property = j.identifier('ZeroAddress'); - dirtyFlag = true; - }); + root + .find(j.MemberExpression, { + object: { object: { name: "ethers" }, property: { name: "constants" } }, + property: { name: "AddressZero" }, + }) + .forEach((path) => { + path.node.object = j.identifier("ethers"); + path.node.property = j.identifier("ZeroAddress"); + dirtyFlag = true; + }); // Replace ethers.constants.HashZero with ethers.ZeroHash - root.find(j.MemberExpression, { - object: { object: { name: 'ethers' }, property: { name: 'constants' } }, - property: { name: 'HashZero' } - }).forEach(path => { - path.node.object = j.identifier('ethers'); - path.node.property = j.identifier('ZeroHash'); - dirtyFlag = true; - }); + root + .find(j.MemberExpression, { + object: { object: { name: "ethers" }, property: { name: "constants" } }, + property: { name: "HashZero" }, + }) + .forEach((path) => { + path.node.object = j.identifier("ethers"); + path.node.property = j.identifier("ZeroHash"); + dirtyFlag = true; + }); // Replace ethers.utils.hexDataSlice with ethers.dataSlice - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'hexDataSlice' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('dataSlice')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "hexDataSlice" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("dataSlice"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.hexZeroPad with ethers.zeroPadValue - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'hexZeroPad' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('zeroPadValue')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "hexZeroPad" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("zeroPadValue"), + ); + dirtyFlag = true; + }); // Replace hexlify with toBeHex - root.find(j.CallExpression, { - callee: { name: 'hexlify' } - }).forEach(path => { - path.node.callee = j.identifier('toBeHex'); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { name: "hexlify" }, + }) + .forEach((path) => { + path.node.callee = j.identifier("toBeHex"); + dirtyFlag = true; + }); // Replace AbiCoder.defaultAbiCoder with AbiCoder.defaultAbiCoder() - root.find(j.MemberExpression, { - object: { name: 'AbiCoder' }, - property: { name: 'defaultAbiCoder' } - }).forEach(path => { - path.replace(j.callExpression(j.memberExpression(j.identifier('AbiCoder'), j.identifier('defaultAbiCoder')), [])); - dirtyFlag = true; - }); + root + .find(j.MemberExpression, { + object: { name: "AbiCoder" }, + property: { name: "defaultAbiCoder" }, + }) + .forEach((path) => { + path.replace( + j.callExpression( + j.memberExpression( + j.identifier("AbiCoder"), + j.identifier("defaultAbiCoder"), + ), + [], + ), + ); + dirtyFlag = true; + }); // Replace ethers.utils.hexValue with ethers.toQuantity - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'hexValue' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('toQuantity')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "hexValue" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("toQuantity"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.arrayify with ethers.getBytes - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'arrayify' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('getBytes')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "arrayify" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("getBytes"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.solidityPack with ethers.solidityPacked - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'solidityPack' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('solidityPacked')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "solidityPack" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("solidityPacked"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.solidityKeccak256 with ethers.solidityPackedKeccak256 - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'solidityKeccak256' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('solidityPackedKeccak256')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "solidityKeccak256" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("solidityPackedKeccak256"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.soliditySha256 with ethers.solidityPackedSha256 - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'soliditySha256' } - } - }).forEach(path => { - path.node.callee = j.memberExpression(j.identifier('ethers'), j.identifier('solidityPackedSha256')); - dirtyFlag = true; - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "soliditySha256" }, + }, + }) + .forEach((path) => { + path.node.callee = j.memberExpression( + j.identifier("ethers"), + j.identifier("solidityPackedSha256"), + ); + dirtyFlag = true; + }); // Replace ethers.utils.defineReadOnly with ethers.defineProperties - root.find(j.CallExpression, { - callee: { - object: { object: { name: 'ethers' }, property: { name: 'utils' } }, - property: { name: 'defineReadOnly' } - } - }).forEach(path => { - const args = path.node.arguments; - if (args.length === 3) { - const obj = args[0]; - const key = args[1]; - const value = args[2]; - path.replace(j.callExpression( - j.memberExpression(j.identifier('ethers'), j.identifier('defineProperties')), - [obj, j.objectExpression([j.property.from({ kind: 'init', key: j.identifier(key.value), value })])] - )); - dirtyFlag = true; - } - }); + root + .find(j.CallExpression, { + callee: { + object: { object: { name: "ethers" }, property: { name: "utils" } }, + property: { name: "defineReadOnly" }, + }, + }) + .forEach((path) => { + const args = path.node.arguments; + if (args.length === 3) { + const obj = args[0]; + const key = args[1]; + const value = args[2]; + path.replace( + j.callExpression( + j.memberExpression( + j.identifier("ethers"), + j.identifier("defineProperties"), + ), + [ + obj, + j.objectExpression([ + j.property.from({ + kind: "init", + key: j.identifier(key.value), + value, + }), + ]), + ], + ), + ); + dirtyFlag = true; + } + }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/utilities/test/test.ts b/packages/codemods/ethers/v6/utilities/test/test.ts index ed9125782..f27c35276 100644 --- a/packages/codemods/ethers/v6/utilities/test/test.ts +++ b/packages/codemods/ethers/v6/utilities/test/test.ts @@ -1,142 +1,198 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('ethers/utils-to-core-methods-migration', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("ethers/utils-to-core-methods-migration", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #2', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture2.output.ts'), 'utf-8'); + it("test #2", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture2.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #3', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture3.output.ts'), 'utf-8'); + it("test #3", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture3.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #4', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture4.output.ts'), 'utf-8'); + it("test #4", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture4.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #5', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture5.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture5.output.ts'), 'utf-8'); + it("test #5", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture5.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture5.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #6', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture6.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture6.output.ts'), 'utf-8'); + it("test #6", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture6.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture6.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); - it('test #7', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture7.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture7.output.ts'), 'utf-8'); + it("test #7", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture7.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture7.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/ethers/v6/utilities/tsconfig.json b/packages/codemods/ethers/v6/utilities/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/ethers/v6/utilities/tsconfig.json +++ b/packages/codemods/ethers/v6/utilities/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/ethers/v6/utilities/vitest.config.ts b/packages/codemods/ethers/v6/utilities/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/ethers/v6/utilities/vitest.config.ts +++ b/packages/codemods/ethers/v6/utilities/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/jasmine/5.0/handling_env-execute/package.json b/packages/codemods/jasmine/5.0/handling_env-execute/package.json index 5922497b9..fb36beada 100644 --- a/packages/codemods/jasmine/5.0/handling_env-execute/package.json +++ b/packages/codemods/jasmine/5.0/handling_env-execute/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/jasmine/5.0/handling_env-execute/src/index.ts b/packages/codemods/jasmine/5.0/handling_env-execute/src/index.ts index 746f40e3e..104f8bc76 100644 --- a/packages/codemods/jasmine/5.0/handling_env-execute/src/index.ts +++ b/packages/codemods/jasmine/5.0/handling_env-execute/src/index.ts @@ -1,29 +1,32 @@ -import { API, FileInfo } from 'jscodeshift'; +import { API, FileInfo } from "jscodeshift"; export default function transformer(fileInfo: FileInfo, api: API) { const j = api.jscodeshift; const root = j(fileInfo.source); // Find all CallExpressions where env.execute is called with a callback - root.find(j.CallExpression, { - callee: { - type: 'MemberExpression', - object: { name: 'env' }, - property: { name: 'execute' } - }, - arguments: (args: any[]) => args.length === 2 && j.FunctionExpression.check(args[1]), - }).forEach((path) => { - const callExpression = path.node; + root + .find(j.CallExpression, { + callee: { + type: "MemberExpression", + object: { name: "env" }, + property: { name: "execute" }, + }, + arguments: (args: any[]) => + args.length === 2 && j.FunctionExpression.check(args[1]), + }) + .forEach((path) => { + const callExpression = path.node; - // Replace the function expression argument with async/await syntax - callExpression.arguments = []; + // Replace the function expression argument with async/await syntax + callExpression.arguments = []; - // Wrap in an await expression - const awaitExpression = j.awaitExpression(callExpression); + // Wrap in an await expression + const awaitExpression = j.awaitExpression(callExpression); - // Replace the old statement with await env.execute() - j(path).replaceWith(awaitExpression); - }); + // Replace the old statement with await env.execute() + j(path).replaceWith(awaitExpression); + }); return root.toSource(); } diff --git a/packages/codemods/jasmine/5.0/handling_env-execute/test/test.ts b/packages/codemods/jasmine/5.0/handling_env-execute/test/test.ts index cd08cce3d..314a2a0bc 100644 --- a/packages/codemods/jasmine/5.0/handling_env-execute/test/test.ts +++ b/packages/codemods/jasmine/5.0/handling_env-execute/test/test.ts @@ -1,40 +1,48 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('handling_env-execute', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("handling_env-execute", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/jasmine/5.0/handling_env-execute/tsconfig.json b/packages/codemods/jasmine/5.0/handling_env-execute/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/jasmine/5.0/handling_env-execute/tsconfig.json +++ b/packages/codemods/jasmine/5.0/handling_env-execute/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/jasmine/5.0/handling_env-execute/vitest.config.ts b/packages/codemods/jasmine/5.0/handling_env-execute/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/jasmine/5.0/handling_env-execute/vitest.config.ts +++ b/packages/codemods/jasmine/5.0/handling_env-execute/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/jasmine/5.0/node-boot-removal/package.json b/packages/codemods/jasmine/5.0/node-boot-removal/package.json index 478aacc88..ef9953b31 100644 --- a/packages/codemods/jasmine/5.0/node-boot-removal/package.json +++ b/packages/codemods/jasmine/5.0/node-boot-removal/package.json @@ -13,11 +13,7 @@ "test": "vitest run", "test:watch": "vitest watch" }, - "files": [ - "README.md", - ".codemodrc.json", - "/dist/index.cjs" - ], + "files": ["README.md", ".codemodrc.json", "/dist/index.cjs"], "type": "module", "author": "yugal41735" -} \ No newline at end of file +} diff --git a/packages/codemods/jasmine/5.0/node-boot-removal/src/index.ts b/packages/codemods/jasmine/5.0/node-boot-removal/src/index.ts index b9d71da6d..3d50681d3 100644 --- a/packages/codemods/jasmine/5.0/node-boot-removal/src/index.ts +++ b/packages/codemods/jasmine/5.0/node-boot-removal/src/index.ts @@ -4,25 +4,32 @@ export default function transform(file, api, options) { let dirtyFlag = false; // Find require statements - root.find(j.VariableDeclarator, { - init: { - callee: { name: 'require' }, - arguments: [{ value: 'jasmine-core/node_boot.js' }] - } - }).forEach(path => { - // Replace with require('jasmine-core').boot - const requireCall = path.value.init; - if (j.CallExpression.check(requireCall) && requireCall.arguments.length === 1) { - const arg = requireCall.arguments[0]; - if (j.Literal.check(arg) && arg.value === 'jasmine-core/node_boot.js') { - path.value.init = j.memberExpression( - j.callExpression(j.identifier('require'), [j.literal('jasmine-core')]), - j.identifier('boot') - ); - dirtyFlag = true; + root + .find(j.VariableDeclarator, { + init: { + callee: { name: "require" }, + arguments: [{ value: "jasmine-core/node_boot.js" }], + }, + }) + .forEach((path) => { + // Replace with require('jasmine-core').boot + const requireCall = path.value.init; + if ( + j.CallExpression.check(requireCall) && + requireCall.arguments.length === 1 + ) { + const arg = requireCall.arguments[0]; + if (j.Literal.check(arg) && arg.value === "jasmine-core/node_boot.js") { + path.value.init = j.memberExpression( + j.callExpression(j.identifier("require"), [ + j.literal("jasmine-core"), + ]), + j.identifier("boot"), + ); + dirtyFlag = true; + } } - } - }); + }); return dirtyFlag ? root.toSource() : undefined; -} \ No newline at end of file +} diff --git a/packages/codemods/jasmine/5.0/node-boot-removal/test/test.ts b/packages/codemods/jasmine/5.0/node-boot-removal/test/test.ts index 6487cc098..172612820 100644 --- a/packages/codemods/jasmine/5.0/node-boot-removal/test/test.ts +++ b/packages/codemods/jasmine/5.0/node-boot-removal/test/test.ts @@ -1,40 +1,48 @@ -import { describe, it } from 'vitest'; -import jscodeshift, { type API } from 'jscodeshift'; -import transform from '../src/index.js'; -import assert from 'node:assert'; -import { readFile } from 'node:fs/promises'; -import { join } from 'node:path'; +import assert from "node:assert"; +import { readFile } from "node:fs/promises"; +import { join } from "node:path"; +import jscodeshift, { type API } from "jscodeshift"; +import { describe, it } from "vitest"; +import transform from "../src/index.js"; const buildApi = (parser: string | undefined): API => ({ j: parser ? jscodeshift.withParser(parser) : jscodeshift, jscodeshift: parser ? jscodeshift.withParser(parser) : jscodeshift, stats: () => { console.error( - 'The stats function was called, which is not supported on purpose', + "The stats function was called, which is not supported on purpose", ); }, report: () => { console.error( - 'The report function was called, which is not supported on purpose', + "The report function was called, which is not supported on purpose", ); }, }); -describe('jasmine/1/require-node-boot-to-boot', () => { - it('test #1', async () => { - const INPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.input.ts'), 'utf-8'); - const OUTPUT = await readFile(join(__dirname, '..', '__testfixtures__/fixture1.output.ts'), 'utf-8'); +describe("jasmine/1/require-node-boot-to-boot", () => { + it("test #1", async () => { + const INPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.input.ts"), + "utf-8", + ); + const OUTPUT = await readFile( + join(__dirname, "..", "__testfixtures__/fixture1.output.ts"), + "utf-8", + ); - const actualOutput = transform({ - path: 'index.js', + const actualOutput = transform( + { + path: "index.js", source: INPUT, }, - buildApi('tsx'), {} + buildApi("tsx"), + {}, ); assert.deepEqual( - actualOutput?.replace(/W/gm, ''), - OUTPUT.replace(/W/gm, ''), + actualOutput?.replace(/W/gm, ""), + OUTPUT.replace(/W/gm, ""), ); }); -}); \ No newline at end of file +}); diff --git a/packages/codemods/jasmine/5.0/node-boot-removal/tsconfig.json b/packages/codemods/jasmine/5.0/node-boot-removal/tsconfig.json index b27702178..e63ca9bdc 100644 --- a/packages/codemods/jasmine/5.0/node-boot-removal/tsconfig.json +++ b/packages/codemods/jasmine/5.0/node-boot-removal/tsconfig.json @@ -3,10 +3,7 @@ "module": "NodeNext", "target": "ESNext", "moduleResolution": "NodeNext", - "lib": [ - "ESNext", - "DOM" - ], + "lib": ["ESNext", "DOM"], "skipLibCheck": true, "esModuleInterop": true, "resolveJsonModule": true, @@ -35,4 +32,4 @@ "ts-node": { "transpileOnly": true } -} \ No newline at end of file +} diff --git a/packages/codemods/jasmine/5.0/node-boot-removal/vitest.config.ts b/packages/codemods/jasmine/5.0/node-boot-removal/vitest.config.ts index 951b877be..772ad4c3b 100644 --- a/packages/codemods/jasmine/5.0/node-boot-removal/vitest.config.ts +++ b/packages/codemods/jasmine/5.0/node-boot-removal/vitest.config.ts @@ -1,7 +1,7 @@ -import { configDefaults, defineConfig } from 'vitest/config'; +import { configDefaults, defineConfig } from "vitest/config"; export default defineConfig({ test: { - include: [...configDefaults.include, '**/test/*.ts'], + include: [...configDefaults.include, "**/test/*.ts"], }, -}); \ No newline at end of file +}); diff --git a/packages/codemods/python/eliminate-async-io/.codemodrc.json b/packages/codemods/python/eliminate-async-io/.codemodrc.json index aa89bf27d..1d257aaac 100644 --- a/packages/codemods/python/eliminate-async-io/.codemodrc.json +++ b/packages/codemods/python/eliminate-async-io/.codemodrc.json @@ -6,11 +6,7 @@ "private": false, "arguments": [], "meta": { - "tags": [ - "python", - "asyncio", - "ast-grep" - ], + "tags": ["python", "asyncio", "ast-grep"], "git": "https://github.com/codemod-com/codemod/tree/main/packages/codemods/python/eliminate-async-io" } -} \ No newline at end of file +} diff --git a/packages/codemods/styledictionary/4/asynchronous-api-file-headers/.codemodrc.json b/packages/codemods/styledictionary/4/asynchronous-api-file-headers/.codemodrc.json index 005aed8aa..420a45f8a 100644 --- a/packages/codemods/styledictionary/4/asynchronous-api-file-headers/.codemodrc.json +++ b/packages/codemods/styledictionary/4/asynchronous-api-file-headers/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/asynchronous-api-file-headers", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/asynchronous-api-file-headers/src/index.ts b/packages/codemods/styledictionary/4/asynchronous-api-file-headers/src/index.ts index 040bcbc19..607f1a6a6 100644 --- a/packages/codemods/styledictionary/4/asynchronous-api-file-headers/src/index.ts +++ b/packages/codemods/styledictionary/4/asynchronous-api-file-headers/src/index.ts @@ -6,55 +6,57 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Rename "formatter" to "format" - root.find(j.Identifier, { name: 'formatter' }).forEach((path) => { - path.node.name = 'format'; - }); + // Rename "formatter" to "format" + root.find(j.Identifier, { name: "formatter" }).forEach((path) => { + path.node.name = "format"; + }); - // Find all fileHeader usages - root.find(j.CallExpression, { - callee: { - name: 'fileHeader', - }, - }).forEach((path) => { - const call = path.node; + // Find all fileHeader usages + root + .find(j.CallExpression, { + callee: { + name: "fileHeader", + }, + }) + .forEach((path) => { + const call = path.node; - // Check if fileHeader is used inside an async function - let asyncFunction = false; - let functionPath = path.parent; + // Check if fileHeader is used inside an async function + let asyncFunction = false; + let functionPath = path.parent; - // Traverse up to find the enclosing function - while (functionPath) { - if ( - functionPath.node.type === 'FunctionDeclaration' || - functionPath.node.type === 'FunctionExpression' || - functionPath.node.type === 'ArrowFunctionExpression' - ) { - if (!functionPath.node.async) { - // Add async to the function if not already async - functionPath.node.async = true; - asyncFunction = true; - } - break; - } - functionPath = functionPath.parent; + // Traverse up to find the enclosing function + while (functionPath) { + if ( + functionPath.node.type === "FunctionDeclaration" || + functionPath.node.type === "FunctionExpression" || + functionPath.node.type === "ArrowFunctionExpression" + ) { + if (!functionPath.node.async) { + // Add async to the function if not already async + functionPath.node.async = true; + asyncFunction = true; + } + break; } + functionPath = functionPath.parent; + } - // Ensure fileHeader is awaited if inside an async function - if (asyncFunction) { - if (call && call.type === 'CallExpression') { - const awaitExpression = j.awaitExpression(call); - j(path).replaceWith(awaitExpression); - } + // Ensure fileHeader is awaited if inside an async function + if (asyncFunction) { + if (call && call.type === "CallExpression") { + const awaitExpression = j.awaitExpression(call); + j(path).replaceWith(awaitExpression); } + } }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/asynchronous-api/.codemodrc.json b/packages/codemods/styledictionary/4/asynchronous-api/.codemodrc.json index ee9f4ef46..eb4f63a43 100644 --- a/packages/codemods/styledictionary/4/asynchronous-api/.codemodrc.json +++ b/packages/codemods/styledictionary/4/asynchronous-api/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/asynchronous-api", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/asynchronous-api/src/index.ts b/packages/codemods/styledictionary/4/asynchronous-api/src/index.ts index 2761aa271..307d6004d 100644 --- a/packages/codemods/styledictionary/4/asynchronous-api/src/index.ts +++ b/packages/codemods/styledictionary/4/asynchronous-api/src/index.ts @@ -1,78 +1,76 @@ import type { - API, - ArrowFunctionExpression, - FileInfo, - Options, -} from 'jscodeshift'; + API, + ArrowFunctionExpression, + FileInfo, + Options, +} from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, + file: FileInfo, + api: API, + options?: Options, ): string | undefined { - const j = api.jscodeshift; + const j = api.jscodeshift; - // Methods that should be awaited - const asyncMethods = [ - 'cleanAllPlatforms', - 'buildAllPlatforms', - 'extend', - 'exportPlatform', - 'getPlatform', - 'buildPlatform', - 'cleanPlatform', - ]; + // Methods that should be awaited + const asyncMethods = [ + "cleanAllPlatforms", + "buildAllPlatforms", + "extend", + "exportPlatform", + "getPlatform", + "buildPlatform", + "cleanPlatform", + ]; - const root = j(file.source); + const root = j(file.source); - // Find all function declarations, function expressions, and arrow functions - root.find(j.FunctionDeclaration).forEach((path) => - addAsyncIfNeeded(path, j), - ); + // Find all function declarations, function expressions, and arrow functions + root.find(j.FunctionDeclaration).forEach((path) => addAsyncIfNeeded(path, j)); - root.find(j.FunctionExpression).forEach((path) => - addAsyncIfNeeded(path, j), - ); + root.find(j.FunctionExpression).forEach((path) => addAsyncIfNeeded(path, j)); - root.find(j.ArrowFunctionExpression).forEach((path) => - addAsyncIfNeeded(path, j), - ); + root + .find(j.ArrowFunctionExpression) + .forEach((path) => addAsyncIfNeeded(path, j)); - // Add 'await' before the relevant method calls, except for StyleDictionary.extend() - asyncMethods.forEach((method) => { - root.find(j.CallExpression, { - callee: { property: { name: method } }, - }).forEach((path) => { - // Check if the method is already awaited - if (!j.AwaitExpression.check(path.parent.node)) { - // Skip if it's StyleDictionary.extend() - if ( - !( - path.node.callee.object && - path.node.callee.object.name === 'StyleDictionary' && - path.node.callee.property.name === 'extend' - ) - ) { - j(path).replaceWith(j.awaitExpression(path.node)); - } - } - }); - }); + // Add 'await' before the relevant method calls, except for StyleDictionary.extend() + asyncMethods.forEach((method) => { + root + .find(j.CallExpression, { + callee: { property: { name: method } }, + }) + .forEach((path) => { + // Check if the method is already awaited + if (!j.AwaitExpression.check(path.parent.node)) { + // Skip if it's StyleDictionary.extend() + if ( + !( + path.node.callee.object && + path.node.callee.object.name === "StyleDictionary" && + path.node.callee.property.name === "extend" + ) + ) { + j(path).replaceWith(j.awaitExpression(path.node)); + } + } + }); + }); - return root.toSource(); + return root.toSource(); - // Helper function to add 'async' if needed - function addAsyncIfNeeded(path, j) { - // Check if the function body contains any of the async methods - const containsAsyncMethod = j(path) - .find(j.CallExpression) - .some((callPath) => - asyncMethods.includes(callPath.node.callee.property?.name), - ); + // Helper function to add 'async' if needed + function addAsyncIfNeeded(path, j) { + // Check if the function body contains any of the async methods + const containsAsyncMethod = j(path) + .find(j.CallExpression) + .some((callPath) => + asyncMethods.includes(callPath.node.callee.property?.name), + ); - // Only mark as async if it contains one of the async methods - if (containsAsyncMethod && !path.node.async) { - path.node.async = true; - } + // Only mark as async if it contains one of the async methods + if (containsAsyncMethod && !path.node.async) { + path.node.async = true; } + } } diff --git a/packages/codemods/styledictionary/4/format-helpers/.codemodrc.json b/packages/codemods/styledictionary/4/format-helpers/.codemodrc.json index 11b79d308..f3c90de4e 100644 --- a/packages/codemods/styledictionary/4/format-helpers/.codemodrc.json +++ b/packages/codemods/styledictionary/4/format-helpers/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/format-helpers", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/format-helpers/src/index.ts b/packages/codemods/styledictionary/4/format-helpers/src/index.ts index 60190a53f..11e837d74 100644 --- a/packages/codemods/styledictionary/4/format-helpers/src/index.ts +++ b/packages/codemods/styledictionary/4/format-helpers/src/index.ts @@ -6,46 +6,48 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Find all destructuring assignments of formatHelpers from StyleDictionary - root.find(j.VariableDeclarator, { - id: { - type: 'ObjectPattern', + // Find all destructuring assignments of formatHelpers from StyleDictionary + root + .find(j.VariableDeclarator, { + id: { + type: "ObjectPattern", + }, + init: { + type: "MemberExpression", + object: { + name: "StyleDictionary", }, - init: { - type: 'MemberExpression', - object: { - name: 'StyleDictionary', - }, - property: { - name: 'formatHelpers', - }, + property: { + name: "formatHelpers", }, - }).forEach((variablePath) => { - // Get the properties being destructured - const destructuredProperties = variablePath.node.id.properties.map( - (prop) => prop.key.name, - ); + }, + }) + .forEach((variablePath) => { + // Get the properties being destructured + const destructuredProperties = variablePath.node.id.properties.map( + (prop) => prop.key.name, + ); - // Remove the old destructuring - j(variablePath).remove(); + // Remove the old destructuring + j(variablePath).remove(); - // Add the new import statement from 'style-dictionary/utils' - const importDeclaration = j.importDeclaration( - destructuredProperties.map((property) => - j.importSpecifier(j.identifier(property)), - ), - j.literal('style-dictionary/utils'), - ); + // Add the new import statement from 'style-dictionary/utils' + const importDeclaration = j.importDeclaration( + destructuredProperties.map((property) => + j.importSpecifier(j.identifier(property)), + ), + j.literal("style-dictionary/utils"), + ); - root.find(j.Program).get('body', 0).insertBefore(importDeclaration); + root.find(j.Program).get("body", 0).insertBefore(importDeclaration); }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/formatting-options/.codemodrc.json b/packages/codemods/styledictionary/4/formatting-options/.codemodrc.json index 9bd6b94bf..bd9741106 100644 --- a/packages/codemods/styledictionary/4/formatting-options/.codemodrc.json +++ b/packages/codemods/styledictionary/4/formatting-options/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/formatting-options", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/formatting-options/src/index.ts b/packages/codemods/styledictionary/4/formatting-options/src/index.ts index 3baaebe4e..c4f7d41ed 100644 --- a/packages/codemods/styledictionary/4/formatting-options/src/index.ts +++ b/packages/codemods/styledictionary/4/formatting-options/src/index.ts @@ -6,79 +6,77 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // List of properties to be moved into the `options` object - const optionsProps = new Set([ - 'className', - 'packageName', - 'type', - 'mapName', - 'name', - 'resourceType', - 'resourceMap', - ]); + // List of properties to be moved into the `options` object + const optionsProps = new Set([ + "className", + "packageName", + "type", + "mapName", + "name", + "resourceType", + "resourceMap", + ]); - // Function to transform an object expression by moving specific properties into an `options` object - function moveToOptions(objectExpression) { - const fileProps = objectExpression.properties; - const optionsObject = j.objectExpression([]); + // Function to transform an object expression by moving specific properties into an `options` object + function moveToOptions(objectExpression) { + const fileProps = objectExpression.properties; + const optionsObject = j.objectExpression([]); - objectExpression.properties = fileProps.filter((prop) => { - if (optionsProps.has(prop.key.name)) { - optionsObject.properties.push(prop); - return false; // remove from the original properties - } - return true; - }); + objectExpression.properties = fileProps.filter((prop) => { + if (optionsProps.has(prop.key.name)) { + optionsObject.properties.push(prop); + return false; // remove from the original properties + } + return true; + }); - // Add `options` property if any options are found - if (optionsObject.properties.length > 0) { - objectExpression.properties.push( - j.property('init', j.identifier('options'), optionsObject), - ); - } + // Add `options` property if any options are found + if (optionsObject.properties.length > 0) { + objectExpression.properties.push( + j.property("init", j.identifier("options"), optionsObject), + ); } + } - // Recursively search for object expressions and process them - root.find(j.ObjectExpression).forEach((path) => { - const obj = path.value; + // Recursively search for object expressions and process them + root.find(j.ObjectExpression).forEach((path) => { + const obj = path.value; - // Check if this object expression has the properties we care about - const hasDestinationAndFormat = obj.properties.some((prop) => { - if (prop.key.name === 'files') { - const filesArray = prop.value.elements; - return filesArray.some((file) => { - return ( - file.type === 'ObjectExpression' && - file.properties.some( - (p) => p.key.name === 'destination', - ) && - file.properties.some((p) => p.key.name === 'format') - ); - }); - } - return false; + // Check if this object expression has the properties we care about + const hasDestinationAndFormat = obj.properties.some((prop) => { + if (prop.key.name === "files") { + const filesArray = prop.value.elements; + return filesArray.some((file) => { + return ( + file.type === "ObjectExpression" && + file.properties.some((p) => p.key.name === "destination") && + file.properties.some((p) => p.key.name === "format") + ); }); + } + return false; + }); - // Only transform if destination and format are present - if (hasDestinationAndFormat) { - obj.properties.forEach((prop) => { - if (prop.value.type === 'ArrayExpression') { - prop.value.elements.forEach((item) => { - if (item.type === 'ObjectExpression') { - moveToOptions(item); - } - }); - } - }); + // Only transform if destination and format are present + if (hasDestinationAndFormat) { + obj.properties.forEach((prop) => { + if (prop.value.type === "ArrayExpression") { + prop.value.elements.forEach((item) => { + if (item.type === "ObjectExpression") { + moveToOptions(item); + } + }); } - }); + }); + } + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-actions/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-actions/.codemodrc.json index 51f97d56a..5b353a14f 100644 --- a/packages/codemods/styledictionary/4/hook-api-actions/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-actions/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-actions", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-actions/src/index.ts b/packages/codemods/styledictionary/4/hook-api-actions/src/index.ts index fabcc7c5a..9ecf2c80b 100644 --- a/packages/codemods/styledictionary/4/hook-api-actions/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-actions/src/index.ts @@ -6,73 +6,69 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Find and update `action` to `hooks.actions` - root.find(j.ObjectExpression).forEach((path) => { - const obj = path.node; + // Find and update `action` to `hooks.actions` + root.find(j.ObjectExpression).forEach((path) => { + const obj = path.node; - // Check if `action` property exists - const actionProp = obj.properties.find( - (prop) => - prop.key.name === 'action' || - (prop.key.type === 'Literal' && prop.key.value === 'action'), - ); + // Check if `action` property exists + const actionProp = obj.properties.find( + (prop) => + prop.key.name === "action" || + (prop.key.type === "Literal" && prop.key.value === "action"), + ); - if (actionProp) { - // Create `hooks` property if it doesn't exist - let hooksProp = obj.properties.find( - (prop) => - prop.key.name === 'hooks' || - (prop.key.type === 'Literal' && prop.key.value === 'hooks'), - ); + if (actionProp) { + // Create `hooks` property if it doesn't exist + let hooksProp = obj.properties.find( + (prop) => + prop.key.name === "hooks" || + (prop.key.type === "Literal" && prop.key.value === "hooks"), + ); - if (!hooksProp) { - hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([]), - ); - obj.properties.push(hooksProp); - } + if (!hooksProp) { + hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([]), + ); + obj.properties.push(hooksProp); + } - const hooksObj = hooksProp.value; - const actionsProp = hooksObj.properties.find( - (prop) => - prop.key.name === 'actions' || - (prop.key.type === 'Literal' && - prop.key.value === 'actions'), - ); + const hooksObj = hooksProp.value; + const actionsProp = hooksObj.properties.find( + (prop) => + prop.key.name === "actions" || + (prop.key.type === "Literal" && prop.key.value === "actions"), + ); - if (!actionsProp) { - // Create `actions` inside `hooks` - const newActionsProp = j.property( - 'init', - j.identifier('actions'), - j.objectExpression([]), - ); - hooksObj.properties.push(newActionsProp); - } + if (!actionsProp) { + // Create `actions` inside `hooks` + const newActionsProp = j.property( + "init", + j.identifier("actions"), + j.objectExpression([]), + ); + hooksObj.properties.push(newActionsProp); + } - // Move `action` properties to `hooks.actions` - const actionsObj = hooksObj.properties.find( - (prop) => - prop.key.name === 'actions' || - (prop.key.type === 'Literal' && - prop.key.value === 'actions'), - ); + // Move `action` properties to `hooks.actions` + const actionsObj = hooksObj.properties.find( + (prop) => + prop.key.name === "actions" || + (prop.key.type === "Literal" && prop.key.value === "actions"), + ); - actionsObj.value.properties.push(...actionProp.value.properties); - obj.properties = obj.properties.filter( - (prop) => prop !== actionProp, - ); - } - }); + actionsObj.value.properties.push(...actionProp.value.properties); + obj.properties = obj.properties.filter((prop) => prop !== actionProp); + } + }); - return root.toSource({ quote: 'single' }); + return root.toSource({ quote: "single" }); } diff --git a/packages/codemods/styledictionary/4/hook-api-file-header/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-file-header/.codemodrc.json index 783504259..b9d0ffb9b 100644 --- a/packages/codemods/styledictionary/4/hook-api-file-header/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-file-header/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-file-header", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-file-header/src/index.ts b/packages/codemods/styledictionary/4/hook-api-file-header/src/index.ts index c2c5a0929..a4fb30c19 100644 --- a/packages/codemods/styledictionary/4/hook-api-file-header/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-file-header/src/index.ts @@ -6,51 +6,47 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Helper function to recursively find and transform fileHeader properties - function transformObjectProperties(objectExpression) { - const properties = objectExpression.properties; + // Helper function to recursively find and transform fileHeader properties + function transformObjectProperties(objectExpression) { + const properties = objectExpression.properties; - properties.forEach((prop, index) => { - if ( - prop.key.name === 'fileHeader' && - prop.value.type === 'ObjectExpression' - ) { - // Create the hooks.fileHeaders property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property( - 'init', - j.identifier('fileHeaders'), - prop.value, - ), - ]), - ); + properties.forEach((prop, index) => { + if ( + prop.key.name === "fileHeader" && + prop.value.type === "ObjectExpression" + ) { + // Create the hooks.fileHeaders property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("fileHeaders"), prop.value), + ]), + ); - // Remove the old fileHeader property - properties.splice(index, 1); + // Remove the old fileHeader property + properties.splice(index, 1); - // Add the new hooks property - properties.push(hooksProp); - } else if (prop.value.type === 'ObjectExpression') { - // Recursively transform nested objects - transformObjectProperties(prop.value); - } - }); - } - - // Find all object expressions in the file and transform them - root.find(j.ObjectExpression).forEach((path) => { - transformObjectProperties(path.node); + // Add the new hooks property + properties.push(hooksProp); + } else if (prop.value.type === "ObjectExpression") { + // Recursively transform nested objects + transformObjectProperties(prop.value); + } }); + } + + // Find all object expressions in the file and transform them + root.find(j.ObjectExpression).forEach((path) => { + transformObjectProperties(path.node); + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-filters/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-filters/.codemodrc.json index 313557187..32a82be44 100644 --- a/packages/codemods/styledictionary/4/hook-api-filters/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-filters/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-filters", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-filters/src/index.ts b/packages/codemods/styledictionary/4/hook-api-filters/src/index.ts index 3d539a590..182834f1b 100644 --- a/packages/codemods/styledictionary/4/hook-api-filters/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-filters/src/index.ts @@ -6,47 +6,47 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Helper function to recursively find and transform filter properties - function transformObjectProperties(objectExpression) { - const properties = objectExpression.properties; + // Helper function to recursively find and transform filter properties + function transformObjectProperties(objectExpression) { + const properties = objectExpression.properties; - properties.forEach((prop, index) => { - if ( - prop.key.name === 'filter' && - prop.value.type === 'ObjectExpression' - ) { - // Create the hooks.filters property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property('init', j.identifier('filters'), prop.value), - ]), - ); + properties.forEach((prop, index) => { + if ( + prop.key.name === "filter" && + prop.value.type === "ObjectExpression" + ) { + // Create the hooks.filters property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("filters"), prop.value), + ]), + ); - // Remove the old filter property - properties.splice(index, 1); + // Remove the old filter property + properties.splice(index, 1); - // Add the new hooks property - properties.push(hooksProp); - } else if (prop.value.type === 'ObjectExpression') { - // Recursively transform nested objects - transformObjectProperties(prop.value); - } - }); - } - - // Find all object expressions in the file and transform them - root.find(j.ObjectExpression).forEach((path) => { - transformObjectProperties(path.node); + // Add the new hooks property + properties.push(hooksProp); + } else if (prop.value.type === "ObjectExpression") { + // Recursively transform nested objects + transformObjectProperties(prop.value); + } }); + } + + // Find all object expressions in the file and transform them + root.find(j.ObjectExpression).forEach((path) => { + transformObjectProperties(path.node); + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-formats/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-formats/.codemodrc.json index f86d734f8..a0438b40c 100644 --- a/packages/codemods/styledictionary/4/hook-api-formats/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-formats/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-formats", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-formats/src/index.ts b/packages/codemods/styledictionary/4/hook-api-formats/src/index.ts index 4f345bbe5..ca30d0103 100644 --- a/packages/codemods/styledictionary/4/hook-api-formats/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-formats/src/index.ts @@ -6,86 +6,88 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Helper function to recursively find and transform format properties - function transformObjectProperties(objectExpression) { - const properties = objectExpression.properties; + // Helper function to recursively find and transform format properties + function transformObjectProperties(objectExpression) { + const properties = objectExpression.properties; - properties.forEach((prop, index) => { - if ( - prop.key.name === 'format' && - prop.value.type === 'ObjectExpression' - ) { - // Create the hooks.formats property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property('init', j.identifier('formats'), prop.value), - ]), - ); + properties.forEach((prop, index) => { + if ( + prop.key.name === "format" && + prop.value.type === "ObjectExpression" + ) { + // Create the hooks.formats property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("formats"), prop.value), + ]), + ); - // Remove the old format property - properties.splice(index, 1); + // Remove the old format property + properties.splice(index, 1); - // Add the new hooks property - properties.push(hooksProp); + // Add the new hooks property + properties.push(hooksProp); - // Transform the inner properties of the format object - const formatProperties = prop.value.properties; - formatProperties.forEach((formatProp) => { - if (formatProp.key.name === 'formatter') { - formatProp.key.name = 'format'; - } - }); - } else if (prop.value.type === 'ObjectExpression') { - // Recursively transform nested objects - transformObjectProperties(prop.value); - } + // Transform the inner properties of the format object + const formatProperties = prop.value.properties; + formatProperties.forEach((formatProp) => { + if (formatProp.key.name === "formatter") { + formatProp.key.name = "format"; + } }); - } - - // Find all object expressions in the file and transform them - root.find(j.ObjectExpression).forEach((path) => { - transformObjectProperties(path.node); + } else if (prop.value.type === "ObjectExpression") { + // Recursively transform nested objects + transformObjectProperties(prop.value); + } }); + } - // Update import statements - root.find(j.ImportDeclaration).forEach((path) => { - const importSpecifiers = path.node.specifiers; + // Find all object expressions in the file and transform them + root.find(j.ObjectExpression).forEach((path) => { + transformObjectProperties(path.node); + }); - importSpecifiers.forEach((specifier) => { - if (specifier.imported && specifier.imported.name === 'Formatter') { - specifier.imported.name = 'FormatFn'; - } else if ( - specifier.imported && - specifier.imported.name === 'FormatterArguments' - ) { - specifier.imported.name = 'FormatFnArguments'; - } - }); + // Update import statements + root.find(j.ImportDeclaration).forEach((path) => { + const importSpecifiers = path.node.specifiers; + + importSpecifiers.forEach((specifier) => { + if (specifier.imported && specifier.imported.name === "Formatter") { + specifier.imported.name = "FormatFn"; + } else if ( + specifier.imported && + specifier.imported.name === "FormatterArguments" + ) { + specifier.imported.name = "FormatFnArguments"; + } }); + }); - // Update StyleDictionary.registerFormat calls - root.find(j.CallExpression, { - callee: { - object: { name: 'StyleDictionary' }, - property: { name: 'registerFormat' }, - }, - }).forEach((path) => { - const properties = path.node.arguments[0].properties; - properties.forEach((prop) => { - if (prop.key.name === 'formatter') { - prop.key.name = 'format'; - } - }); + // Update StyleDictionary.registerFormat calls + root + .find(j.CallExpression, { + callee: { + object: { name: "StyleDictionary" }, + property: { name: "registerFormat" }, + }, + }) + .forEach((path) => { + const properties = path.node.arguments[0].properties; + properties.forEach((prop) => { + if (prop.key.name === "formatter") { + prop.key.name = "format"; + } + }); }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-parsers/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-parsers/.codemodrc.json index 2e3fc1d66..7804e39a4 100644 --- a/packages/codemods/styledictionary/4/hook-api-parsers/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-parsers/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-parsers", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-parsers/src/index.ts b/packages/codemods/styledictionary/4/hook-api-parsers/src/index.ts index 2da68c4ee..96533b261 100644 --- a/packages/codemods/styledictionary/4/hook-api-parsers/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-parsers/src/index.ts @@ -1,133 +1,130 @@ import type { - API, - ArrowFunctionExpression, - FileInfo, - Options, -} from 'jscodeshift'; + API, + ArrowFunctionExpression, + FileInfo, + Options, +} from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, + file: FileInfo, + api: API, + options?: Options, ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); - - // Function to transform parsers array to hooks.parsers object - function transformParsersArray(path) { - // Check if `parsers` is an array property - const parsersProperty = path.value.properties.find( - (prop) => - prop.key.name === 'parsers' && - j.ArrayExpression.check(prop.value), + const j = api.jscodeshift; + const root = j(file.source); + + // Function to transform parsers array to hooks.parsers object + function transformParsersArray(path) { + // Check if `parsers` is an array property + const parsersProperty = path.value.properties.find( + (prop) => + prop.key.name === "parsers" && j.ArrayExpression.check(prop.value), + ); + + if (parsersProperty) { + const parserConfigs = parsersProperty.value.elements; // Get all parser objects + const parserPropertiesMap = new Map(); + + // Iterate over all parser configs + parserConfigs.forEach((parserConfig) => { + const parserProperties = parserConfig.properties; + + // Rename 'parse' property to 'parser' + parserProperties.forEach((prop) => { + if (prop.key.name === "parse") { + prop.key.name = "parser"; // Rename parse to parser + } + }); + + // Generate the parser name based on the file extension in the pattern regex + const patternProperty = parserProperties.find( + (p) => p.key.name === "pattern", ); - - if (parsersProperty) { - const parserConfigs = parsersProperty.value.elements; // Get all parser objects - const parserPropertiesMap = new Map(); - - // Iterate over all parser configs - parserConfigs.forEach((parserConfig) => { - const parserProperties = parserConfig.properties; - - // Rename 'parse' property to 'parser' - parserProperties.forEach((prop) => { - if (prop.key.name === 'parse') { - prop.key.name = 'parser'; // Rename parse to parser - } - }); - - // Generate the parser name based on the file extension in the pattern regex - const patternProperty = parserProperties.find( - (p) => p.key.name === 'pattern', - ); - const patternRegex = patternProperty.value.regex.pattern; // e.g., /\.yaml$/ -> "yaml" - const extensionMatch = patternRegex.match(/\\\.([a-z0-9]+)\$/); - const parserName = extensionMatch - ? `${extensionMatch[1]}-parser` - : 'custom-parser'; - - // Store the parser configuration in a map with parserName as the key - parserPropertiesMap.set(parserName, parserProperties); - }); - - // Create the new `hooks.parsers` object with all parser configurations - const hooksProperty = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property( - 'init', - j.identifier('parsers'), - j.objectExpression( - Array.from(parserPropertiesMap.entries()).map( - ([parserName, properties]) => - j.property( - 'init', - j.literal(parserName), - j.objectExpression([...properties]), // Move all properties inside - ), - ), - ), - ), - ]), - ); - - // Replace `parsers` property with `parsers: [parserNames]` - parsersProperty.value = j.arrayExpression( - Array.from(parserPropertiesMap.keys()).map((parserName) => + const patternRegex = patternProperty.value.regex.pattern; // e.g., /\.yaml$/ -> "yaml" + const extensionMatch = patternRegex.match(/\\\.([a-z0-9]+)\$/); + const parserName = extensionMatch + ? `${extensionMatch[1]}-parser` + : "custom-parser"; + + // Store the parser configuration in a map with parserName as the key + parserPropertiesMap.set(parserName, parserProperties); + }); + + // Create the new `hooks.parsers` object with all parser configurations + const hooksProperty = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property( + "init", + j.identifier("parsers"), + j.objectExpression( + Array.from(parserPropertiesMap.entries()).map( + ([parserName, properties]) => + j.property( + "init", j.literal(parserName), - ), - ); - - // Add the `hooks` property to the root object - path.value.properties.push(hooksProperty); - } + j.objectExpression([...properties]), // Move all properties inside + ), + ), + ), + ), + ]), + ); + + // Replace `parsers` property with `parsers: [parserNames]` + parsersProperty.value = j.arrayExpression( + Array.from(parserPropertiesMap.keys()).map((parserName) => + j.literal(parserName), + ), + ); + + // Add the `hooks` property to the root object + path.value.properties.push(hooksProperty); } + } - // Function to transform StyleDictionary.registerParser calls - function transformRegisterParserCalls(path) { - const args = path.node.arguments; - - // Ensure the first argument is an object expression - if (args.length > 0 && args[0].type === 'ObjectExpression') { - const properties = args[0].properties; - - // Check if 'name' property already exists - const hasNameProperty = properties.some( - (prop) => prop.key.name === 'name', - ); - - // If 'name' property does not exist, add it - if (!hasNameProperty) { - properties.unshift( - j.property( - 'init', - j.identifier('name'), - j.literal('parser-foo'), - ), - ); - } - - // Find and rename 'parse' property to 'parser' - properties.forEach((prop) => { - if (prop.key.name === 'parse') { - prop.key.name = 'parser'; // Rename parse to parser - } - }); - } - } + // Function to transform StyleDictionary.registerParser calls + function transformRegisterParserCalls(path) { + const args = path.node.arguments; - // Apply the transformation for parsers array to hooks.parsers object - root.find(j.ObjectExpression).forEach(transformParsersArray); + // Ensure the first argument is an object expression + if (args.length > 0 && args[0].type === "ObjectExpression") { + const properties = args[0].properties; - // Apply the transformation for StyleDictionary.registerParser calls - root.find(j.CallExpression, { - callee: { - object: { name: 'StyleDictionary' }, - property: { name: 'registerParser' }, - }, - }).forEach(transformRegisterParserCalls); + // Check if 'name' property already exists + const hasNameProperty = properties.some( + (prop) => prop.key.name === "name", + ); - return root.toSource(); + // If 'name' property does not exist, add it + if (!hasNameProperty) { + properties.unshift( + j.property("init", j.identifier("name"), j.literal("parser-foo")), + ); + } + + // Find and rename 'parse' property to 'parser' + properties.forEach((prop) => { + if (prop.key.name === "parse") { + prop.key.name = "parser"; // Rename parse to parser + } + }); + } + } + + // Apply the transformation for parsers array to hooks.parsers object + root.find(j.ObjectExpression).forEach(transformParsersArray); + + // Apply the transformation for StyleDictionary.registerParser calls + root + .find(j.CallExpression, { + callee: { + object: { name: "StyleDictionary" }, + property: { name: "registerParser" }, + }, + }) + .forEach(transformRegisterParserCalls); + + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-preprocessors/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-preprocessors/.codemodrc.json index 699cb2934..639a6a7d5 100644 --- a/packages/codemods/styledictionary/4/hook-api-preprocessors/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-preprocessors/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-preprocessors", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-preprocessors/src/index.ts b/packages/codemods/styledictionary/4/hook-api-preprocessors/src/index.ts index 75e2f7755..7c108551b 100644 --- a/packages/codemods/styledictionary/4/hook-api-preprocessors/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-preprocessors/src/index.ts @@ -6,67 +6,60 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - root.find(j.ObjectExpression).forEach((path) => { - const properties = path.node.properties; + root.find(j.ObjectExpression).forEach((path) => { + const properties = path.node.properties; - const preprocessorPropIndex = properties.findIndex( - (prop) => - prop.key.name === 'preprocessors' && - prop.value.type === 'ObjectExpression', - ); + const preprocessorPropIndex = properties.findIndex( + (prop) => + prop.key.name === "preprocessors" && + prop.value.type === "ObjectExpression", + ); - if (preprocessorPropIndex !== -1) { - const preprocessorProp = properties[preprocessorPropIndex]; - const preprocessorValue = preprocessorProp.value; + if (preprocessorPropIndex !== -1) { + const preprocessorProp = properties[preprocessorPropIndex]; + const preprocessorValue = preprocessorProp.value; - // Create the hooks.preprocessors property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property( - 'init', - j.identifier('preprocessors'), - preprocessorValue, - ), - ]), - ); + // Create the hooks.preprocessors property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("preprocessors"), preprocessorValue), + ]), + ); - // Remove the old preprocessors property - properties.splice(preprocessorPropIndex, 1); + // Remove the old preprocessors property + properties.splice(preprocessorPropIndex, 1); - // Add the new hooks property - properties.push(hooksProp); + // Add the new hooks property + properties.push(hooksProp); - // Create the global preprocessors property with string literals - const globalPreprocessorsProp = j.property( - 'init', - j.identifier('preprocessors'), - j.arrayExpression( - preprocessorValue.properties.map((prop) => - j.literal(prop.key.name), - ), - ), - ); + // Create the global preprocessors property with string literals + const globalPreprocessorsProp = j.property( + "init", + j.identifier("preprocessors"), + j.arrayExpression( + preprocessorValue.properties.map((prop) => j.literal(prop.key.name)), + ), + ); - // Add the global preprocessors property if not already present - if ( - !properties.some( - (prop) => - prop.key.name === 'preprocessors' && prop !== hooksProp, - ) - ) { - properties.push(globalPreprocessorsProp); - } - } - }); + // Add the global preprocessors property if not already present + if ( + !properties.some( + (prop) => prop.key.name === "preprocessors" && prop !== hooksProp, + ) + ) { + properties.push(globalPreprocessorsProp); + } + } + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-transform-groups/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-transform-groups/.codemodrc.json index 8f8e38469..c99329a1e 100644 --- a/packages/codemods/styledictionary/4/hook-api-transform-groups/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-transform-groups/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-transform-groups", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-transform-groups/src/index.ts b/packages/codemods/styledictionary/4/hook-api-transform-groups/src/index.ts index 157ee491f..2a6c5c0a9 100644 --- a/packages/codemods/styledictionary/4/hook-api-transform-groups/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-transform-groups/src/index.ts @@ -6,51 +6,47 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Helper function to recursively find and transform transformGroup properties - function transformObjectProperties(objectExpression) { - const properties = objectExpression.properties; + // Helper function to recursively find and transform transformGroup properties + function transformObjectProperties(objectExpression) { + const properties = objectExpression.properties; - properties.forEach((prop, index) => { - if ( - prop.key.name === 'transformGroup' && - prop.value.type === 'ObjectExpression' - ) { - // Create the hooks.transformGroups property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property( - 'init', - j.identifier('transformGroups'), - prop.value, - ), - ]), - ); + properties.forEach((prop, index) => { + if ( + prop.key.name === "transformGroup" && + prop.value.type === "ObjectExpression" + ) { + // Create the hooks.transformGroups property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("transformGroups"), prop.value), + ]), + ); - // Remove the old transformGroup property - properties.splice(index, 1); + // Remove the old transformGroup property + properties.splice(index, 1); - // Add the new hooks property - properties.push(hooksProp); - } else if (prop.value.type === 'ObjectExpression') { - // Recursively transform nested objects - transformObjectProperties(prop.value); - } - }); - } - - // Find all object expressions in the file and transform them - root.find(j.ObjectExpression).forEach((path) => { - transformObjectProperties(path.node); + // Add the new hooks property + properties.push(hooksProp); + } else if (prop.value.type === "ObjectExpression") { + // Recursively transform nested objects + transformObjectProperties(prop.value); + } }); + } + + // Find all object expressions in the file and transform them + root.find(j.ObjectExpression).forEach((path) => { + transformObjectProperties(path.node); + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/hook-api-transform/.codemodrc.json b/packages/codemods/styledictionary/4/hook-api-transform/.codemodrc.json index e6063eb22..e936fc485 100644 --- a/packages/codemods/styledictionary/4/hook-api-transform/.codemodrc.json +++ b/packages/codemods/styledictionary/4/hook-api-transform/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/hook-api-transform", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/hook-api-transform/src/index.ts b/packages/codemods/styledictionary/4/hook-api-transform/src/index.ts index cb1432319..0e37dd19c 100644 --- a/packages/codemods/styledictionary/4/hook-api-transform/src/index.ts +++ b/packages/codemods/styledictionary/4/hook-api-transform/src/index.ts @@ -6,92 +6,88 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Helper function to recursively find and transform object properties - function transformObjectProperties(objectExpression) { - const properties = objectExpression.properties; + // Helper function to recursively find and transform object properties + function transformObjectProperties(objectExpression) { + const properties = objectExpression.properties; - properties.forEach((prop, index) => { - if ( - prop.key.name === 'transform' && - prop.value.type === 'ObjectExpression' - ) { - // Create the hooks.transforms property - const hooksProp = j.property( - 'init', - j.identifier('hooks'), - j.objectExpression([ - j.property( - 'init', - j.identifier('transforms'), - prop.value, - ), - ]), - ); + properties.forEach((prop, index) => { + if ( + prop.key.name === "transform" && + prop.value.type === "ObjectExpression" + ) { + // Create the hooks.transforms property + const hooksProp = j.property( + "init", + j.identifier("hooks"), + j.objectExpression([ + j.property("init", j.identifier("transforms"), prop.value), + ]), + ); - // Remove the old transform property - properties.splice(index, 1); + // Remove the old transform property + properties.splice(index, 1); - // Add the new hooks property - properties.push(hooksProp); + // Add the new hooks property + properties.push(hooksProp); - // Transform the inner properties of the transform object - const transformProperties = prop.value.properties; - transformProperties.forEach((transformProp) => { - if (transformProp.value.type === 'ObjectExpression') { - const innerProperties = transformProp.value.properties; - innerProperties.forEach((innerProp) => { - if (innerProp.key.name === 'matcher') { - innerProp.key.name = 'filter'; - } else if (innerProp.key.name === 'transformer') { - innerProp.key.name = 'transform'; - } - }); - } - }); - } else if (prop.value.type === 'ObjectExpression') { - // Recursively transform nested objects - transformObjectProperties(prop.value); - } + // Transform the inner properties of the transform object + const transformProperties = prop.value.properties; + transformProperties.forEach((transformProp) => { + if (transformProp.value.type === "ObjectExpression") { + const innerProperties = transformProp.value.properties; + innerProperties.forEach((innerProp) => { + if (innerProp.key.name === "matcher") { + innerProp.key.name = "filter"; + } else if (innerProp.key.name === "transformer") { + innerProp.key.name = "transform"; + } + }); + } }); - } - - // Transform object properties in all object expressions - root.find(j.ObjectExpression).forEach((path) => { - transformObjectProperties(path.node); + } else if (prop.value.type === "ObjectExpression") { + // Recursively transform nested objects + transformObjectProperties(prop.value); + } }); + } - // Handle StyleDictionary.registerTransform calls - root.find(j.CallExpression).forEach((path) => { - const callee = path.node.callee; - if ( - callee.object && - callee.object.name === 'StyleDictionary' && - callee.property.name === 'registerTransform' - ) { - path.node.arguments.forEach((arg) => { - if (arg.type === 'ObjectExpression') { - arg.properties.forEach((prop) => { - // Rename 'matcher' to 'filter' - if (prop.key.name === 'matcher') { - prop.key.name = 'filter'; - } + // Transform object properties in all object expressions + root.find(j.ObjectExpression).forEach((path) => { + transformObjectProperties(path.node); + }); - // Rename 'transformer' to 'transform' - if (prop.key.name === 'transformer') { - prop.key.name = 'transform'; - } - }); - } - }); + // Handle StyleDictionary.registerTransform calls + root.find(j.CallExpression).forEach((path) => { + const callee = path.node.callee; + if ( + callee.object && + callee.object.name === "StyleDictionary" && + callee.property.name === "registerTransform" + ) { + path.node.arguments.forEach((arg) => { + if (arg.type === "ObjectExpression") { + arg.properties.forEach((prop) => { + // Rename 'matcher' to 'filter' + if (prop.key.name === "matcher") { + prop.key.name = "filter"; + } + + // Rename 'transformer' to 'transform' + if (prop.key.name === "transformer") { + prop.key.name = "transform"; + } + }); } - }); + }); + } + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/instantiating-style-dictionary/.codemodrc.json b/packages/codemods/styledictionary/4/instantiating-style-dictionary/.codemodrc.json index 4b061fcae..01056b129 100644 --- a/packages/codemods/styledictionary/4/instantiating-style-dictionary/.codemodrc.json +++ b/packages/codemods/styledictionary/4/instantiating-style-dictionary/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/instantiating-style-dictionary", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/instantiating-style-dictionary/src/index.ts b/packages/codemods/styledictionary/4/instantiating-style-dictionary/src/index.ts index 55256d6b9..2ccb45e98 100644 --- a/packages/codemods/styledictionary/4/instantiating-style-dictionary/src/index.ts +++ b/packages/codemods/styledictionary/4/instantiating-style-dictionary/src/index.ts @@ -15,137 +15,143 @@ export default function transform( // Helper function to add `await` before `hasInitialized` function addAwaitInitialization(path) { - const parent = path.parent.node; - let variableName; - if (parent.id && parent.id.name) { - variableName = parent.id.name; - } else if (parent.left && parent.left.name) { - variableName = parent.left.name; - } + const parent = path.parent.node; + let variableName; + if (parent.id && parent.id.name) { + variableName = parent.id.name; + } else if (parent.left && parent.left.name) { + variableName = parent.left.name; + } - if (variableName) { - const awaitExpression = j.awaitExpression( - j.memberExpression( - j.identifier(variableName), - j.identifier('hasInitialized'), - ), - ); - const expressionStatement = j.expressionStatement(awaitExpression); - j(path.parent.parent).insertAfter(expressionStatement); - } + if (variableName) { + const awaitExpression = j.awaitExpression( + j.memberExpression( + j.identifier(variableName), + j.identifier("hasInitialized"), + ), + ); + const expressionStatement = j.expressionStatement(awaitExpression); + j(path.parent.parent).insertAfter(expressionStatement); + } } // Transform `StyleDictionary.extend` to `new StyleDictionary` - root.find(j.CallExpression, { + root + .find(j.CallExpression, { callee: { - object: { name: 'StyleDictionary' }, - property: { name: 'extend' }, + object: { name: "StyleDictionary" }, + property: { name: "extend" }, }, - }).forEach((path) => { + }) + .forEach((path) => { const args = path.node.arguments; const newExpression = j.newExpression( - j.identifier('StyleDictionary'), - args, + j.identifier("StyleDictionary"), + args, ); j(path).replaceWith(newExpression); addAwaitInitialization(path); - }); + }); // Transform `require` to `import` root.find(j.VariableDeclaration).forEach((path) => { - const declaration = path.node.declarations[0]; - if ( - declaration.init && - declaration.init.callee && - declaration.init.callee.name === 'require' && - declaration.init.arguments[0].value === 'style-dictionary' - ) { - const importDeclaration = j.importDeclaration( - [j.importDefaultSpecifier(j.identifier(declaration.id.name))], - j.literal('style-dictionary'), - ); - j(path).replaceWith(importDeclaration); - } + const declaration = path.node.declarations[0]; + if ( + declaration.init && + declaration.init.callee && + declaration.init.callee.name === "require" && + declaration.init.arguments[0].value === "style-dictionary" + ) { + const importDeclaration = j.importDeclaration( + [j.importDefaultSpecifier(j.identifier(declaration.id.name))], + j.literal("style-dictionary"), + ); + j(path).replaceWith(importDeclaration); + } }); // Handle class constructor and make it async if necessary - root.find(j.MethodDefinition, { - key: { name: 'constructor' }, - }).forEach((path) => { + root + .find(j.MethodDefinition, { + key: { name: "constructor" }, + }) + .forEach((path) => { const body = path.node.value.body.body; let requiresAsync = false; body.forEach((statement, index) => { - if ( - j.ExpressionStatement.check(statement) && - j.CallExpression.check(statement.expression) && - statement.expression.callee.property && - statement.expression.callee.property.name === 'extend' - ) { - requiresAsync = true; - const variableName = statement.expression.callee.object.name; - const awaitExpression = j.awaitExpression( - j.memberExpression( - j.identifier(variableName), - j.identifier('hasInitialized'), - ), - ); - const expressionStatement = - j.expressionStatement(awaitExpression); - body.splice(index + 1, 0, expressionStatement); - } + if ( + j.ExpressionStatement.check(statement) && + j.CallExpression.check(statement.expression) && + statement.expression.callee.property && + statement.expression.callee.property.name === "extend" + ) { + requiresAsync = true; + const variableName = statement.expression.callee.object.name; + const awaitExpression = j.awaitExpression( + j.memberExpression( + j.identifier(variableName), + j.identifier("hasInitialized"), + ), + ); + const expressionStatement = j.expressionStatement(awaitExpression); + body.splice(index + 1, 0, expressionStatement); + } }); if (requiresAsync) { - path.node.value.async = true; + path.node.value.async = true; } - }); + }); // Ensure functions containing new StyleDictionary are async - root.find(j.FunctionDeclaration, { + root + .find(j.FunctionDeclaration, { body: { - body: (body) => - body.some( - (statement) => - j.ExpressionStatement.check(statement) && - j.AwaitExpression.check(statement.expression) && - statement.expression.argument.property.name === - 'hasInitialized', - ), + body: (body) => + body.some( + (statement) => + j.ExpressionStatement.check(statement) && + j.AwaitExpression.check(statement.expression) && + statement.expression.argument.property.name === "hasInitialized", + ), }, - }).forEach((path) => { + }) + .forEach((path) => { path.node.async = true; - }); + }); - root.find(j.FunctionExpression, { + root + .find(j.FunctionExpression, { body: { - body: (body) => - body.some( - (statement) => - j.ExpressionStatement.check(statement) && - j.AwaitExpression.check(statement.expression) && - statement.expression.argument.property.name === - 'hasInitialized', - ), + body: (body) => + body.some( + (statement) => + j.ExpressionStatement.check(statement) && + j.AwaitExpression.check(statement.expression) && + statement.expression.argument.property.name === "hasInitialized", + ), }, - }).forEach((path) => { + }) + .forEach((path) => { path.node.async = true; - }); + }); - root.find(j.ArrowFunctionExpression, { + root + .find(j.ArrowFunctionExpression, { body: { - body: (body) => - body.some( - (statement) => - j.ExpressionStatement.check(statement) && - j.AwaitExpression.check(statement.expression) && - statement.expression.argument.property.name === - 'hasInitialized', - ), + body: (body) => + body.some( + (statement) => + j.ExpressionStatement.check(statement) && + j.AwaitExpression.check(statement.expression) && + statement.expression.argument.property.name === "hasInitialized", + ), }, - }).forEach((path) => { + }) + .forEach((path) => { path.node.async = true; - }); + }); return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/logging/.codemodrc.json b/packages/codemods/styledictionary/4/logging/.codemodrc.json index 75199d318..32ce57079 100644 --- a/packages/codemods/styledictionary/4/logging/.codemodrc.json +++ b/packages/codemods/styledictionary/4/logging/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/logging", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/logging/src/index.ts b/packages/codemods/styledictionary/4/logging/src/index.ts index dca92226a..7085bf020 100644 --- a/packages/codemods/styledictionary/4/logging/src/index.ts +++ b/packages/codemods/styledictionary/4/logging/src/index.ts @@ -6,39 +6,28 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Traverse the JSON object - root.find(j.ObjectExpression).forEach((path) => { - path.node.properties.forEach((property) => { - if ( - property.key.name === 'log' && - j.Literal.check(property.value) - ) { - // Convert the old `log` format to the new object format - const logValue = property.value.value; - const newLogObject = j.objectExpression([ - j.property( - 'init', - j.identifier('warnings'), - j.literal(logValue), - ), - j.property( - 'init', - j.identifier('verbosity'), - j.literal('default'), - ), - ]); + // Traverse the JSON object + root.find(j.ObjectExpression).forEach((path) => { + path.node.properties.forEach((property) => { + if (property.key.name === "log" && j.Literal.check(property.value)) { + // Convert the old `log` format to the new object format + const logValue = property.value.value; + const newLogObject = j.objectExpression([ + j.property("init", j.identifier("warnings"), j.literal(logValue)), + j.property("init", j.identifier("verbosity"), j.literal("default")), + ]); - property.value = newLogObject; // Replace the value - } - }); + property.value = newLogObject; // Replace the value + } }); + }); - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/migration-recipe/.codemodrc.json b/packages/codemods/styledictionary/4/migration-recipe/.codemodrc.json index 2addb2b07..d1e28a509 100644 --- a/packages/codemods/styledictionary/4/migration-recipe/.codemodrc.json +++ b/packages/codemods/styledictionary/4/migration-recipe/.codemodrc.json @@ -29,7 +29,10 @@ "git": "https://github.com/codemod-com/codemod/tree/main/packages/codemods/styledictionary/4/migration-recipe" }, "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "include": ["**/*.js", "**/*.jsx", "**/*.ts", "**/*.tsx", "**/*.vue"] diff --git a/packages/codemods/styledictionary/4/module-common-js/.codemodrc.json b/packages/codemods/styledictionary/4/module-common-js/.codemodrc.json index 581feba50..f4a99cea8 100644 --- a/packages/codemods/styledictionary/4/module-common-js/.codemodrc.json +++ b/packages/codemods/styledictionary/4/module-common-js/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/module-common-js", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/module-common-js/src/index.ts b/packages/codemods/styledictionary/4/module-common-js/src/index.ts index 33b5bbc8d..1a707c78d 100644 --- a/packages/codemods/styledictionary/4/module-common-js/src/index.ts +++ b/packages/codemods/styledictionary/4/module-common-js/src/index.ts @@ -13,25 +13,24 @@ export default function transform( const j = api.jscodeshift; return j(file.source) - .find(j.VariableDeclaration) - .filter((path) => { - // Check if it matches `const StyleDictionary = require('style-dictionary');` - const declaration = path.node.declarations[0]; - return ( - declaration.id.name === 'StyleDictionary' && - j.CallExpression.check(declaration.init) && - declaration.init.callee.name === 'require' && - declaration.init.arguments.length === 1 && - declaration.init.arguments[0].value === 'style-dictionary' - ); - }) - .replaceWith((path) => { - // Replace with `import StyleDictionary from 'style-dictionary';` - return j.importDeclaration( - [j.importDefaultSpecifier(j.identifier('StyleDictionary'))], - j.literal('style-dictionary'), - ); - }) - .toSource(); + .find(j.VariableDeclaration) + .filter((path) => { + // Check if it matches `const StyleDictionary = require('style-dictionary');` + const declaration = path.node.declarations[0]; + return ( + declaration.id.name === "StyleDictionary" && + j.CallExpression.check(declaration.init) && + declaration.init.callee.name === "require" && + declaration.init.arguments.length === 1 && + declaration.init.arguments[0].value === "style-dictionary" + ); + }) + .replaceWith((path) => { + // Replace with `import StyleDictionary from 'style-dictionary';` + return j.importDeclaration( + [j.importDefaultSpecifier(j.identifier("StyleDictionary"))], + j.literal("style-dictionary"), + ); + }) + .toSource(); } - diff --git a/packages/codemods/styledictionary/4/reference-utils/.codemodrc.json b/packages/codemods/styledictionary/4/reference-utils/.codemodrc.json index 39017e7a3..34529680e 100644 --- a/packages/codemods/styledictionary/4/reference-utils/.codemodrc.json +++ b/packages/codemods/styledictionary/4/reference-utils/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/reference-utils", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/reference-utils/src/index.ts b/packages/codemods/styledictionary/4/reference-utils/src/index.ts index 2eb30454f..c67c85044 100644 --- a/packages/codemods/styledictionary/4/reference-utils/src/index.ts +++ b/packages/codemods/styledictionary/4/reference-utils/src/index.ts @@ -1,97 +1,99 @@ import type { - API, - ArrowFunctionExpression, - FileInfo, - Options, -} from 'jscodeshift'; + API, + ArrowFunctionExpression, + FileInfo, + Options, +} from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, + file: FileInfo, + api: API, + options?: Options, ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + const j = api.jscodeshift; + const root = j(file.source); - // Map of reference utilities to their corresponding method names - const referenceUtils = { - usesReferences: 'usesReferences', - usesReference: 'usesReferences', - getReferences: 'getReferences', - getReference: 'getReferences', - // Add more references here as needed from the documentation - isReference: 'isReference', - resolveReferences: 'resolveReferences', - flattenReferences: 'flattenReferences', - outputReferencesFilter: 'outputReferencesFilter', - outputReferencesTransformed: 'outputReferencesTransformed', - }; + // Map of reference utilities to their corresponding method names + const referenceUtils = { + usesReferences: "usesReferences", + usesReference: "usesReferences", + getReferences: "getReferences", + getReference: "getReferences", + // Add more references here as needed from the documentation + isReference: "isReference", + resolveReferences: "resolveReferences", + flattenReferences: "flattenReferences", + outputReferencesFilter: "outputReferencesFilter", + outputReferencesTransformed: "outputReferencesTransformed", + }; - // Track which utilities are used in the file - const usedReferences = new Set(); + // Track which utilities are used in the file + const usedReferences = new Set(); - // Step 1: Replace the relevant method calls in the code and track usage - Object.entries(referenceUtils).forEach(([oldMethod, newMethod]) => { - root.find(j.CallExpression, { - callee: { - object: { name: 'dictionary' }, - property: { name: oldMethod }, - }, - }).forEach((path) => { - // Replace the original call with the new utility function - j(path).replaceWith( - j.callExpression(j.identifier(newMethod), [ - path.node.arguments[0], - j.memberExpression( - j.identifier('dictionary'), - j.identifier('tokens'), - ), - ]), - ); + // Step 1: Replace the relevant method calls in the code and track usage + Object.entries(referenceUtils).forEach(([oldMethod, newMethod]) => { + root + .find(j.CallExpression, { + callee: { + object: { name: "dictionary" }, + property: { name: oldMethod }, + }, + }) + .forEach((path) => { + // Replace the original call with the new utility function + j(path).replaceWith( + j.callExpression(j.identifier(newMethod), [ + path.node.arguments[0], + j.memberExpression( + j.identifier("dictionary"), + j.identifier("tokens"), + ), + ]), + ); - // Track that this utility is used - usedReferences.add(newMethod); - }); - }); + // Track that this utility is used + usedReferences.add(newMethod); + }); + }); - // Step 2: Add imports only for the utilities that are actually used - if (usedReferences.size > 0) { - const existingUtilsImport = root.find(j.ImportDeclaration, { - source: { value: 'style-dictionary/utils' }, - }); + // Step 2: Add imports only for the utilities that are actually used + if (usedReferences.size > 0) { + const existingUtilsImport = root.find(j.ImportDeclaration, { + source: { value: "style-dictionary/utils" }, + }); - if (existingUtilsImport.size() === 0) { - // Create a new import statement for the used utilities - const newImport = j.importDeclaration( - Array.from(usedReferences).map((util) => - j.importSpecifier(j.identifier(util)), - ), - j.literal('style-dictionary/utils'), - ); + if (existingUtilsImport.size() === 0) { + // Create a new import statement for the used utilities + const newImport = j.importDeclaration( + Array.from(usedReferences).map((util) => + j.importSpecifier(j.identifier(util)), + ), + j.literal("style-dictionary/utils"), + ); - // Insert the new import after the main style-dictionary import - const styleDictionaryImport = root.find(j.ImportDeclaration, { - source: { value: 'style-dictionary' }, - }); + // Insert the new import after the main style-dictionary import + const styleDictionaryImport = root.find(j.ImportDeclaration, { + source: { value: "style-dictionary" }, + }); - if (styleDictionaryImport.size() > 0) { - styleDictionaryImport.insertAfter(newImport); - } else { - root.get().node.program.body.unshift(newImport); - } - } else { - // Update the existing import statement to include only the used utilities - existingUtilsImport.forEach((path) => { - const existingSpecifiers = path.node.specifiers.map( - (spec) => spec.local.name, - ); - const newSpecifiers = Array.from(usedReferences) - .filter((util) => !existingSpecifiers.includes(util)) - .map((util) => j.importSpecifier(j.identifier(util))); - path.node.specifiers.push(...newSpecifiers); - }); - } + if (styleDictionaryImport.size() > 0) { + styleDictionaryImport.insertAfter(newImport); + } else { + root.get().node.program.body.unshift(newImport); + } + } else { + // Update the existing import statement to include only the used utilities + existingUtilsImport.forEach((path) => { + const existingSpecifiers = path.node.specifiers.map( + (spec) => spec.local.name, + ); + const newSpecifiers = Array.from(usedReferences) + .filter((util) => !existingSpecifiers.includes(util)) + .map((util) => j.importSpecifier(j.identifier(util))); + path.node.specifiers.push(...newSpecifiers); + }); } + } - return root.toSource({ quote: 'single' }); + return root.toSource({ quote: "single" }); } diff --git a/packages/codemods/styledictionary/4/type/.codemodrc.json b/packages/codemods/styledictionary/4/type/.codemodrc.json index d1c842de6..2413a8b19 100644 --- a/packages/codemods/styledictionary/4/type/.codemodrc.json +++ b/packages/codemods/styledictionary/4/type/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/type", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/type/src/index.ts b/packages/codemods/styledictionary/4/type/src/index.ts index bcad9bc51..800ce9489 100644 --- a/packages/codemods/styledictionary/4/type/src/index.ts +++ b/packages/codemods/styledictionary/4/type/src/index.ts @@ -6,46 +6,47 @@ import type { } from "jscodeshift"; export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); - // Find all type declarations involving StyleDictionary - const typeDeclarations = root - .find(j.TSTypeAliasDeclaration) - .filter((path) => { - const { typeAnnotation } = path.node; - return ( - typeAnnotation.typeName.type === 'TSQualifiedName' && - typeAnnotation.typeName.left.name === 'StyleDictionary' - ); - }); + // Find all type declarations involving StyleDictionary + const typeDeclarations = root + .find(j.TSTypeAliasDeclaration) + .filter((path) => { + const { typeAnnotation } = path.node; + return ( + typeAnnotation.typeName.type === "TSQualifiedName" && + typeAnnotation.typeName.left.name === "StyleDictionary" + ); + }); - if (typeDeclarations.size()) { - // Extract the names of the types being declared - const typesToImport = typeDeclarations - .nodes() - .map((node) => node.typeAnnotation.typeName.right.name); + if (typeDeclarations.size()) { + // Extract the names of the types being declared + const typesToImport = typeDeclarations + .nodes() + .map((node) => node.typeAnnotation.typeName.right.name); - // Add the new type-specific import - root.find(j.Program) - .get('body', 0) - .insertBefore( - j.importDeclaration( - typesToImport.map((typeName) => - j.importSpecifier(j.identifier(typeName)), - ), - j.stringLiteral('style-dictionary/types'), - 'type', - ), - ); + // Add the new type-specific import + root + .find(j.Program) + .get("body", 0) + .insertBefore( + j.importDeclaration( + typesToImport.map((typeName) => + j.importSpecifier(j.identifier(typeName)), + ), + j.stringLiteral("style-dictionary/types"), + "type", + ), + ); - // Remove the old type declarations - typeDeclarations.remove(); - } + // Remove the old type declarations + typeDeclarations.remove(); + } - return root.toSource(); + return root.toSource(); } diff --git a/packages/codemods/styledictionary/4/updated-and-removed-transforms/.codemodrc.json b/packages/codemods/styledictionary/4/updated-and-removed-transforms/.codemodrc.json index dd31795e3..ccd2e06da 100644 --- a/packages/codemods/styledictionary/4/updated-and-removed-transforms/.codemodrc.json +++ b/packages/codemods/styledictionary/4/updated-and-removed-transforms/.codemodrc.json @@ -5,7 +5,10 @@ "name": "styledictionary/4/updated-and-removed-transforms", "engine": "jscodeshift", "applicability": { - "from": [["styledictionary", ">=", "3.0.0"], ["styledictionary", "<", "4.0.0"]], + "from": [ + ["styledictionary", ">=", "3.0.0"], + ["styledictionary", "<", "4.0.0"] + ], "to": [["styledictionary", ">=", "4.0.0"]] }, "meta": { diff --git a/packages/codemods/styledictionary/4/updated-and-removed-transforms/src/index.ts b/packages/codemods/styledictionary/4/updated-and-removed-transforms/src/index.ts index 8d339344f..34cd38156 100644 --- a/packages/codemods/styledictionary/4/updated-and-removed-transforms/src/index.ts +++ b/packages/codemods/styledictionary/4/updated-and-removed-transforms/src/index.ts @@ -5,60 +5,55 @@ import type { Options, } from "jscodeshift"; - const transformations = { - 'name/cti/': 'name/', - 'font/objC/literal': null, - 'font/swift/literal': null, - 'font/flutter/literal': null, - 'content/icon': 'html/icon', + "name/cti/": "name/", + "font/objC/literal": null, + "font/swift/literal": null, + "font/flutter/literal": null, + "content/icon": "html/icon", }; function transformTransforms(transforms) { - return transforms - .map((transform) => { - // Replace 'name/cti/' with 'name/' - for (const [oldPrefix, newPrefix] of Object.entries( - transformations, - )) { - if (transform.startsWith(oldPrefix)) { - return newPrefix - ? transform.replace(oldPrefix, newPrefix) - : null; - } - } - return transform; - }) - .filter((transform) => transform !== null); // Remove null values + return transforms + .map((transform) => { + // Replace 'name/cti/' with 'name/' + for (const [oldPrefix, newPrefix] of Object.entries(transformations)) { + if (transform.startsWith(oldPrefix)) { + return newPrefix ? transform.replace(oldPrefix, newPrefix) : null; + } + } + return transform; + }) + .filter((transform) => transform !== null); // Remove null values } export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const root = j(file.source); - - root.find(j.ObjectExpression).forEach((path) => { - const obj = path.node; - - // Find the transforms array within the config - const transformsNode = obj.properties.find( - (prop) => prop.key.name === 'transforms', - ); - - if (transformsNode && transformsNode.value.type === 'ArrayExpression') { - const transformsArray = transformsNode.value.elements; - const transforms = transformsArray.map((elem) => elem.value); - const transformed = transformTransforms(transforms); - - // Update the array with transformed values - transformsNode.value.elements = transformed.map((value) => - j.literal(value), - ); - } - }); - - return root.toSource({ quote: 'single' }); + file: FileInfo, + api: API, + options?: Options, +): string | undefined { + const j = api.jscodeshift; + const root = j(file.source); + + root.find(j.ObjectExpression).forEach((path) => { + const obj = path.node; + + // Find the transforms array within the config + const transformsNode = obj.properties.find( + (prop) => prop.key.name === "transforms", + ); + + if (transformsNode && transformsNode.value.type === "ArrayExpression") { + const transformsArray = transformsNode.value.elements; + const transforms = transformsArray.map((elem) => elem.value); + const transformed = transformTransforms(transforms); + + // Update the array with transformed values + transformsNode.value.elements = transformed.map((value) => + j.literal(value), + ); + } + }); + + return root.toSource({ quote: "single" }); } diff --git a/packages/codemods/svelte/5/components-as-functions-destroyfunction/.codemodrc.json b/packages/codemods/svelte/5/components-as-functions-destroyfunction/.codemodrc.json index 67b854801..7aee52180 100644 --- a/packages/codemods/svelte/5/components-as-functions-destroyfunction/.codemodrc.json +++ b/packages/codemods/svelte/5/components-as-functions-destroyfunction/.codemodrc.json @@ -12,5 +12,12 @@ "tags": ["svelte", "5", "migration"], "git": "https://github.com/codemod-com/codemod/tree/main/packages/codemods/svelte/5/components-as-functions-destroyfunction" }, - "include": ["**/*.js", "**/*.jsx", "**/*.ts", "**/*.tsx", "**/*.vue", "**/*.svelte"] + "include": [ + "**/*.js", + "**/*.jsx", + "**/*.ts", + "**/*.tsx", + "**/*.vue", + "**/*.svelte" + ] } diff --git a/packages/codemods/svelte/5/components-as-functions-destroyfunction/src/index.ts b/packages/codemods/svelte/5/components-as-functions-destroyfunction/src/index.ts index e90c73ed1..25b200fe8 100644 --- a/packages/codemods/svelte/5/components-as-functions-destroyfunction/src/index.ts +++ b/packages/codemods/svelte/5/components-as-functions-destroyfunction/src/index.ts @@ -1,35 +1,36 @@ import type { - API, - ArrowFunctionExpression, - FileInfo, - Options, - } from "jscodeshift"; - - export default function transform( - file: FileInfo, - api: API, - options?: Options, - ): string | undefined { - const j = api.jscodeshift; - const source = file.source; - - // Regular expression to find the content inside