"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.git_log = exports.git_status = void 0; const __1 = require("../../"); const constants_1 = require("../../constants"); const path = require("path"); const simpleGit = require("simple-git/promise"); const moment = require("moment"); function git_status(cwd, dir) { return __awaiter(this, void 0, void 0, function* () { const git = simpleGit(cwd); let statusSummary = null; try { statusSummary = yield git.log(['--stat', path.resolve(dir)]); } catch (e) { __1.logger.error('Error Git', e); } return statusSummary; }); } exports.git_status = git_status; function git_log(cwd, dir) { return __awaiter(this, void 0, void 0, function* () { const stats = yield git_status(cwd, dir); __1.logger.info(`Reading Git log at ${cwd}/${dir}`); let changelogs = stats.all.filter((e) => e.message.trim().toLowerCase().startsWith(constants_1.GIT_CHANGELOG_MESSAGE_PREFIX.toLowerCase())); if (!changelogs.length) { return { files: [], last: stats.latest }; } let pretty = changelogs.map((e) => { return { files: e.diff.files.map((f) => { return { path: f.file }; }), msg: e.message.toLowerCase().replace(constants_1.GIT_CHANGELOG_MESSAGE_PREFIX.toLowerCase(), '').trim(), hash: e.hash, date: moment(e.date).format('LLLL') }; }); return { files: pretty, last: stats.latest }; }); } exports.git_log = git_log; ; //# sourceMappingURL=log.js.map