Chromium Code Reviews| Index: utils/compiler/create_snapshot.dart |
| =================================================================== |
| --- utils/compiler/create_snapshot.dart (revision 21414) |
| +++ utils/compiler/create_snapshot.dart (working copy) |
| @@ -18,11 +18,13 @@ |
| Future<String> getSnapshotGenerationFile(var options, var args, var rootPath) { |
| var dart2js = rootPath.append(args["dart2js_main"]); |
| + var dartdoc = rootPath.append(args["dartdoc_main"]); |
| return getVersion(options, rootPath).then((version) { |
| var snapshotGenerationText = |
| """ |
| import '${dart2js}' as dart2jsMain; |
| +import '${dartdoc}' as dartdocMain; |
| import 'dart:io'; |
| void main() { |
| @@ -32,6 +34,8 @@ |
| if (tool == "dart2js") { |
| dart2jsMain.BUILD_ID = "$version"; |
| dart2jsMain.mainWithErrorHandler(options); |
| + } else if (tool == "dartdoc") { |
| + dartdocMain.mainWithOptions(options); |
|
Andrei Mouravski
2013/04/16 20:19:09
Why not call this as a process?
ricow1
2013/04/17 06:58:49
I guess I was not clear about this in the cl since
|
| } |
| } |
| @@ -47,9 +51,10 @@ |
| writer.close(); |
| } |
| -Future createSnapshot(var options, var dart_file) { |
| +Future createSnapshot(var options, var dart_file, var packageRoot) { |
| return Process.run(options.executable, |
| - ["--generate-script-snapshot=$dart_file.snapshot", |
| + ["--package-root=$packageRoot", |
| + "--generate-script-snapshot=$dart_file.snapshot", |
| dart_file]) |
| .then((result) { |
| if (result.exitCode != 0) { |
| @@ -65,7 +70,8 @@ |
| */ |
| void main() { |
| Options options = new Options(); |
| - var validArguments = ["--output_dir", "--dart2js_main"]; |
| + var validArguments = ["--output_dir", "--dart2js_main", "--dartdoc_main", |
| + "--package_root"]; |
| var args = {}; |
| for (var argument in options.arguments) { |
| var argumentSplit = argument.split("="); |
| @@ -76,7 +82,9 @@ |
| args[argumentSplit[0].substring(2)] = argumentSplit[1]; |
| } |
| if (!args.containsKey("dart2js_main")) throw "Please specify dart2js_main"; |
| + if (!args.containsKey("dartdoc_main")) throw "Please specify dartdoc_main"; |
| if (!args.containsKey("output_dir")) throw "Please specify output_dir"; |
| + if (!args.containsKey("package_root")) throw "Please specify package_root"; |
| var scriptFile = new File(options.script); |
| var path = new Path(scriptFile.directorySync().path); |
| @@ -85,6 +93,6 @@ |
| getSnapshotGenerationFile(options, args, rootPath).then((result) { |
| var wrapper = "${args['output_dir']}/utils_wrapper.dart"; |
| writeSnapshotFile(wrapper, result); |
| - createSnapshot(options, wrapper); |
| + createSnapshot(options, wrapper, args["package_root"]); |
| }); |
| } |