Commit a7016062 authored by Ian Hickson's avatar Ian Hickson

Improve flutter create help text.

parent 366385b3
...@@ -20,17 +20,12 @@ class CreateCommand extends Command { ...@@ -20,17 +20,12 @@ class CreateCommand extends Command {
final String name = 'create'; final String name = 'create';
@override @override
final String description = 'Create a new Flutter project.'; final String description = 'Create a new Flutter project.\nIf run on a project that already exists, this will repair the project, recreating any files that are missing.';
@override @override
final List<String> aliases = <String>['init']; final List<String> aliases = <String>['init'];
CreateCommand() { CreateCommand() {
argParser.addOption('out',
abbr: 'o',
hide: true,
help: 'The output directory.'
);
argParser.addFlag('pub', argParser.addFlag('pub',
defaultsTo: true, defaultsTo: true,
help: 'Whether to run "pub get" after the project has been created.' help: 'Whether to run "pub get" after the project has been created.'
...@@ -41,6 +36,11 @@ class CreateCommand extends Command { ...@@ -41,6 +36,11 @@ class CreateCommand extends Command {
defaultsTo: false, defaultsTo: false,
help: 'Also add a flutter_driver dependency and generate a sample \'flutter drive\' test.' help: 'Also add a flutter_driver dependency and generate a sample \'flutter drive\' test.'
); );
argParser.addOption(
'description',
defaultsTo: 'A new flutter project.',
help: 'The description to use for your new flutter project. This string ends up in the pubspec.yaml file.'
);
} }
@override @override
...@@ -48,12 +48,18 @@ class CreateCommand extends Command { ...@@ -48,12 +48,18 @@ class CreateCommand extends Command {
@override @override
Future<int> run() async { Future<int> run() async {
if (!argResults.wasParsed('out') && argResults.rest.isEmpty) { if (argResults.rest.isEmpty) {
printStatus('No option specified for the output directory.'); printStatus('No option specified for the output directory.');
printStatus(usage); printStatus(usage);
return 2; return 2;
} }
if (argResults.rest.length > 1) {
printStatus('Multiple output directories specified.');
printStatus('To create (or repair) a flutter application directory, run "flutter create dirname" where "dirname" is the application directory.');
return 2;
}
if (ArtifactStore.flutterRoot == null) { if (ArtifactStore.flutterRoot == null) {
printError('Neither the --flutter-root command line flag nor the FLUTTER_ROOT environment'); printError('Neither the --flutter-root command line flag nor the FLUTTER_ROOT environment');
printError('variable was specified. Unable to find package:flutter.'); printError('variable was specified. Unable to find package:flutter.');
...@@ -75,14 +81,7 @@ class CreateCommand extends Command { ...@@ -75,14 +81,7 @@ class CreateCommand extends Command {
return 2; return 2;
} }
Directory projectDir; Directory projectDir = new Directory(argResults.rest.first);
if (argResults.wasParsed('out')) {
projectDir = new Directory(argResults['out']);
} else {
projectDir = new Directory(argResults.rest.first);
}
String dirPath = path.normalize(projectDir.absolute.path); String dirPath = path.normalize(projectDir.absolute.path);
String projectName = _normalizeProjectName(path.basename(dirPath)); String projectName = _normalizeProjectName(path.basename(dirPath));
...@@ -91,8 +90,13 @@ class CreateCommand extends Command { ...@@ -91,8 +90,13 @@ class CreateCommand extends Command {
return 1; return 1;
} }
_renderTemplates(projectName, dirPath, flutterPackagesDirectory, _renderTemplates(
renderDriverTest: argResults['with-driver-test']); projectName,
argResults['description'],
dirPath,
flutterPackagesDirectory,
renderDriverTest: argResults['with-driver-test']
);
printStatus(''); printStatus('');
...@@ -132,7 +136,7 @@ All done! In order to run your application, type: ...@@ -132,7 +136,7 @@ All done! In order to run your application, type:
return 0; return 0;
} }
void _renderTemplates(String projectName, String dirPath, void _renderTemplates(String projectName, String projectDescription, String dirPath,
String flutterPackagesDirectory, { bool renderDriverTest: false }) { String flutterPackagesDirectory, { bool renderDriverTest: false }) {
new Directory(dirPath).createSync(recursive: true); new Directory(dirPath).createSync(recursive: true);
...@@ -145,7 +149,7 @@ All done! In order to run your application, type: ...@@ -145,7 +149,7 @@ All done! In order to run your application, type:
'projectName': projectName, 'projectName': projectName,
'androidIdentifier': _createAndroidIdentifier(projectName), 'androidIdentifier': _createAndroidIdentifier(projectName),
'iosIdentifier': _createUTIIdentifier(projectName), 'iosIdentifier': _createUTIIdentifier(projectName),
'description': description, 'description': projectDescription,
'flutterPackagesDirectory': flutterPackagesDirectory, 'flutterPackagesDirectory': flutterPackagesDirectory,
'androidMinApiLevel': android.minApiLevel 'androidMinApiLevel': android.minApiLevel
}; };
......
...@@ -10,7 +10,7 @@ environment: ...@@ -10,7 +10,7 @@ environment:
dependencies: dependencies:
analyzer: '>=0.26.1+17' # see note below analyzer: '>=0.26.1+17' # see note below
archive: ^1.0.20 archive: ^1.0.20
args: ^0.13.2+1 args: ^0.13.4
crypto: ^0.9.1 crypto: ^0.9.1
den_api: ^0.1.0 den_api: ^0.1.0
file: ^0.1.0 file: ^0.1.0
......
...@@ -31,7 +31,7 @@ void main() { ...@@ -31,7 +31,7 @@ void main() {
CreateCommand command = new CreateCommand(); CreateCommand command = new CreateCommand();
CommandRunner runner = new CommandRunner('test_flutter', '') CommandRunner runner = new CommandRunner('test_flutter', '')
..addCommand(command); ..addCommand(command);
await runner.run(['create', '--out', temp.path]) await runner.run(['create', temp.path])
.then((int code) => expect(code, equals(0))); .then((int code) => expect(code, equals(0)));
String mainPath = path.join(temp.path, 'lib', 'main.dart'); String mainPath = path.join(temp.path, 'lib', 'main.dart');
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment