tscoverage/ts/npmts.compile.ts

95 lines
3.2 KiB
TypeScript
Raw Normal View History

2016-05-25 03:23:48 +00:00
import "typings-global";
2016-02-19 23:53:23 +00:00
import plugins = require("./npmts.plugins");
import paths = require("./npmts.paths");
import helpers = require("./npmts.compile.helpers");
2016-05-17 00:32:40 +00:00
import {npmtsOra} from "./npmts.promisechain";
2016-05-01 19:15:52 +00:00
/**
* handles definition to make them fit for modular use
*/
let definitionHandler = function(configArg){
2016-05-17 00:32:40 +00:00
npmtsOra.text("now making declaration files ready");
2016-05-01 19:15:52 +00:00
let done = plugins.Q.defer();
let configTsLenght = Object.keys(configArg.ts).length;
if(configTsLenght == 0) {
2016-06-07 06:49:22 +00:00
plugins.beautylog.warn("No TS file and thus no definitions found!");
2016-05-01 19:15:52 +00:00
done.resolve(configArg); //if there are no definition files, resolve...
}
let localCounter = 0;
for (let key in configArg.ts){
let distPath = configArg.ts[key];
let stream = plugins.gulp.src(plugins.path.join(distPath,"**/*.d.ts"))
.pipe(plugins.g.replace(plugins.smartstring.typescript.regexReferencePath,""))
.pipe(plugins.gulp.dest(distPath))
.pipe(plugins.g.gFunction(function(){
localCounter++
if(localCounter == configTsLenght){
2016-05-17 00:32:40 +00:00
plugins.beautylog.ok("made declaration files ready!");
2016-05-01 19:15:52 +00:00
done.resolve(configArg)
};
},"atEnd"));
}
return done.promise;
}
2016-06-07 06:49:22 +00:00
let compileTs = (tsFileArrayArg,tsOptionsArg = {}) => {
let done = plugins.Q.defer();
let moduleStream = plugins.merge2({ end: false });
2016-03-12 09:21:16 +00:00
let tsOptionsDefault = {
declaration: true,
target: "ES5",
module: "commonjs"
};
/**
* merges default ts options with those found in npmts.json
*/
let tsOptions = function (keyArg:string) {
2016-06-07 06:49:22 +00:00
return plugins.lodashObject.assign(tsOptionsDefault, tsOptionsArg)
};
2016-06-07 06:49:22 +00:00
for (let keyArg in tsFileArrayArg) {
if (helpers.checkOutputPath(tsFileArrayArg,keyArg)) {
let tsStream = plugins.gulp.src([plugins.path.join(paths.cwd, keyArg), "!**/typings/**"])
.pipe(plugins.g.sourcemaps.init()) // This means sourcemaps will be generated
.pipe(plugins.g.typescript(tsOptions(keyArg)));
let jsStream = tsStream.js
.pipe(plugins.g.sourcemaps.write()) // Now the sourcemaps are added to the .js file
2016-06-07 06:49:22 +00:00
.pipe(plugins.gulp.dest(tsFileArrayArg[keyArg]));
let declarationStream = tsStream.dts
2016-06-07 06:49:22 +00:00
.pipe(plugins.gulp.dest(tsFileArrayArg[keyArg]));
moduleStream.add(tsStream,jsStream,declarationStream);
}
}
2016-06-07 06:49:22 +00:00
moduleStream.on("queueDrain",() => {
done.resolve();
})
return done.promise;
}
2016-06-07 06:49:22 +00:00
export let run = function (configArg) {
let done = plugins.Q.defer();
let config = configArg;
npmtsOra.text("now compiling " + "TypeScript".yellow);
compileTs(config.ts,config.tsOptions)
.then(() => {
2016-06-07 06:53:47 +00:00
compileTs(config.testTs);
2016-06-07 06:49:22 +00:00
})
.then(function () {
2016-05-17 00:32:40 +00:00
plugins.beautylog.ok("compiled TypeScript!");
2016-05-01 19:15:52 +00:00
definitionHandler(config)
2016-06-07 06:49:22 +00:00
.then(function(){
done.resolve(config);
});
2016-02-09 04:39:31 +00:00
});
/*==================== END TS Compilation =====================*/
2016-03-12 09:21:16 +00:00
2016-02-19 23:53:23 +00:00
return done.promise;
};