@@ -126,6 +126,22 @@ const buildSrc = () => buildProject("src");
126126
127127task ( "build-src" , series ( preSrc , buildSrc ) ) ;
128128
129+ /**
130+ * @param {string } entrypoint
131+ * @param {string } output
132+ */
133+ async function runDtsBundler ( entrypoint , output ) {
134+ // Want to preserve @internal ? Pass `--stripInternal=false` when running the dts task.
135+ await exec ( process . execPath , [
136+ "./scripts/dtsBundler.js" ,
137+ "--entrypoint" ,
138+ entrypoint ,
139+ "--output" ,
140+ output ,
141+ `--stripInternal=${ cmdLineOptions . stripInternal } ` ,
142+ ] ) ;
143+ }
144+
129145/** @type {string | undefined } */
130146let copyrightHeader ;
131147function getCopyrightHeader ( ) {
@@ -265,10 +281,13 @@ const preBuild = cmdLineOptions.lkg ? lkgPreBuild : localPreBuild;
265281const esbuildServices = esbuildTask ( "./src/typescript/typescript.ts" , "./built/local/typescript.js" , /* exportIsTsObject */ true , /* performanceMatters */ true ) ;
266282
267283// TODO(jakebailey): rename this; no longer "services".
284+
285+ const buildServicesProject = ( ) => buildProject ( "src/typescript" ) ;
286+
268287const buildServices = ( ) => {
269288 if ( cmdLineOptions . bundle ) return esbuildServices . build ( ) ;
270289 writeCJSReexport ( "./built/local/typescript/typescript.js" , "./built/local/typescript.js" ) ;
271- return buildProject ( "src/typescript" ) ;
290+ return buildServicesProject ( ) ;
272291} ;
273292
274293task ( "services" , series ( preBuild , buildServices ) ) ;
@@ -291,6 +310,9 @@ task("watch-services").flags = {
291310 " --built" : "Compile using the built version of the compiler."
292311} ;
293312
313+ const dtsServices = ( ) => runDtsBundler ( "./built/local/typescript/typescript.d.ts" , "./built/local/typescript.d.ts" ) ;
314+ task ( "dts-services" , series ( preBuild , buildServicesProject , dtsServices ) ) ;
315+ task ( "dts-services" ) . description = "Builds typescript.d.ts" ;
294316
295317const esbuildServer = esbuildTask ( "./src/tsserver/server.ts" , "./built/local/tsserver.js" , /* exportIsTsObject */ true , /* performanceMatters */ true ) ;
296318
@@ -337,10 +359,11 @@ task("watch-min").flags = {
337359
338360const esbuildLssl = esbuildTask ( "./src/tsserverlibrary/tsserverlibrary.ts" , "./built/local/tsserverlibrary.js" , /* exportIsTsObject */ true , /* performanceMatters */ true ) ;
339361
362+ const buildLsslProject = ( ) => buildProject ( "src/tsserverlibrary" ) ;
340363const buildLssl = ( ) => {
341364 if ( cmdLineOptions . bundle ) return esbuildLssl . build ( ) ;
342365 writeCJSReexport ( "./built/local/tsserverlibrary/tsserverlibrary.js" , "./built/local/tsserverlibrary.js" ) ;
343- return buildProject ( "src/tsserverlibrary" ) ;
366+ return buildLsslProject ( ) ;
344367} ;
345368task ( "lssl" , series ( preBuild , buildLssl ) ) ;
346369task ( "lssl" ) . description = "Builds language service server library" ;
@@ -362,6 +385,14 @@ task("watch-lssl").flags = {
362385 " --built" : "Compile using the built version of the compiler."
363386} ;
364387
388+ const dtsLssl = ( ) => runDtsBundler ( "./built/local/tsserverlibrary/tsserverlibrary.d.ts" , "./built/local/tsserverlibrary.d.ts" ) ;
389+ task ( "dts-lssl" , series ( preBuild , buildLsslProject , dtsLssl ) ) ;
390+ task ( "dts-lssl" ) . description = "Builds tsserverlibrary.d.ts" ;
391+
392+ // TODO(jakebailey): this is probably not efficient, but, gulp.
393+ const dts = series ( preBuild , parallel ( buildServicesProject , buildLsslProject ) , parallel ( dtsServices , dtsLssl ) ) ;
394+ task ( "dts" , dts ) ;
395+
365396const testRunner = "./built/local/run.js" ;
366397const esbuildTests = esbuildTask ( "./src/testRunner/_namespaces/Harness.ts" , testRunner ) ;
367398
@@ -472,7 +503,7 @@ const buildOtherOutputs = parallel(buildCancellationToken, buildTypingsInstaller
472503task ( "other-outputs" , series ( preBuild , buildOtherOutputs ) ) ;
473504task ( "other-outputs" ) . description = "Builds miscelaneous scripts and documents distributed with the LKG" ;
474505
475- task ( "local" , series ( preBuild , parallel ( localize , buildTsc , buildServer , buildServices , buildLssl , buildOtherOutputs ) ) ) ;
506+ task ( "local" , series ( preBuild , parallel ( localize , buildTsc , buildServer , buildServices , buildLssl , buildOtherOutputs , dts ) ) ) ;
476507task ( "local" ) . description = "Builds the full compiler and services" ;
477508task ( "local" ) . flags = {
478509 " --built" : "Compile using the built version of the compiler."
@@ -488,7 +519,7 @@ const preTest = parallel(buildTsc, buildTests, buildServices, buildLssl);
488519preTest . displayName = "preTest" ;
489520
490521const runTests = ( ) => runConsoleTests ( testRunner , "mocha-fivemat-progress-reporter" , /*runInParallel*/ false , /*watchMode*/ false ) ;
491- task ( "runtests" , series ( preBuild , preTest , runTests ) ) ;
522+ task ( "runtests" , series ( preBuild , preTest , dts , runTests ) ) ;
492523task ( "runtests" ) . description = "Runs the tests using the built run.js file." ;
493524task ( "runtests" ) . flags = {
494525 "-t --tests=<regex>" : "Pattern for tests to run." ,
@@ -507,7 +538,7 @@ task("runtests").flags = {
507538} ;
508539
509540const runTestsParallel = ( ) => runConsoleTests ( testRunner , "min" , /*runInParallel*/ cmdLineOptions . workers > 1 , /*watchMode*/ false ) ;
510- task ( "runtests-parallel" , series ( preBuild , preTest , runTestsParallel ) ) ;
541+ task ( "runtests-parallel" , series ( preBuild , preTest , dts , runTestsParallel ) ) ;
511542task ( "runtests-parallel" ) . description = "Runs all the tests in parallel using the built run.js file." ;
512543task ( "runtests-parallel" ) . flags = {
513544 " --light" : "Run tests in light mode (fewer verifications, but tests run faster)." ,
@@ -594,8 +625,7 @@ const produceLKG = async () => {
594625 }
595626} ;
596627
597- // TODO(jakebailey): dependencies on dts
598- task ( "LKG" , series ( lkgPreBuild , parallel ( localize , buildTsc , buildServer , buildServices , buildLssl , buildOtherOutputs ) , produceLKG ) ) ;
628+ task ( "LKG" , series ( lkgPreBuild , parallel ( localize , buildTsc , buildServer , buildServices , buildLssl , buildOtherOutputs , dts ) , produceLKG ) ) ;
599629task ( "LKG" ) . description = "Makes a new LKG out of the built js files" ;
600630task ( "LKG" ) . flags = {
601631 " --built" : "Compile using the built version of the compiler." ,
0 commit comments