turbo-gulp
Version:
Gulp tasks to boost high-quality projects.
85 lines (83 loc) • 12.1 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
result["default"] = mod;
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
const fs_1 = require("fs");
const gulp_tslint_1 = __importDefault(require("gulp-tslint"));
const minimatch_1 = require("minimatch");
const path_1 = require("path");
const tslint = __importStar(require("tslint"));
const tslint_1 = require("tslint");
const typescript_1 = require("typescript");
const tslint_2 = require("../options/tslint");
const matcher = __importStar(require("../utils/matcher"));
exports.taskName = ":lint";
function getSources(project) {
const baseDir = project.root;
const sources = [];
let patterns;
if (project.tslint !== undefined && project.tslint.files !== undefined) {
patterns = project.tslint.files;
}
else {
patterns = [path_1.posix.join(project.srcDir, "**/*.ts")];
}
for (const pattern of patterns) {
const minimatchPattern = new minimatch_1.Minimatch(pattern);
const glob = matcher.asString(matcher.join(baseDir, minimatchPattern));
sources.push(glob);
}
return { baseDir, sources };
}
exports.getSources = getSources;
function createTsProgram(tsconfigJson, basePath) {
const parseConfigHost = {
useCaseSensitiveFileNames: true,
readDirectory: typescript_1.sys.readDirectory,
fileExists: fs_1.existsSync,
readFile: (path) => fs_1.readFileSync(path, "utf8"),
};
const parsed = typescript_1.parseJsonConfigFileContent(tsconfigJson, parseConfigHost, basePath, { noEmit: true });
const host = typescript_1.createCompilerHost(parsed.options, true);
return typescript_1.createProgram(parsed.fileNames, parsed.options, host);
}
function registerTask(gulp, project) {
let configuration;
const baseConfig = tslint_1.Configuration.parseConfigFile(tslint_2.DEFAULT_TYPED_TSLINT_CONFIG, project.root);
if (project.tslint !== undefined && project.tslint.configuration !== undefined) {
const userRawConfig = project.tslint.configuration;
let userConfig;
if (typeof userRawConfig === "string") {
const configPath = path_1.posix.join(project.root, userRawConfig);
userConfig = tslint_1.Configuration.loadConfigurationFromPath(configPath);
}
else {
userConfig = tslint_1.Configuration.parseConfigFile(userRawConfig, project.root);
}
configuration = tslint_1.Configuration.extendConfigurationFile(baseConfig, userConfig);
}
else {
configuration = baseConfig;
}
const program = createTsProgram({ compilerOptions: {} }, project.root);
const options = Object.assign({ emitError: true, formatter: "msbuild", tslint }, project.tslint, { configuration,
program });
const sources = getSources(project);
gulp.task(exports.taskName, function () {
return gulp.src(sources.sources, { base: sources.baseDir })
.pipe(gulp_tslint_1.default(options))
.pipe(gulp_tslint_1.default.report({
summarizeFailureOutput: true,
}));
});
}
exports.registerTask = registerTask;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["_src/project-tasks/lint.ts"],"names":[],"mappings":"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","file":"project-tasks/lint.js","sourcesContent":["import { existsSync as fileExistsSync, readFileSync } from \"fs\";\nimport { Gulp } from \"gulp\";\nimport { default as gulpTslint, PluginOptions as GulpTslintOptions } from \"gulp-tslint\";\nimport { IMinimatch, Minimatch } from \"minimatch\";\nimport { posix as path } from \"path\";\nimport * as tslint from \"tslint\";\nimport { Configuration as TslintConfiguration } from \"tslint\";\nimport {\n  CompilerHost,\n  createCompilerHost,\n  createProgram,\n  ParseConfigHost,\n  ParsedCommandLine,\n  parseJsonConfigFileContent,\n  Program,\n  sys as tsSys,\n} from \"typescript\";\nimport { DEFAULT_TYPED_TSLINT_CONFIG } from \"../options/tslint\";\nimport { Project } from \"../project\";\nimport * as matcher from \"../utils/matcher\";\n\nexport const taskName: string = \":lint\";\n\n/**\n * Sources to use when compiling TS code\n */\nexport interface Sources {\n  /**\n   * Base directory to use when expanding glob stars.\n   */\n  baseDir: string;\n\n  /**\n   * List of absolute patterns for the sources (script or type definition) files\n   */\n  sources: string[];\n}\n\nexport function getSources(project: Project): Sources {\n  const baseDir: string = project.root;\n  const sources: string[] = [];\n  let patterns: string[];\n\n  if (project.tslint !== undefined && project.tslint.files !== undefined) {\n    patterns = project.tslint.files;\n  } else {\n    patterns = [path.join(project.srcDir, \"**/*.ts\")];\n  }\n\n  for (const pattern of patterns) {\n    const minimatchPattern: IMinimatch = new Minimatch(pattern);\n    const glob: string = matcher.asString(matcher.join(baseDir, minimatchPattern));\n    sources.push(glob);\n  }\n\n  return {baseDir, sources};\n}\n\nfunction createTsProgram(tsconfigJson: any, basePath: string): Program {\n  const parseConfigHost: ParseConfigHost = {\n    useCaseSensitiveFileNames: true,\n    readDirectory: tsSys.readDirectory,\n    fileExists: fileExistsSync,\n    readFile: (path: string) => readFileSync(path, \"utf8\"),\n  };\n  const parsed: ParsedCommandLine = parseJsonConfigFileContent(\n    tsconfigJson,\n    parseConfigHost,\n    basePath,\n    {noEmit: true},\n  );\n  const host: CompilerHost = createCompilerHost(parsed.options, true);\n  return createProgram(parsed.fileNames, parsed.options, host);\n}\n\nexport function registerTask(gulp: Gulp, project: Project) {\n  type TslintRawConfig = TslintConfiguration.RawConfigFile;\n  type TslintConfig = TslintConfiguration.IConfigurationFile;\n\n  let configuration: TslintConfig;\n\n  const baseConfig: TslintConfig = TslintConfiguration.parseConfigFile(DEFAULT_TYPED_TSLINT_CONFIG, project.root);\n\n  if (project.tslint !== undefined && project.tslint.configuration !== undefined) {\n    const userRawConfig: TslintRawConfig | string = project.tslint.configuration;\n    let userConfig: TslintConfig;\n    if (typeof userRawConfig === \"string\") {\n      const configPath: string = path.join(project.root, userRawConfig);\n      userConfig = TslintConfiguration.loadConfigurationFromPath(configPath);\n    } else {\n      userConfig = TslintConfiguration.parseConfigFile(userRawConfig, project.root);\n    }\n    configuration = TslintConfiguration.extendConfigurationFile(baseConfig, userConfig);\n  } else {\n    configuration = baseConfig;\n  }\n\n  const program: Program = createTsProgram({compilerOptions: {}}, project.root);\n\n  const options: any = {\n    emitError: true,\n    formatter: \"msbuild\",\n    tslint,\n    ...(project.tslint as GulpTslintOptions),\n    configuration,\n    program,\n  };\n\n  const sources: Sources = getSources(project);\n\n  gulp.task(taskName, function () {\n    return gulp.src(sources.sources, {base: sources.baseDir})\n      .pipe(gulpTslint(options))\n      .pipe(gulpTslint.report({\n        summarizeFailureOutput: true,\n      }));\n  });\n}\n"],"sourceRoot":".."}