12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- "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;
|