blob: 65e56ded00c4a23e8c24d8a135d7bc58c4df4c89 [file] [log] [blame]
#!/usr/bin/env python
#
# Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
# for details. All rights reserved. Use of this source code is governed by a
# BSD-style license that can be found in the LICENSE file.
"""Script to create snapshot bin file."""
import getopt
import optparse
import os
from os.path import basename, join
import sys
import utils
HOST_OS = utils.GuessOS()
HOST_CPUS = utils.GuessCpus()
DEBUG = False
VERBOSE = False
def BuildOptions():
result = optparse.OptionParser()
result.add_option("--executable",
action="store", type="string",
help="path to snapshot generator executable")
result.add_option("--vm_output_bin",
action="store", type="string",
help="output file name into which vm isolate snapshot in binary form " +
"is generated")
result.add_option("--output_bin",
action="store", type="string",
help="output file name into which isolate snapshot in binary form " +
"is generated")
result.add_option("--instructions_bin",
action="store", type="string",
help="output file name into which instructions snapshot in assembly " +
"form is generated")
result.add_option("--embedder_entry_points_manifest",
action="store", type="string",
help="input manifest with the vm entry points in a precompiled snapshot")
result.add_option("--script",
action="store", type="string",
help="Dart script for which snapshot is to be generated")
result.add_option("--package_root",
action="store", type="string",
help="path used to resolve package: imports.")
result.add_option("--packages",
action="store", type="string",
help="package config file used to reasolve package: imports.")
result.add_option("--url_mapping",
default=[],
action="append",
help=("mapping from url to file name, used when generating snapshots " +
"E.g.: --url_mapping=fileUri,/path/to/file.dart"))
result.add_option("-v", "--verbose",
help='Verbose output.',
default=False, action="store_true")
result.add_option("--target_os",
action="store", type="string",
help="Which os to run the executable on. Current choice is android")
result.add_option("--abi",
action="store", type="string",
help="Desired ABI for android target OS. armeabi-v7a or x86")
result.add_option("--timestamp_file",
action="store", type="string",
help="Path to timestamp file that will be written",
default="")
return result
def ProcessOptions(options):
if not options.executable:
sys.stderr.write('--executable not specified\n')
return False
if not options.vm_output_bin:
sys.stderr.write('--vm_output_bin not specified\n')
return False
if not options.output_bin:
sys.stderr.write('--output_bin not specified\n')
return False
if options.abi and not options.target_os == 'android':
sys.stderr.write('--abi requires --target_os android\n')
return False
return True
def CreateTimestampFile(options):
if options.timestamp_file != '':
dir_name = os.path.dirname(options.timestamp_file)
if not os.path.exists(dir_name):
os.mkdir(dir_name)
open(options.timestamp_file, 'w').close()
def Main():
# Parse options.
parser = BuildOptions()
(options, args) = parser.parse_args()
if not ProcessOptions(options):
parser.print_help()
return 1
# If there are additional arguments, report error and exit.
if args:
parser.print_help()
return 1
# Setup arguments to the snapshot generator binary.
script_args = ["--ignore_unrecognized_flags",
"--error_on_bad_type",
"--error_on_bad_override"]
# Pass along the package_root if there is one.
if options.package_root:
script_args.append(''.join([ "--package_root=", options.package_root]))
# Pass along the packages if there is one.
if options.packages:
script_args.append(''.join([ "--packages=", options.packages]))
# First setup the vm isolate and regular isolate snapshot output filename.
script_args.append(''.join([ "--vm_isolate_snapshot=",
options.vm_output_bin ]))
script_args.append(''.join([ "--isolate_snapshot=", options.output_bin ]))
# Setup the instuctions snapshot output filename
if options.instructions_bin:
script_args.append(''.join([ "--instructions_snapshot=",
options.instructions_bin ]))
# Specify the embedder entry points snapshot
if options.embedder_entry_points_manifest:
script_args.append(''.join([ "--embedder_entry_points_manifest=",
options.embedder_entry_points_manifest ]))
# Next setup all url mapping options specified.
for url_arg in options.url_mapping:
url_mapping_argument = ''.join(["--url_mapping=", url_arg ])
script_args.append(url_mapping_argument)
# Finally append the script name if one is specified.
if options.script:
script_args.append(options.script)
# Construct command line to execute the snapshot generator binary and invoke.
command = [ options.executable ] + script_args
try:
utils.RunCommand(command, outStream=sys.stderr, errStream=sys.stderr,
verbose=options.verbose, printErrorInfo=True)
except Exception as e:
return -1
# Success, update timestamp file.
CreateTimestampFile(options)
return 0
if __name__ == '__main__':
sys.exit(Main())