UNPKG

projen

Version:

CDK for software projects

111 lines • 15.8 kB
"use strict"; var _a, _b; Object.defineProperty(exports, "__esModule", { value: true }); exports.SampleDir = exports.SampleFile = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const fs = require("fs"); const path = require("path"); const glob = require("fast-glob"); const component_1 = require("./component"); const util_1 = require("./util"); /** * Produces a file with the given contents but only once, if the file doesn't already exist. * Use this for creating example code files or other resources. */ class SampleFile extends component_1.Component { /** * Creates a new SampleFile object * @param project - the project to tie this file to. * @param filePath - the relative path in the project to put the file * @param options - the options for the file. */ constructor(project, filePath, options) { super(project); if (options.contents && options.sourcePath) { throw new Error("Cannot specify both 'contents' and 'source' fields."); } if (!options.contents && !options.sourcePath) { throw new Error("Must specify at least one of 'contents' or 'source'."); } this.filePath = filePath; this.options = options; } synthesize() { let contents; if (this.options.contents) { contents = this.options.contents; } else if (this.options.sourcePath) { contents = fs.readFileSync(this.options.sourcePath); } this.writeOnceFileContents(this.project.outdir, this.filePath, contents ?? ""); } /** * A helper function that will write the file once and return if it was written or not. * @param dir - the directory for the new file * @param filename - the filename for the new file * @param contents - the contents of the file to write * @return boolean - whether a new file was written or not. * @private */ writeOnceFileContents(dir, filename, contents) { const fullFilename = path.join(dir, filename); if (fs.existsSync(fullFilename)) { return; } (0, util_1.writeFile)(fullFilename, contents, { readonly: false }); } } exports.SampleFile = SampleFile; _a = JSII_RTTI_SYMBOL_1; SampleFile[_a] = { fqn: "projen.SampleFile", version: "0.99.51" }; /** * Renders the given files into the directory if the directory does not exist. Use this to create sample code files */ class SampleDir extends component_1.Component { /** * Create sample files in the given directory if the given directory does not exist * @param project Parent project to add files to. * @param dir directory to add files to. If directory already exists, nothing is added. * @param options options for which files to create. */ constructor(project, dir, options) { super(project); if (!options.files && !options.sourceDir) { throw new Error("Must specify at least one of 'files' or 'source'."); } this.dir = dir; this.options = options; } synthesize() { const fullOutdir = path.join(this.project.outdir, this.dir); if (fs.existsSync(fullOutdir)) { return; } // previously creating the directory to allow empty dirs to be created fs.mkdirSync(fullOutdir, { recursive: true }); if (this.options.sourceDir) { const basedir = this.options.sourceDir; const files = glob.sync("**", { cwd: basedir, onlyFiles: true, followSymbolicLinks: false, dot: true, }); // returns relative file paths with POSIX separators for (const file of files) { const sourcePath = path.join(basedir, file); const targetPath = path.join(fullOutdir, file); fs.mkdirSync(path.dirname(targetPath), { recursive: true }); fs.copyFileSync(sourcePath, targetPath); fs.chmodSync(targetPath, (0, util_1.getFilePermissions)({ readonly: false, executable: false })); } } for (const filename in this.options.files) { (0, util_1.writeFile)(path.join(fullOutdir, filename), this.options.files[filename]); } } } exports.SampleDir = SampleDir; _b = JSII_RTTI_SYMBOL_1; SampleDir[_b] = { fqn: "projen.SampleDir", version: "0.99.51" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sample-file.js","sourceRoot":"","sources":["../src/sample-file.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as glob from \"fast-glob\";\nimport { Component } from \"./component\";\nimport type { Project } from \"./project\";\nimport { getFilePermissions, writeFile } from \"./util\";\n\n/**\n * Options for the SampleFile object.\n */\nexport interface SampleFileOptions {\n  /**\n   * The contents of the file to write.\n   */\n  readonly contents?: string;\n\n  /**\n   * Absolute path to a file to copy the contents from (does not need to be\n   * a text file).\n   *\n   * If your project is Typescript-based and has configured `testdir` to be a\n   * subdirectory of `src`, sample files should outside of the `src` directory,\n   * otherwise they may not be copied. For example:\n   * ```\n   * new SampleFile(this, 'assets/icon.png', { sourcePath: path.join(__dirname, '..', 'sample-assets', 'icon.png') });\n   * ```\n   */\n  readonly sourcePath?: string;\n}\n\n/**\n * Produces a file with the given contents but only once, if the file doesn't already exist.\n * Use this for creating example code files or other resources.\n */\nexport class SampleFile extends Component {\n  private readonly filePath: string;\n  private readonly options: SampleFileOptions;\n\n  /**\n   * Creates a new SampleFile object\n   * @param project - the project to tie this file to.\n   * @param filePath - the relative path in the project to put the file\n   * @param options - the options for the file.\n   */\n  constructor(project: Project, filePath: string, options: SampleFileOptions) {\n    super(project);\n\n    if (options.contents && options.sourcePath) {\n      throw new Error(\"Cannot specify both 'contents' and 'source' fields.\");\n    }\n    if (!options.contents && !options.sourcePath) {\n      throw new Error(\"Must specify at least one of 'contents' or 'source'.\");\n    }\n    this.filePath = filePath;\n    this.options = options;\n  }\n\n  public synthesize() {\n    let contents;\n    if (this.options.contents) {\n      contents = this.options.contents;\n    } else if (this.options.sourcePath) {\n      contents = fs.readFileSync(this.options.sourcePath);\n    }\n    this.writeOnceFileContents(\n      this.project.outdir,\n      this.filePath,\n      contents ?? \"\",\n    );\n  }\n\n  /**\n   * A helper function that will write the file once and return if it was written or not.\n   * @param dir - the directory for the new file\n   * @param filename - the filename for the new file\n   * @param contents - the contents of the file to write\n   * @return boolean - whether a new file was written or not.\n   * @private\n   */\n  private writeOnceFileContents(dir: string, filename: string, contents: any) {\n    const fullFilename = path.join(dir, filename);\n    if (fs.existsSync(fullFilename)) {\n      return;\n    }\n    writeFile(fullFilename, contents, { readonly: false });\n  }\n}\n\n/**\n * SampleDir options\n */\nexport interface SampleDirOptions {\n  /**\n   * The files to render into the directory. These files get added after\n   * any files from `source` if that option is specified (replacing if names\n   * overlap).\n   */\n  readonly files?: { [fileName: string]: string };\n\n  /**\n   * Absolute path to a directory to copy files from (does not need to be text\n   * files).\n   *\n   * If your project is typescript-based and has configured `testdir` to be a\n   * subdirectory of `src`, sample files should outside of the `src` directory\n   * otherwise they may not be copied. For example:\n   * ```\n   * new SampleDir(this, 'public', { source: path.join(__dirname, '..', 'sample-assets') });\n   * ```\n   */\n  readonly sourceDir?: string;\n}\n\n/**\n * Renders the given files into the directory if the directory does not exist. Use this to create sample code files\n */\nexport class SampleDir extends Component {\n  private readonly dir: string;\n  private readonly options: SampleDirOptions;\n\n  /**\n   * Create sample files in the given directory if the given directory does not exist\n   * @param project Parent project to add files to.\n   * @param dir directory to add files to. If directory already exists, nothing is added.\n   * @param options options for which files to create.\n   */\n  constructor(project: Project, dir: string, options: SampleDirOptions) {\n    super(project);\n    if (!options.files && !options.sourceDir) {\n      throw new Error(\"Must specify at least one of 'files' or 'source'.\");\n    }\n\n    this.dir = dir;\n    this.options = options;\n  }\n\n  public synthesize() {\n    const fullOutdir = path.join(this.project.outdir, this.dir);\n    if (fs.existsSync(fullOutdir)) {\n      return;\n    }\n\n    // previously creating the directory to allow empty dirs to be created\n    fs.mkdirSync(fullOutdir, { recursive: true });\n\n    if (this.options.sourceDir) {\n      const basedir = this.options.sourceDir;\n      const files = glob.sync(\"**\", {\n        cwd: basedir,\n        onlyFiles: true,\n        followSymbolicLinks: false,\n        dot: true,\n      }); // returns relative file paths with POSIX separators\n\n      for (const file of files) {\n        const sourcePath = path.join(basedir, file);\n        const targetPath = path.join(fullOutdir, file);\n\n        fs.mkdirSync(path.dirname(targetPath), { recursive: true });\n        fs.copyFileSync(sourcePath, targetPath);\n        fs.chmodSync(\n          targetPath,\n          getFilePermissions({ readonly: false, executable: false }),\n        );\n      }\n    }\n\n    for (const filename in this.options.files) {\n      writeFile(path.join(fullOutdir, filename), this.options.files[filename]);\n    }\n  }\n}\n"]}