projen
Version:
CDK for software projects
111 lines • 15.8 kB
JavaScript
;
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.17" };
/**
* 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.17" };
//# 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 { 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"]}