From 216d28ebe4e6ae015068e1de99615f032aec7c5b Mon Sep 17 00:00:00 2001 From: Timothee Guerin Date: Thu, 14 Dec 2023 10:04:01 -0800 Subject: [PATCH] VSCode extension: Use rollup for dev build too (#2730) Problem is vscode still doesn't allow loading es modules so we had all those hacks to make it work but loading es modules from comon js is always problematic. Using rollup to generate a commonjs output solve the problem and we are using that for the published version just not in dev. Issue with this new approach is `rush watch` won't build the extension but that's also not something you often need to touch. --- .../extensions-cleanup_2023-12-05-20-04.json | 10 ++++++++++ .../extensions-cleanup_2023-12-05-17-22.json | 10 ++++++++++ common/config/rush/pnpm-lock.yaml | 4 ++++ .../src/generate-third-party-notice.ts | 12 +++++++++--- packages/typespec-vscode/.vscodeignore | 2 +- packages/typespec-vscode/extension-shim.js | 3 --- packages/typespec-vscode/package.json | 14 +++++++------- .../{rollup.config.mjs => rollup.config.ts} | 13 +++++++++---- packages/typespec-vscode/tsconfig.build.json | 13 +++++++++++++ packages/typespec-vscode/tsconfig.json | 17 +++++++++-------- tsconfig.json | 1 - 11 files changed, 72 insertions(+), 27 deletions(-) create mode 100644 common/changes/@typespec/internal-build-utils/extensions-cleanup_2023-12-05-20-04.json create mode 100644 common/changes/typespec-vscode/extensions-cleanup_2023-12-05-17-22.json delete mode 100644 packages/typespec-vscode/extension-shim.js rename packages/typespec-vscode/{rollup.config.mjs => rollup.config.ts} (70%) create mode 100644 packages/typespec-vscode/tsconfig.build.json diff --git a/common/changes/@typespec/internal-build-utils/extensions-cleanup_2023-12-05-20-04.json b/common/changes/@typespec/internal-build-utils/extensions-cleanup_2023-12-05-20-04.json new file mode 100644 index 0000000000..a231477acb --- /dev/null +++ b/common/changes/@typespec/internal-build-utils/extensions-cleanup_2023-12-05-20-04.json @@ -0,0 +1,10 @@ +{ + "changes": [ + { + "packageName": "@typespec/internal-build-utils", + "comment": "Fix third party generation when there is invalid sourcemaps", + "type": "none" + } + ], + "packageName": "@typespec/internal-build-utils" +} \ No newline at end of file diff --git a/common/changes/typespec-vscode/extensions-cleanup_2023-12-05-17-22.json b/common/changes/typespec-vscode/extensions-cleanup_2023-12-05-17-22.json new file mode 100644 index 0000000000..4ec67f8df3 --- /dev/null +++ b/common/changes/typespec-vscode/extensions-cleanup_2023-12-05-17-22.json @@ -0,0 +1,10 @@ +{ + "changes": [ + { + "packageName": "typespec-vscode", + "comment": "", + "type": "none" + } + ], + "packageName": "typespec-vscode" +} \ No newline at end of file diff --git a/common/config/rush/pnpm-lock.yaml b/common/config/rush/pnpm-lock.yaml index 820862c23f..ef5083171f 100644 --- a/common/config/rush/pnpm-lock.yaml +++ b/common/config/rush/pnpm-lock.yaml @@ -1417,6 +1417,9 @@ importers: '@rollup/plugin-node-resolve': specifier: ~15.2.1 version: 15.2.3(rollup@4.9.0) + '@rollup/plugin-typescript': + specifier: ~11.1.5 + version: 11.1.5(rollup@4.9.0)(typescript@5.3.3) '@types/mocha': specifier: ~10.0.6 version: 10.0.6 @@ -6930,6 +6933,7 @@ packages: /@swagger-api/apidom-ns-json-schema-draft-4@0.87.0: resolution: {integrity: sha512-dea5jN2F9w8wt/YBZLrNdqF6gcxLOUhCEOJ/qsIK9ZT/Hyb/HjEOAqpLQhQMdZgIyefc/Mh0KGKBdQAxegKMqw==} + requiresBuild: true dependencies: '@babel/runtime-corejs3': 7.23.6 '@swagger-api/apidom-ast': 0.87.0 diff --git a/packages/internal-build-utils/src/generate-third-party-notice.ts b/packages/internal-build-utils/src/generate-third-party-notice.ts index 0d8ed810f7..5a9c139b84 100644 --- a/packages/internal-build-utils/src/generate-third-party-notice.ts +++ b/packages/internal-build-utils/src/generate-third-party-notice.ts @@ -51,8 +51,11 @@ async function findThirdPartyPackages() { const contents = JSON.parse(await readFile(map, "utf-8")); const sources = contents.sources; for (const source of sources) { - const sourcePath = join(dirname(map), source); + const sourcePath = resolve(dirname(map), source); const packageRoot = await getPackageRoot(sourcePath); + if (packageRoot === undefined) { + continue; + } const pkg = JSON.parse(await readFile(join(packageRoot, "package.json"), "utf-8")); if (pkg.name === rootName || /microsoft/i.test(JSON.stringify(pkg.author))) { @@ -80,15 +83,18 @@ async function* projectSourcemaps(rootPath: string): any { yield* projectSourcemaps(filepath); } else { - if (file.name.endsWith(".js.map")) { + if (file.name.endsWith(".js.map") || file.name.endsWith(".cjs.map")) { yield filepath; } } } } -async function getPackageRoot(filename: string): Promise { +async function getPackageRoot(filename: string): Promise { const dir = dirname(filename); + if (dir === "/") { + return undefined; + } try { const pkgPath = join(dir, "package.json"); await stat(pkgPath); diff --git a/packages/typespec-vscode/.vscodeignore b/packages/typespec-vscode/.vscodeignore index 23e1012e2e..63dbd54be3 100644 --- a/packages/typespec-vscode/.vscodeignore +++ b/packages/typespec-vscode/.vscodeignore @@ -7,9 +7,9 @@ # Then explicitly include what we want to ship in VSIX !dist/**/*.tmLanguage !dist/**/*.js +!dist/**/*.cjs !dist/**/*.js.map !dist/**/language-configuration.json -!extension-shim.js !markdown-typespec.json !README.md !ThirdPartyNotices.txt diff --git a/packages/typespec-vscode/extension-shim.js b/packages/typespec-vscode/extension-shim.js deleted file mode 100644 index 613d6ac8ea..0000000000 --- a/packages/typespec-vscode/extension-shim.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = require( - process.env.TYPESPEC_DEVELOPMENT_MODE ? "./dist-dev/src/extension.js" : "./dist/src/extension.js" -); diff --git a/packages/typespec-vscode/package.json b/packages/typespec-vscode/package.json index b0a804b0fd..e95c1e48f3 100644 --- a/packages/typespec-vscode/package.json +++ b/packages/typespec-vscode/package.json @@ -21,8 +21,8 @@ "categories": [ "Programming Languages" ], - "type": "commonjs", - "main": "./extension-shim.js", + "type": "module", + "main": "./dist/src/extension.cjs", "engines": { "vscode": "^1.85.0" }, @@ -106,20 +106,20 @@ ] }, "scripts": { - "clean": "rimraf ./dist ./dist-dev ./temp", - "build": "npm run compile && npm run rollup && npm run copy-tmlanguage && npm run generate-language-configuration && npm run generate-third-party-notices && npm run package-vsix", - "compile": "tsc -p .", - "watch": "tsc -p . --watch", + "clean": "rimraf ./dist ./temp", + "build": "npm run compile && npm run copy-tmlanguage && npm run generate-language-configuration && npm run generate-third-party-notices && npm run package-vsix", + "compile": "rollup --config rollup.config.ts --configPlugin typescript --failAfterWarnings 2>&1", + "watch": "rollup --config rollup.config.ts --configPlugin typescript --watch", "dogfood": "node scripts/dogfood.js", "copy-tmlanguage": "node scripts/copy-tmlanguage.js", "generate-language-configuration": "node scripts/generate-language-configuration.js", "generate-third-party-notices": "typespec-build-tool generate-third-party-notices", - "rollup": "rollup --config --failAfterWarnings 2>&1", "package-vsix": "vsce package" }, "devDependencies": { "@rollup/plugin-commonjs": "~25.0.4", "@rollup/plugin-node-resolve": "~15.2.1", + "@rollup/plugin-typescript": "~11.1.5", "@types/mocha": "~10.0.6", "@types/node": "~18.11.9", "@types/vscode": "~1.85.0", diff --git a/packages/typespec-vscode/rollup.config.mjs b/packages/typespec-vscode/rollup.config.ts similarity index 70% rename from packages/typespec-vscode/rollup.config.mjs rename to packages/typespec-vscode/rollup.config.ts index e5ad837e76..d59c960cd2 100644 --- a/packages/typespec-vscode/rollup.config.mjs +++ b/packages/typespec-vscode/rollup.config.ts @@ -1,19 +1,24 @@ -// @ts-check import commonjs from "@rollup/plugin-commonjs"; import resolve from "@rollup/plugin-node-resolve"; +import typescript from "@rollup/plugin-typescript"; + import { defineConfig } from "rollup"; export default defineConfig({ - input: "dist-dev/src/extension.js", + input: "src/extension.ts", output: { - file: "dist/src/extension.js", + file: "dist/src/extension.cjs", format: "commonjs", sourcemap: true, exports: "named", inlineDynamicImports: true, }, external: ["fs/promises", "vscode"], - plugins: [resolve({ preferBuiltins: true }), commonjs()], + plugins: [ + (resolve as any)({ preferBuiltins: true }), + (commonjs as any)(), + (typescript as any)({ tsconfig: "./tsconfig.build.json" }), + ], onwarn: (warning, warn) => { if (warning.code === "CIRCULAR_DEPENDENCY") { // filter out warnings about circular dependencies out of our control diff --git a/packages/typespec-vscode/tsconfig.build.json b/packages/typespec-vscode/tsconfig.build.json new file mode 100644 index 0000000000..469b708971 --- /dev/null +++ b/packages/typespec-vscode/tsconfig.build.json @@ -0,0 +1,13 @@ +// tsconfig for building the playground +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "sourceMap": true, + "module": "NodeNext", + "moduleResolution": "NodeNext", + "declaration": false, + "declarationMap": false, + "sourceRoot": ".." + }, + "include": ["src/**/*.ts"] +} diff --git a/packages/typespec-vscode/tsconfig.json b/packages/typespec-vscode/tsconfig.json index af1aba2008..ffedbe4e0d 100644 --- a/packages/typespec-vscode/tsconfig.json +++ b/packages/typespec-vscode/tsconfig.json @@ -2,13 +2,14 @@ "extends": "../tsconfig.json", "references": [{ "path": "../tmlanguage-generator/tsconfig.json" }], "compilerOptions": { - "outDir": "dist-dev", - "rootDir": ".", - "tsBuildInfoFile": "temp/tsconfig.tsbuildinfo", - "module": "ES2022", - "moduleResolution": "Bundler", - "skipLibCheck": true, - "types": ["node", "mocha"] + "incremental": false, + "composite": false, + "module": "NodeNext", + "moduleResolution": "NodeNext", + "sourceMap": false, + "resolveJsonModule": true, + "outDir": "dist", + "rootDir": "." }, - "include": ["src/**/*.ts", "test/**/*.ts"] + "include": ["rollup.config.ts", "src/**/*.ts", "test/**/*.ts"] } diff --git a/tsconfig.json b/tsconfig.json index 8207ac41b0..e29d43467e 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -10,7 +10,6 @@ { "path": "packages/openapi3/tsconfig.json" }, { "path": "packages/lint/tsconfig.json" }, { "path": "packages/migrate/tsconfig.json" }, - { "path": "packages/typespec-vscode/tsconfig.json" }, { "path": "packages/internal-build-utils/tsconfig.json" }, { "path": "packages/bundle-uploader/tsconfig.json" }, { "path": "packages/tmlanguage-generator/tsconfig.json" },