UNPKG

turbo-gulp

Version:

Gulp tasks to boost high-quality projects.

82 lines (80 loc) 12.2 kB
"use strict"; 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 = 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":["project-tasks/lint.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2BAAgE;AAEhE,6CAAwF;AACxF,yCAAkD;AAClD,+BAAqC;AACrC,+CAAiC;AACjC,mCAA8D;AAC9D,2CASoB;AACpB,8CAAgE;AAEhE,0DAA4C;AAE/B,QAAA,QAAQ,GAAW,OAAO,CAAC;AAiBxC,oBAA2B,OAAgB;IACzC,MAAM,OAAO,GAAW,OAAO,CAAC,IAAI,CAAC;IACrC,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,IAAI,QAAkB,CAAC;IAEvB,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,KAAK,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC;QACvE,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;IAClC,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,QAAQ,GAAG,CAAC,YAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,GAAG,CAAC,CAAC,MAAM,OAAO,IAAI,QAAQ,CAAC,CAAC,CAAC;QAC/B,MAAM,gBAAgB,GAAe,IAAI,qBAAS,CAAC,OAAO,CAAC,CAAC;QAC5D,MAAM,IAAI,GAAW,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC;QAC/E,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,EAAC,OAAO,EAAE,OAAO,EAAC,CAAC;AAC5B,CAAC;AAlBD,gCAkBC;AAED,yBAAyB,YAAiB,EAAE,QAAgB;IAC1D,MAAM,eAAe,GAAoB;QACvC,yBAAyB,EAAE,IAAI;QAC/B,aAAa,EAAE,gBAAK,CAAC,aAAa;QAClC,UAAU,EAAE,eAAc;QAC1B,QAAQ,EAAE,CAAC,IAAY,EAAE,EAAE,CAAC,iBAAY,CAAC,IAAI,EAAE,MAAM,CAAC;KACvD,CAAC;IACF,MAAM,MAAM,GAAsB,uCAA0B,CAC1D,YAAY,EACZ,eAAe,EACf,QAAQ,EACR,EAAC,MAAM,EAAE,IAAI,EAAC,CACf,CAAC;IACF,MAAM,IAAI,GAAiB,+BAAkB,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACpE,MAAM,CAAC,0BAAa,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAC/D,CAAC;AAED,sBAA6B,IAAU,EAAE,OAAgB;IAIvD,IAAI,aAA2B,CAAC;IAEhC,MAAM,UAAU,GAAiB,sBAAmB,CAAC,eAAe,CAAC,oCAA2B,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IAEhH,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,KAAK,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC,aAAa,KAAK,SAAS,CAAC,CAAC,CAAC;QAC/E,MAAM,aAAa,GAA6B,OAAO,CAAC,MAAM,CAAC,aAAa,CAAC;QAC7E,IAAI,UAAwB,CAAC;QAC7B,EAAE,CAAC,CAAC,OAAO,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC;YACtC,MAAM,UAAU,GAAW,YAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;YAClE,UAAU,GAAG,sBAAmB,CAAC,yBAAyB,CAAC,UAAU,CAAC,CAAC;QACzE,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,UAAU,GAAG,sBAAmB,CAAC,eAAe,CAAC,aAAa,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QAChF,CAAC;QACD,aAAa,GAAG,sBAAmB,CAAC,uBAAuB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;IACtF,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,aAAa,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,MAAM,OAAO,GAAY,eAAe,CAAC,EAAC,eAAe,EAAE,EAAE,EAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9E,MAAM,OAAO,mBACX,SAAS,EAAE,IAAI,EACf,SAAS,EAAE,SAAS,EACpB,MAAM,IACF,OAAO,CAAC,MAA4B,IACxC,aAAa;QACb,OAAO,GACR,CAAC;IAEF,MAAM,OAAO,GAAY,UAAU,CAAC,OAAO,CAAC,CAAC;IAE7C,IAAI,CAAC,IAAI,CAAC,gBAAQ,EAAE;QAClB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,EAAC,IAAI,EAAE,OAAO,CAAC,OAAO,EAAC,CAAC;aACtD,IAAI,CAAC,qBAAU,CAAC,OAAO,CAAC,CAAC;aACzB,IAAI,CAAC,qBAAU,CAAC,MAAM,CAAC;YACtB,sBAAsB,EAAE,IAAI;SAC7B,CAAC,CAAC,CAAC;IACR,CAAC,CAAC,CAAC;AACL,CAAC;AA1CD,oCA0CC","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":".."}