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

Side by Side Diff: utils/pub/git.dart

Issue 14070010: Refactor Future constructors. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Added co19 issue number. Created 7 years, 8 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « utils/pub/error_group.dart ('k') | utils/pub/git_source.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 /// Helper functionality for invoking Git. 5 /// Helper functionality for invoking Git.
6 library git; 6 library git;
7 7
8 import 'dart:async'; 8 import 'dart:async';
9 import 'io.dart'; 9 import 'io.dart';
10 import 'log.dart' as log; 10 import 'log.dart' as log;
11 import 'utils.dart'; 11 import 'utils.dart';
12 12
13 /// Tests whether or not the git command-line app is available for use. 13 /// Tests whether or not the git command-line app is available for use.
14 Future<bool> get isInstalled { 14 Future<bool> get isInstalled {
15 if (_isGitInstalledCache != null) { 15 if (_isGitInstalledCache != null) {
16 return new Future.immediate(_isGitInstalledCache); 16 return new Future.value(_isGitInstalledCache);
17 } 17 }
18 18
19 return _gitCommand.then((git) => git != null); 19 return _gitCommand.then((git) => git != null);
20 } 20 }
21 21
22 /// Run a git process with [args] from [workingDir]. Returns the stdout as a 22 /// Run a git process with [args] from [workingDir]. Returns the stdout as a
23 /// list of strings if it succeeded. Completes to an exception if it failed. 23 /// list of strings if it succeeded. Completes to an exception if it failed.
24 Future<List<String>> run(List<String> args, 24 Future<List<String>> run(List<String> args,
25 {String workingDir, Map<String, String> environment}) { 25 {String workingDir, Map<String, String> environment}) {
26 return _gitCommand.then((git) { 26 return _gitCommand.then((git) {
(...skipping 10 matching lines...) Expand all
37 37
38 bool _isGitInstalledCache; 38 bool _isGitInstalledCache;
39 39
40 /// The cached Git command. 40 /// The cached Git command.
41 String _gitCommandCache; 41 String _gitCommandCache;
42 42
43 /// Returns the name of the git command-line app, or null if Git could not be 43 /// Returns the name of the git command-line app, or null if Git could not be
44 /// found on the user's PATH. 44 /// found on the user's PATH.
45 Future<String> get _gitCommand { 45 Future<String> get _gitCommand {
46 if (_gitCommandCache != null) { 46 if (_gitCommandCache != null) {
47 return new Future.immediate(_gitCommandCache); 47 return new Future.value(_gitCommandCache);
48 } 48 }
49 49
50 return _tryGitCommand("git").then((success) { 50 return _tryGitCommand("git").then((success) {
51 if (success) return "git"; 51 if (success) return "git";
52 52
53 // Git is sometimes installed on Windows as `git.cmd` 53 // Git is sometimes installed on Windows as `git.cmd`
54 return _tryGitCommand("git.cmd").then((success) { 54 return _tryGitCommand("git.cmd").then((success) {
55 if (success) return "git.cmd"; 55 if (success) return "git.cmd";
56 return null; 56 return null;
57 }); 57 });
58 }).then((command) { 58 }).then((command) {
59 log.fine('Determined git command $command.'); 59 log.fine('Determined git command $command.');
60 _gitCommandCache = command; 60 _gitCommandCache = command;
61 return command; 61 return command;
62 }); 62 });
63 } 63 }
64 64
65 /// Checks whether [command] is the Git command for this computer. 65 /// Checks whether [command] is the Git command for this computer.
66 Future<bool> _tryGitCommand(String command) { 66 Future<bool> _tryGitCommand(String command) {
67 // If "git --version" prints something familiar, git is working. 67 // If "git --version" prints something familiar, git is working.
68 return runProcess(command, ["--version"]).then((results) { 68 return runProcess(command, ["--version"]).then((results) {
69 var regexp = new RegExp("^git version"); 69 var regexp = new RegExp("^git version");
70 return results.stdout.length == 1 && regexp.hasMatch(results.stdout[0]); 70 return results.stdout.length == 1 && regexp.hasMatch(results.stdout[0]);
71 }).catchError((err) { 71 }).catchError((err) {
72 // If the process failed, they probably don't have it. 72 // If the process failed, they probably don't have it.
73 return false; 73 return false;
74 }); 74 });
75 } 75 }
OLDNEW
« no previous file with comments | « utils/pub/error_group.dart ('k') | utils/pub/git_source.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698