UNPKG

atom-nuclide

Version:

A unified developer experience for web and mobile development, built as a suite of features on top of Atom to provide hackability and the support of an active community.

238 lines (222 loc) 9.04 kB
Object.defineProperty(exports, '__esModule', { value: true }); /* * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the license found in the LICENSE file in * the root directory of this source tree. */ var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { var callNext = step.bind(null, 'next'); var callThrow = step.bind(null, 'throw'); function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(callNext, callThrow); } } callNext(); }); }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } var _nuclideHgRpcLibHgConstants2; function _nuclideHgRpcLibHgConstants() { return _nuclideHgRpcLibHgConstants2 = require('../../nuclide-hg-rpc/lib/hg-constants'); } /* * Delegate to the passed in HgRepositoryClient. */ var HgRepositoryClientAsync = (function () { function HgRepositoryClientAsync(client) { _classCallCheck(this, HgRepositoryClientAsync); this._client = client; } _createClass(HgRepositoryClientAsync, [{ key: 'getType', value: function getType() { return this._client.getType(); } }, { key: 'getWorkingDirectory', value: function getWorkingDirectory() { return this._client.getWorkingDirectory(); } /** * That extends the `GitRepositoryAsync` implementation which takes a single file path. * Here, it's possible to pass an array of file paths to revert/checkout-head. */ }, { key: 'checkoutHead', value: function checkoutHead(filePathsArg) { var filePaths = Array.isArray(filePathsArg) ? filePathsArg : [filePathsArg]; return this._client._service.revert(filePaths); } }, { key: 'checkoutReference', value: function checkoutReference(reference, create) { return this._client._service.checkout(reference, create); } }, { key: 'createBookmark', value: function createBookmark(name, revision) { return this._client._service.createBookmark(name, revision); } }, { key: 'deleteBookmark', value: function deleteBookmark(name) { return this._client._service.deleteBookmark(name); } }, { key: 'renameBookmark', value: function renameBookmark(name, nextName) { return this._client._service.renameBookmark(name, nextName); } }, { key: 'getBookmarks', value: function getBookmarks() { return this._client._service.fetchBookmarks(); } }, { key: 'getShortHead', value: _asyncToGenerator(function* () { var newlyFetchedBookmark = ''; try { newlyFetchedBookmark = yield this._client._service.fetchActiveBookmark(); } catch (e) { // Suppress the error. There are legitimate times when there may be no // current bookmark, such as during a rebase. In this case, we just want // to return an empty string if there is no current bookmark. } if (newlyFetchedBookmark !== this._client._activeBookmark) { this._client._activeBookmark = newlyFetchedBookmark; // The Atom status-bar uses this as a signal to refresh the 'shortHead'. // There is currently no dedicated 'shortHeadDidChange' event. this._client._emitter.emit('did-change-statuses'); this._client._emitter.emit('did-change-short-head'); } return this._client._activeBookmark || ''; }) }, { key: 'getCachedPathStatus', value: function getCachedPathStatus(filePath) { return Promise.resolve(this._client.getCachedPathStatus(filePath)); } // TODO This is a stub. }, { key: 'getCachedUpstreamAheadBehindCount', value: function getCachedUpstreamAheadBehindCount(path) { return Promise.resolve(this._client.getCachedUpstreamAheadBehindCount(path)); } }, { key: 'getDiffStats', value: function getDiffStats(filePath) { return Promise.resolve(this._client.getDiffStats(filePath)); } /** * Recommended method to use to get the line diffs of files in this repo. * @param path The absolute file path to get the line diffs for. If the path \ * is not in the project, an empty Array will be returned. */ }, { key: 'getLineDiffs', value: function getLineDiffs(filePath) { return Promise.resolve(this._client.getLineDiffs(filePath)); } }, { key: 'refreshStatus', value: _asyncToGenerator(function* () { var repoRoot = this._client.getWorkingDirectory(); var repoProjects = atom.project.getPaths().filter(function (projPath) { return projPath.startsWith(repoRoot); }); yield this._client.getStatuses(repoProjects, { hgStatusOption: (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).HgStatusOption.ONLY_NON_IGNORED }); }) }, { key: 'getHeadCommitMessage', value: function getHeadCommitMessage() { return this._client._service.getHeadCommitMessage(); } /** * Return relative paths to status code number values object. * matching `GitRepositoryAsync` implementation. */ }, { key: 'getCachedPathStatuses', value: function getCachedPathStatuses() { var absoluteCodePaths = this._client.getAllPathStatuses(); var relativeCodePaths = {}; for (var absolutePath in absoluteCodePaths) { var relativePath = this._client.relativize(absolutePath); relativeCodePaths[relativePath] = absoluteCodePaths[absolutePath]; } return relativeCodePaths; } }, { key: 'isPathIgnored', value: function isPathIgnored(filePath) { return Promise.resolve(this._client.isPathIgnored(filePath)); } }, { key: 'isStatusStaged', value: function isStatusStaged(status) { return false; } }, { key: 'isStatusIgnored', value: function isStatusIgnored(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.IGNORED; } }, { key: 'isStatusModified', value: function isStatusModified(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.MODIFIED; } }, { key: 'isStatusDeleted', value: function isStatusDeleted(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.MISSING || status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.REMOVED; } }, { key: 'isStatusNew', value: function isStatusNew(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.ADDED || status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.UNTRACKED; } }, { key: 'isStatusAdded', value: function isStatusAdded(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.ADDED; } }, { key: 'isStatusUntracked', value: function isStatusUntracked(status) { return status === (_nuclideHgRpcLibHgConstants2 || _nuclideHgRpcLibHgConstants()).StatusCodeNumber.UNTRACKED; } }, { key: 'onDidChangeBookmarks', value: function onDidChangeBookmarks(callback) { return this._client._emitter.on('did-change-bookmarks', callback); } }, { key: 'onDidChangeShortHead', value: function onDidChangeShortHead(callback) { return this._client._emitter.on('did-change-short-head', callback); } }, { key: 'onDidChangeStatus', value: function onDidChangeStatus(callback) { return this._client.onDidChangeStatus(callback); } }, { key: 'onDidChangeStatuses', value: function onDidChangeStatuses(callback) { return this._client.onDidChangeStatuses(callback); } }, { key: 'addAll', value: function addAll(filePaths) { return this._client.addAll(filePaths); } }, { key: 'onDidDestroy', value: function onDidDestroy(callback) { return this._client.onDidDestroy(callback); } }]); return HgRepositoryClientAsync; })(); exports.default = HgRepositoryClientAsync; module.exports = exports.default;