blob: 9ab900f0a753b88747dbd8ea1835e98852dcd34f [file] [log] [blame]
Guido van Rossumd8336c21994-10-05 16:13:01 +00001THE FREEZE SCRIPT
2=================
3
4
5What is Freeze?
6---------------
7
8Freeze make it possible to ship arbitrary Python programs to people
9who don't have Python. The shipped file (called a "frozen" version of
10your Python program) is an executable, so this only works if your
11platform is compatible with that on the receiving end (this is usually
12a matter of having the same major operating system revision and CPU
13type).
14
15The shipped file contains a Python interpreter and large portions of
16the Python run-time. Some measures have been taken to avoid linking
17unneeded modules, but the resulting binary is usually not small.
18
19The Python source code of your program (and of the library modules
20written in Python that it uses) is not included in the binary --
21instead, the compiled byte-code (the instruction stream used
22internally by the interpreter) is incorporated. This gives some
23protection of your Python source code, though not much -- a
24disassembler for Python byte-code is available in the standard Python
25library. At least someone running "strings" on your binary won't see
26the source.
27
28
29How does Freeze know which modules to include?
30----------------------------------------------
31
32Freeze uses a pretty simple-minded algorithm to find the modules that
33your program uses: given a file containing Python source code, it
34scans for lines beginning with the word "import" or "from" (possibly
35preceded by whitespace) and then it knows where to find the module
36name(s) in those lines. It then recursively scans the source for
37those modules (if found, and not already processed) in the same way.
38
39Freeze will not see import statements hidden behind another statement,
40like this:
41
42 if some_test: import M # M not seen
43
44or like this:
45
46 import A; import B; import C # B and C not seen
47
48nor will it see import statements constructed using string
49operations and passed to 'exec', like this:
50
51 exec "import %s" % "M" # M not seen
52
53On the other hand, Freeze will think you are importing a module even
54if the import statement it sees will never be executed, like this:
55
56 if 0:
57 import M # M is seen
58
59One tricky issue: Freeze assumes that the Python interpreter and
60environment you're using to run Freeze is the same one that would be
61used to run your program, which should also be the same whose sources
62and installed files you will learn about in the next section. In
63particular, your PYTHONPATH setting should be the same as for running
64your program locally. (Tip: if the program doesn't run when you type
65"python hello.py" there's little chance of getting the frozen version
66to run.)
67
68
69How do I use Freeze?
70--------------------
71
72Ideally, you should be able to use it as follows:
73
74 python freeze.py hello.py
75
76where hello.py is your program and freeze.py is the main file of
77Freeze (in actuality, you'll probably specify an absolute pathname
78such as /ufs/guido/src/python/Demo/freeze/freeze.py).
79
80Unfortunately, this doesn't work. Well, it might, but somehow it's
81extremely unlikely that it'll work on the first try. (If it does,
82skip to the next section.) Most likely you'll get this error message:
83
84 needed directory /usr/local/lib/python/lib not found
85
86The reason is that Freeze require that some files that are normally
87kept inside the Python build tree are installed, and it searches for
88it in the default install location. (The default install prefix is
89/usr/local; these particular files are installed at lib/python/lib
90under the install prefix.)
91
92The particular set of files needed is installed only if you run "make
93libainstall" (note: "liba", not "lib") in the Python build tree (which
94is the tree where you build Python -- often, but not necessarily, this
95is also the Python source tree). If you have in fact done a "make
96libainstall" but used a different prefix, all you need to do is pass
97that same prefix to Freeze with the -p option:
98
99 python freeze.py -p your-prefix hello.py
100
101(If you haven't run "make libainstall" yet, go and do it now and don't
102come back until you've done it.)
103
104
105How do I configure Freeze?
106--------------------------
107
108It's a good idea to change the line marked with XXX in freeze.py (an
109assignment to variable PACK) to point to the absolute pathname of the
110directory where Freeze lives (Demo/freeze in the Python source tree.)
111This makes it possible to call Freeze from other directories.
112
113You can also edit the assignment to variable PREFIX -- this saves a
114lot of -p options.
115
116
117How do I use Freeze with extensions modules?
118--------------------------------------------
119
120XXX to be written. (In short: pass -e extensionbuilddir.)
121
122
123How do I use Freeze with dynamically loaded extension modules?
124--------------------------------------------------------------
125
126XXX to be written. (In short: pass -e modulebuilddir -- this even
127works if you built the modules in Python's own Modules directory.)
128
129
130
131What do I do next?
132------------------
133
134Freeze creates three files: frozen.c, config.c and Makefile. To
135produce the frozen version of your program, you can simply type
136"make". This should produce a binary file. If the filename argument
137to Freeze was "hello.py", the binary will be called "hello". On the
138other hand, if the argument was "hello", the binary will be called
139"hello.bin". If you passed any other filename, all bets are off. :-)
140In any case, the name of the file will be printed as the last message
141from Freeze.
142
143
144Help! I've tried everything but it doesn't work!
145-------------------------------------------------
146
147Freeze is currently beta software. You could email me a bug report.
148Please give as much context as possible -- "Freeze doesn't work" is
149not going to get much sympathy. You could fix the bug and send me a
150patch. You could learn Tcl.
151
152If you are thinking about debugging Freeze, start playing with a
153really simple program first (like "print 'hello world'"). If you
154can't get that to work there's something fundamentally wrong with your
155environment (or with your understanding of it). Gradually build it up
156to use more modules and extensions until you find where it stops
157working. After that, you're on your own -- happy hacking!
158
159
160--Guido van Rossum, CWI, Amsterdam <mailto:Guido.van.Rossum@cwi.nl>
161<http://www.cwi.nl/cwi/people/Guido.van.Rossum.html>