UNPKG

sql-code-generator

Version:

Generate code from your SQL schema and queries for type safety and development speed.

32 lines 1.76 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.extractSqlFromTsFile = void 0; const readFileAsync_1 = require("../readFileAsync"); /* note: in order to not block users when they have typescript type errors (by using ts-node), we can simply parse the file contents and grab the `export const sql = `__SQL__`;` w/ regex */ const extractSqlFromTsFile = (_a) => __awaiter(void 0, [_a], void 0, function* ({ filePath, }) { var _b; // grab file contents const content = yield (0, readFileAsync_1.readFileAsync)({ filePath }); // grab the sql definition w/ regex const [_, // tslint:disable-line no-unused sqlMatch,] = (_b = new RegExp(/(?:export const sql = `)((.|\n)+)(?:`)/).exec(content)) !== null && _b !== void 0 ? _b : []; // throw error if could not extract if (!sqlMatch) throw new Error(`could not extract sql from file at path '${filePath}'`); // return the sql return sqlMatch; }); exports.extractSqlFromTsFile = extractSqlFromTsFile; //# sourceMappingURL=extractSqlFromTsFile.js.map