1994-10-03 13:33:08 -03:00
|
|
|
import marshal
|
1998-08-25 11:06:55 -03:00
|
|
|
import bkfile
|
1994-10-03 13:33:08 -03:00
|
|
|
|
|
|
|
|
|
|
|
# Write a file containing frozen code for the modules in the dictionary.
|
|
|
|
|
|
|
|
header = """
|
1996-06-17 14:48:30 -03:00
|
|
|
#include "Python.h"
|
|
|
|
|
|
|
|
static struct _frozen _PyImport_FrozenModules[] = {
|
1994-10-03 13:33:08 -03:00
|
|
|
"""
|
|
|
|
trailer = """\
|
1998-03-05 00:56:37 -04:00
|
|
|
{0, 0, 0} /* sentinel */
|
1994-10-03 13:33:08 -03:00
|
|
|
};
|
1998-03-20 13:37:24 -04:00
|
|
|
"""
|
1996-06-17 14:48:30 -03:00
|
|
|
|
1998-04-23 11:39:05 -03:00
|
|
|
# if __debug__ == 0 (i.e. -O option given), set Py_OptimizeFlag in frozen app.
|
1998-03-20 13:37:24 -04:00
|
|
|
default_entry_point = """
|
1997-07-19 18:58:30 -03:00
|
|
|
int
|
2002-04-04 12:15:41 -04:00
|
|
|
main(int argc, char **argv)
|
1997-07-19 18:58:30 -03:00
|
|
|
{
|
2004-07-18 03:16:08 -03:00
|
|
|
extern int Py_FrozenMain(int, char **);
|
1998-04-23 11:39:05 -03:00
|
|
|
""" + ((not __debug__ and """
|
|
|
|
Py_OptimizeFlag++;
|
|
|
|
""") or "") + """
|
1998-03-05 00:56:37 -04:00
|
|
|
PyImport_FrozenModules = _PyImport_FrozenModules;
|
|
|
|
return Py_FrozenMain(argc, argv);
|
1997-07-19 18:58:30 -03:00
|
|
|
}
|
|
|
|
|
1994-10-03 13:33:08 -03:00
|
|
|
"""
|
|
|
|
|
2001-10-18 16:15:32 -03:00
|
|
|
def makefreeze(base, dict, debug=0, entry_point=None, fail_import=()):
|
1998-03-20 13:37:24 -04:00
|
|
|
if entry_point is None: entry_point = default_entry_point
|
1998-03-05 00:56:37 -04:00
|
|
|
done = []
|
1998-08-25 11:06:55 -03:00
|
|
|
files = []
|
2007-06-11 21:28:30 -03:00
|
|
|
mods = sorted(dict.keys())
|
1998-03-05 00:56:37 -04:00
|
|
|
for mod in mods:
|
|
|
|
m = dict[mod]
|
2002-09-11 17:36:02 -03:00
|
|
|
mangled = "__".join(mod.split("."))
|
1998-03-05 00:56:37 -04:00
|
|
|
if m.__code__:
|
1998-08-25 11:06:55 -03:00
|
|
|
file = 'M_' + mangled + '.c'
|
2015-03-20 04:21:59 -03:00
|
|
|
with bkfile.open(base + file, 'w') as outfp:
|
|
|
|
files.append(file)
|
|
|
|
if debug:
|
|
|
|
print("freezing", mod, "...")
|
|
|
|
str = marshal.dumps(m.__code__)
|
|
|
|
size = len(str)
|
|
|
|
if m.__path__:
|
|
|
|
# Indicate package by negative size
|
|
|
|
size = -size
|
|
|
|
done.append((mod, mangled, size))
|
|
|
|
writecode(outfp, mangled, str)
|
1998-03-05 00:56:37 -04:00
|
|
|
if debug:
|
2007-02-09 19:27:01 -04:00
|
|
|
print("generating table of frozen modules")
|
2015-03-20 04:21:59 -03:00
|
|
|
with bkfile.open(base + 'frozen.c', 'w') as outfp:
|
|
|
|
for mod, mangled, size in done:
|
|
|
|
outfp.write('extern unsigned char M_%s[];\n' % mangled)
|
|
|
|
outfp.write(header)
|
|
|
|
for mod, mangled, size in done:
|
|
|
|
outfp.write('\t{"%s", M_%s, %d},\n' % (mod, mangled, size))
|
|
|
|
outfp.write('\n')
|
|
|
|
# The following modules have a NULL code pointer, indicating
|
|
|
|
# that the frozen program should not search for them on the host
|
|
|
|
# system. Importing them will *always* raise an ImportError.
|
|
|
|
# The zero value size is never used.
|
|
|
|
for mod in fail_import:
|
|
|
|
outfp.write('\t{"%s", NULL, 0},\n' % (mod,))
|
|
|
|
outfp.write(trailer)
|
|
|
|
outfp.write(entry_point)
|
1998-08-25 11:06:55 -03:00
|
|
|
return files
|
1998-03-20 13:37:24 -04:00
|
|
|
|
1994-10-03 13:33:08 -03:00
|
|
|
|
|
|
|
|
|
|
|
# Write a C initializer for a module containing the frozen python code.
|
|
|
|
# The array is called M_<mod>.
|
|
|
|
|
|
|
|
def writecode(outfp, mod, str):
|
1998-08-25 11:06:55 -03:00
|
|
|
outfp.write('unsigned char M_%s[] = {' % mod)
|
1998-03-05 00:56:37 -04:00
|
|
|
for i in range(0, len(str), 16):
|
|
|
|
outfp.write('\n\t')
|
2007-06-11 21:28:30 -03:00
|
|
|
for c in bytes(str[i:i+16]):
|
|
|
|
outfp.write('%d,' % c)
|
1998-03-05 00:56:37 -04:00
|
|
|
outfp.write('\n};\n')
|
1998-08-25 11:06:55 -03:00
|
|
|
|
|
|
|
## def writecode(outfp, mod, str):
|
|
|
|
## outfp.write('unsigned char M_%s[%d] = "%s";\n' % (mod, len(str),
|
2004-02-12 13:35:32 -04:00
|
|
|
## '\\"'.join(map(lambda s: repr(s)[1:-1], str.split('"')))))
|