Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(992)

Unified Diff: sdk/lib/_internal/pub/lib/src/git.dart

Issue 341643002: Make short-running Git operations synchronous. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sdk/lib/_internal/pub/lib/src/entrypoint.dart ('k') | sdk/lib/_internal/pub/lib/src/io.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sdk/lib/_internal/pub/lib/src/git.dart
diff --git a/sdk/lib/_internal/pub/lib/src/git.dart b/sdk/lib/_internal/pub/lib/src/git.dart
index d79a914073e6d2c818b39718d9ae7350f96854c6..e6f20cb269c15b9d6da290d7ab9772fffe932b02 100644
--- a/sdk/lib/_internal/pub/lib/src/git.dart
+++ b/sdk/lib/_internal/pub/lib/src/git.dart
@@ -8,6 +8,8 @@ library pub.git;
import 'dart:async';
import 'dart:io';
+import 'package:stack_trace/stack_trace.dart';
+
import 'io.dart';
import 'log.dart' as log;
import 'utils.dart';
@@ -29,73 +31,76 @@ class GitException implements Exception {
}
/// Tests whether or not the git command-line app is available for use.
-Future<bool> get isInstalled {
- if (_isGitInstalledCache != null) {
- return new Future.value(_isGitInstalledCache);
- }
-
- return _gitCommand.then((git) => git != null);
+bool get isInstalled {
+ if (_isInstalledCache != null) return _isInstalledCache;
+ _isInstalledCache = _gitCommand != null;
+ return _isInstalledCache;
}
+bool _isInstalledCache;
/// Run a git process with [args] from [workingDir]. Returns the stdout as a
/// list of strings if it succeeded. Completes to an exception if it failed.
Future<List<String>> run(List<String> args,
{String workingDir, Map<String, String> environment}) {
- return _gitCommand.then((git) {
- if (git == null) {
- throw new ApplicationException(
- "Cannot find a Git executable.\n"
- "Please ensure Git is correctly installed.");
- }
-
- return runProcess(git, args, workingDir: workingDir,
- environment: environment);
- }).then((result) {
+ if (!isInstalled) {
+ throw new ApplicationException(
+ "Cannot find a Git executable.\n"
+ "Please ensure Git is correctly installed.");
+ }
+
+ return runProcess(_gitCommand, args, workingDir: workingDir,
+ environment: environment).then((result) {
if (!result.success) throw new GitException(args, result.stderr.join("\n"));
return result.stdout;
});
}
-bool _isGitInstalledCache;
+/// Like [run], but synchronous.
+List<String> runSync(List<String> args, {String workingDir,
+ Map<String, String> environment}) {
+ if (!isInstalled) {
+ throw new ApplicationException(
+ "Cannot find a Git executable.\n"
+ "Please ensure Git is correctly installed.");
+ }
-/// The cached Git command.
-String _gitCommandCache;
+ var result = runProcessSync(_gitCommand, args,
+ workingDir: workingDir,
+ environment: environment);
+ if (!result.success) throw new GitException(args, result.stderr.join("\n"));
+ return result.stdout;
+}
/// Returns the name of the git command-line app, or null if Git could not be
/// found on the user's PATH.
-Future<String> get _gitCommand {
- if (_gitCommandCache != null) {
- return new Future.value(_gitCommandCache);
+String get _gitCommand {
+ if (_commandCache != null) return _commandCache;
+
+ var command;
+ if (_tryGitCommand("git")) {
+ _commandCache = "git";
+ } else if (_tryGitCommand("git.cmd")){
+ _commandCache = "git.cmd";
+ } else {
+ return null;
}
- return _tryGitCommand("git").then((success) {
- if (success) return "git";
-
- // Git is sometimes installed on Windows as `git.cmd`
- return _tryGitCommand("git.cmd").then((success) {
- if (success) return "git.cmd";
- return null;
- });
- }).then((command) {
- log.fine('Determined git command $command.');
- _gitCommandCache = command;
- return command;
- });
+ log.fine('Determined git command $command.');
+ return _commandCache;
}
+String _commandCache;
/// Checks whether [command] is the Git command for this computer.
-Future<bool> _tryGitCommand(String command) {
+bool _tryGitCommand(String command) {
// If "git --version" prints something familiar, git is working.
- return runProcess(command, ["--version"]).then((results) {
+ try {
+ var result = runProcessSync(command, ["--version"]);
var regexp = new RegExp("^git version");
- return results.stdout.length == 1 && regexp.hasMatch(results.stdout[0]);
- }).catchError((err, stackTrace) {
+ return result.stdout.length == 1 && regexp.hasMatch(result.stdout.single);
+ } on ProcessException catch (error, stackTrace) {
+ var chain = new Chain.forTrace(stackTrace);
// If the process failed, they probably don't have it.
- if (err is ProcessException) {
- log.io('Git command is not "$command": $err\n$stackTrace');
- return false;
- }
-
- throw err;
- });
+ log.message('Git command is not "$command": $error\n$chain');
+ return false;
+ }
}
« no previous file with comments | « sdk/lib/_internal/pub/lib/src/entrypoint.dart ('k') | sdk/lib/_internal/pub/lib/src/io.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698