sql-code-generator
Version:
Generate code from your SQL schema and queries for type safety and development speed.
32 lines • 1.76 kB
JavaScript
;
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