Add support for using a shell file except than the built-in one

This adds a --shell-file compiler option which allows users to use a
custom shell file.
This commit is contained in:
Ehsan Akhgari 2012-01-27 16:32:46 -05:00
Родитель 01e21e5412
Коммит 86e5310006
1 изменённых файлов: 14 добавлений и 1 удалений

15
emcc
Просмотреть файл

@ -164,6 +164,13 @@ Options that are modified or new in %s include:
will be run). Note that this by itself
will not minify the code (closure does
that)
--shell-path <path> The path name to a skeleton HTML file used
when generating HTML output. The shell file
used needs to have this token inside it:
{{{ SCRIPT_CODE }}}
Note that this argument is ignored if a
target other than HTML is specified using
the -o option.
The target file, if specified (-o <target>), defines what will
be generated:
@ -282,6 +289,7 @@ try:
closure = None
js_transform = None
compress_whitespace = None
shell_path = shared.path_from_root('src', 'shell.html')
def check_bad_eq(arg):
assert '=' not in arg, 'Invalid parameter (do not use "=" with "--" options)'
@ -321,6 +329,11 @@ try:
f.close()
newargs[i] = ''
newargs[i+1] = ''
elif newargs[i].startswith('--shell-file'):
check_bad_eq(newargs[i])
shell_path = newargs[i+1]
newargs[i] = ''
newargs[i+1] = ''
newargs = [ arg for arg in newargs if arg is not '' ]
if llvm_opt_level is None: llvm_opt_level = 1 if opt_level >= 1 else 0
@ -626,7 +639,7 @@ try:
# If we were asked to also generate HTML, do that
if final_suffix == 'html':
if DEBUG: print >> sys.stderr, 'emcc: generating HTML'
shell = open(shared.path_from_root('src', 'shell.html')).read()
shell = open(shell_path).read()
html = open(target, 'w')
html.write(shell.replace('{{{ SCRIPT_CODE }}}', open(final).read()))
html.close()