Skip to content

Commit

Permalink
Move tsserverlibrary.js to typescript.js, make tsserverlibrary.js a s…
Browse files Browse the repository at this point in the history
…him (#55273)
  • Loading branch information
jakebailey authored Aug 14, 2023
1 parent fd390e7 commit 3c6c557
Show file tree
Hide file tree
Showing 12 changed files with 4,105 additions and 11,401 deletions.
51 changes: 37 additions & 14 deletions Herebyfile.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -404,27 +404,50 @@ export const watchMin = task({



const { main: lssl, build: buildLssl, watch: watchLssl } = entrypointBuildTask({
// This is technically not enough to make tsserverlibrary loadable in the
// browser, but it's unlikely that anyone has actually been doing that.
const lsslJs = `
if (typeof module !== "undefined" && module.exports) {
module.exports = require("./typescript.js");
}
else {
throw new Error("tsserverlibrary requires CommonJS; use typescript.js instead");
}
`;

const lsslDts = `
import ts = require("./typescript.js");
export = ts;
`;

const lsslDtsInternal = `
import ts = require("./typescript.internal.js");
export = ts;
`;

/**
* @param {string} contents
*/
async function fileContentsWithCopyright(contents) {
return await copyright() + contents.trim().replace(/\r\n/g, "\n") + "\n";
}

const lssl = task({
name: "lssl",
description: "Builds language service server library",
buildDeps: [generateDiagnostics],
project: "src/tsserverlibrary",
srcEntrypoint: "./src/tsserverlibrary/tsserverlibrary.ts",
builtEntrypoint: "./built/local/tsserverlibrary/tsserverlibrary.js",
output: "./built/local/tsserverlibrary.js",
mainDeps: [generateLibs],
bundlerOptions: { exportIsTsObject: true },
dependencies: [services],
run: async () => {
await fs.promises.writeFile("./built/local/tsserverlibrary.js", await fileContentsWithCopyright(lsslJs));
}
});
export { lssl, watchLssl };

export const dtsLssl = task({
name: "dts-lssl",
description: "Bundles tsserverlibrary.d.ts",
dependencies: [buildLssl],
dependencies: [dtsServices],
run: async () => {
if (needsUpdate("./built/local/tsserverlibrary/tsconfig.tsbuildinfo", ["./built/local/tsserverlibrary.d.ts", "./built/local/tsserverlibrary.internal.d.ts"])) {
await runDtsBundler("./built/local/tsserverlibrary/tsserverlibrary.d.ts", "./built/local/tsserverlibrary.d.ts");
}
await fs.promises.writeFile("./built/local/tsserverlibrary.d.ts", await fileContentsWithCopyright(lsslDts));
await fs.promises.writeFile("./built/local/tsserverlibrary.internal.d.ts", await fileContentsWithCopyright(lsslDtsInternal));
}
});

Expand Down Expand Up @@ -563,7 +586,7 @@ export const watchLocal = task({
name: "watch-local",
description: "Watches the full compiler and services",
hiddenFromTaskList: true,
dependencies: [localize, watchTsc, watchTsserver, watchServices, watchLssl, watchOtherOutputs, dts, watchSrc],
dependencies: [localize, watchTsc, watchTsserver, watchServices, lssl, watchOtherOutputs, dts, watchSrc],
});

const runtestsDeps = [tests, generateLibs].concat(cmdLineOptions.typecheck ? [dts] : []);
Expand Down
16 changes: 0 additions & 16 deletions src/testRunner/unittests/publicApi.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import * as compiler from "../_namespaces/compiler";
import * as documents from "../_namespaces/documents";
import * as fakes from "../_namespaces/fakes";
import * as Harness from "../_namespaces/Harness";
Expand All @@ -19,21 +18,6 @@ describe("unittests:: Public APIs", () => {
it("should be acknowledged when they change", () => {
Harness.Baseline.runBaseline(api, fileContent, { PrintDiff: true });
});

it("should compile", () => {
const fs = vfs.createFromFileSystem(Harness.IO, /*ignoreCase*/ false);
fs.linkSync(`${vfs.builtFolder}/${fileName}`, `${vfs.srcFolder}/${fileName}`);
const sys = new fakes.System(fs);
const options: ts.CompilerOptions = {
...ts.getDefaultCompilerOptions(),
strict: true,
exactOptionalPropertyTypes: true,
lib: ["lib.es2018.d.ts"],
};
const host = new fakes.CompilerHost(sys, options);
const result = compiler.compileFiles(host, [`${vfs.srcFolder}/${fileName}`], options);
assert(!result.diagnostics || !result.diagnostics.length, Harness.Compiler.minimalDiagnosticsToString(result.diagnostics, /*pretty*/ true));
});
}

describe("for the language service and compiler", () => {
Expand Down
1 change: 0 additions & 1 deletion src/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@
{ "path": "./testRunner" },
{ "path": "./tsc" },
{ "path": "./tsserver" },
{ "path": "./tsserverlibrary" },
{ "path": "./typescript" },
{ "path": "./typingsInstaller" },
{ "path": "./typingsInstallerCore" },
Expand Down
8 changes: 0 additions & 8 deletions src/tsserverlibrary/_namespaces/ts.ts

This file was deleted.

12 changes: 0 additions & 12 deletions src/tsserverlibrary/tsconfig.json

This file was deleted.

3 changes: 0 additions & 3 deletions src/tsserverlibrary/tsserverlibrary.ts

This file was deleted.

File renamed without changes.
4 changes: 3 additions & 1 deletion src/typescript/_namespaces/ts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,6 @@
export * from "../../compiler/_namespaces/ts";
export * from "../../jsTyping/_namespaces/ts";
export * from "../../services/_namespaces/ts";
export * from "../../deprecatedCompat/_namespaces/ts";
export * from "../../server/_namespaces/ts";
import * as server from "./ts.server";
export { server };
2 changes: 1 addition & 1 deletion src/typescript/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
{ "path": "../compiler" },
{ "path": "../jsTyping" },
{ "path": "../services" },
{ "path": "../deprecatedCompat" }
{ "path": "../server" }
],
"include": ["**/*"]
}
4 changes: 2 additions & 2 deletions tests/baselines/reference/APILibCheck.types
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ import tsInternal = require("typescript-internal");
>tsInternal : typeof tsInternal

import tsserverlibrary = require("tsserverlibrary");
>tsserverlibrary : typeof tsserverlibrary
>tsserverlibrary : typeof ts

import tsserverlibraryInternal = require("tsserverlibrary-internal");
>tsserverlibraryInternal : typeof tsserverlibraryInternal
>tsserverlibraryInternal : typeof tsInternal

Loading

0 comments on commit 3c6c557

Please sign in to comment.