@inst/vscode-bin-darwin
Version:
BINARY ONLY - VSCode binary deployment for macOS
87 lines (86 loc) • 4.81 kB
JavaScript
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
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) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const nls = require("vscode-nls");
const localize = nls.config(process.env.VSCODE_NLS_CONFIG)(__filename);
const vscode_1 = require("vscode");
const git_1 = require("./git");
const model_1 = require("./model");
const commands_1 = require("./commands");
const contentProvider_1 = require("./contentProvider");
const askpass_1 = require("./askpass");
const util_1 = require("./util");
const vscode_extension_telemetry_1 = require("vscode-extension-telemetry");
function init(context, disposables) {
return __awaiter(this, void 0, void 0, function* () {
const { name, version, aiKey } = require(context.asAbsolutePath('./package.json'));
const telemetryReporter = new vscode_extension_telemetry_1.default(name, version, aiKey);
disposables.push(telemetryReporter);
const outputChannel = vscode_1.window.createOutputChannel('Git');
disposables.push(outputChannel);
const config = vscode_1.workspace.getConfiguration('git');
const enabled = config.get('enabled') === true;
const pathHint = vscode_1.workspace.getConfiguration('git').get('path');
const info = yield git_1.findGit(pathHint);
const askpass = new askpass_1.Askpass();
const env = yield askpass.getEnv();
const git = new git_1.Git({ gitPath: info.path, version: info.version, env });
const model = new model_1.Model(git);
disposables.push(model);
const onRepository = () => vscode_1.commands.executeCommand('setContext', 'gitOpenRepositoryCount', `${model.repositories.length}`);
model.onDidOpenRepository(onRepository, null, disposables);
model.onDidCloseRepository(onRepository, null, disposables);
onRepository();
if (!enabled) {
const commandCenter = new commands_1.CommandCenter(git, model, outputChannel, telemetryReporter);
disposables.push(commandCenter);
return;
}
outputChannel.appendLine(localize(0, null, info.version, info.path));
const onOutput = str => outputChannel.append(str);
git.onOutput.addListener('log', onOutput);
disposables.push(util_1.toDisposable(() => git.onOutput.removeListener('log', onOutput)));
disposables.push(new commands_1.CommandCenter(git, model, outputChannel, telemetryReporter), new contentProvider_1.GitContentProvider(model));
yield checkGitVersion(info);
});
}
function activate(context) {
const disposables = [];
context.subscriptions.push(new vscode_1.Disposable(() => vscode_1.Disposable.from(...disposables).dispose()));
init(context, disposables)
.catch(err => console.error(err));
}
exports.activate = activate;
function checkGitVersion(info) {
return __awaiter(this, void 0, void 0, function* () {
const config = vscode_1.workspace.getConfiguration('git');
const shouldIgnore = config.get('ignoreLegacyWarning') === true;
if (shouldIgnore) {
return;
}
if (!/^[01]/.test(info.version)) {
return;
}
const update = localize(1, null);
const neverShowAgain = localize(2, null);
const choice = yield vscode_1.window.showWarningMessage(localize(3, null, info.version), update, neverShowAgain);
if (choice === update) {
vscode_1.commands.executeCommand('vscode.open', vscode_1.Uri.parse('https://git-scm.com/'));
}
else if (choice === neverShowAgain) {
yield config.update('ignoreLegacyWarning', true, true);
}
});
}
//# sourceMappingURL=https://ticino.blob.core.windows.net/sourcemaps/b813d12980308015bcd2b3a2f6efa5c810c33ba5/extensions/git/out/main.js.map