This repository has been archived on 2020-11-02. You can view files and clone it, but cannot push or open issues or pull requests.
TripSit_Suite/node_modules/pretty-quick/dist/scms/git.js
2020-11-01 22:46:04 +00:00

82 lines
3.0 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.stageFile = exports.getUnstagedChangedFiles = exports.getChangedFiles = exports.getSinceRevision = exports.detect = exports.name = void 0;
var _findUp = _interopRequireDefault(require("find-up"));
var _execa = _interopRequireDefault(require("execa"));
var _path = require("path");
var fs = _interopRequireWildcard(require("fs"));
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function () { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const name = 'git';
exports.name = name;
const detect = directory => {
if (fs.existsSync((0, _path.join)(directory, '.git'))) {
return directory;
}
const gitDirectory = _findUp.default.sync('.git', {
cwd: directory,
type: 'directory'
});
if (gitDirectory) {
return (0, _path.dirname)(gitDirectory);
}
};
exports.detect = detect;
const runGit = (directory, args) => _execa.default.sync('git', args, {
cwd: directory
});
const getLines = execaResult => execaResult.stdout.split('\n');
const getSinceRevision = (directory, {
staged,
branch
}) => {
try {
const revision = staged ? 'HEAD' : runGit(directory, ['merge-base', 'HEAD', branch || 'master']).stdout.trim();
return runGit(directory, ['rev-parse', '--short', revision]).stdout.trim();
} catch (error) {
if (/HEAD/.test(error.message) || staged && /Needed a single revision/.test(error.message)) {
return null;
}
throw error;
}
};
exports.getSinceRevision = getSinceRevision;
const getChangedFiles = (directory, revision, staged) => {
return [...getLines(runGit(directory, ['diff', '--name-only', staged ? '--cached' : null, '--diff-filter=ACMRTUB', revision].filter(Boolean))), ...(staged ? [] : getLines(runGit(directory, ['ls-files', '--others', '--exclude-standard'])))].filter(Boolean);
};
exports.getChangedFiles = getChangedFiles;
const getUnstagedChangedFiles = directory => {
return getChangedFiles(directory, null, false);
};
exports.getUnstagedChangedFiles = getUnstagedChangedFiles;
const stageFile = (directory, file) => {
runGit(directory, ['add', file]);
};
exports.stageFile = stageFile;