mirror of https://github.com/python/cpython.git
Initial release (+ 1 bugfix in setup.py)
This commit is contained in:
parent
90eea07d28
commit
f71f6133d0
|
@ -0,0 +1,49 @@
|
||||||
|
Python 1.4beta3 for Windows NT 3.5
|
||||||
|
==================================
|
||||||
|
|
||||||
|
The zip file pyth14b3.zip contains a preliminary binary release of
|
||||||
|
Python 1.4beta3 for Windows NT 3.5, with Tcl/Tk support. The
|
||||||
|
installation has not been tested on Windows '95 or Windows 3.1 with
|
||||||
|
Win32s. For general information on Python, see http://www.python.org/.
|
||||||
|
|
||||||
|
To install:
|
||||||
|
|
||||||
|
Unzip the archive in the root of a file system with enough space. It
|
||||||
|
will create a directory \Python1.4b3 containing subdirectories Bin and
|
||||||
|
Lib and files setup.bat and setup.py. (If you don't have a zip
|
||||||
|
program that supports long filenames, get the file winzip95.exe and
|
||||||
|
install it -- this is WinZip 6.1 for 32-bit Windows systems.)
|
||||||
|
|
||||||
|
Run the SETUP.BAT file found in directory just created. When it is
|
||||||
|
done, press Enter.
|
||||||
|
|
||||||
|
To use:
|
||||||
|
|
||||||
|
Python runs in a console (DOS) window. From the File Manager, run the
|
||||||
|
file python.exe found in the Bin subdirectory. You can also drag it
|
||||||
|
to a program group of your choice for easier access. Opening any file
|
||||||
|
ending in .py from the file manager should run it.
|
||||||
|
|
||||||
|
To use with Tkinter:
|
||||||
|
|
||||||
|
Get the file win41p1.exe from here or from ftp site ftp.sunlabs.com,
|
||||||
|
directory /pub/tcl/. This is a self-extracting archive containing the
|
||||||
|
Tcl/Tk distribution for Windows NT. Don't use an older version.
|
||||||
|
|
||||||
|
Using the control panel, set the TCL_LIBRARY and TK_LIBRARY
|
||||||
|
environment variables. E.g. if you installed Tcl/Tk in C:\TCL (the
|
||||||
|
default suggested by the installer), set TCL_LIBRARY to
|
||||||
|
"C:\TCL\lib\tcl7.5" and set TK_LIBRARY to "C:\TCL\lib\tk4.1".
|
||||||
|
|
||||||
|
Once Tcl/Tk is installed, you should be able to type the following
|
||||||
|
commands in Python:
|
||||||
|
|
||||||
|
>>> import Tkinter
|
||||||
|
>>> Tkinter._test()
|
||||||
|
|
||||||
|
This creates a simple test dialog box (you may have to move the Python
|
||||||
|
window a bit to see it). Click on OK to get the Python prompt back.
|
||||||
|
|
||||||
|
August 30, 1996
|
||||||
|
|
||||||
|
--Guido van Rossum (home page: http://www.python.org/~guido/)
|
|
@ -0,0 +1 @@
|
||||||
|
bin\python.exe -i .\setup.py
|
|
@ -0,0 +1,254 @@
|
||||||
|
"""Setup script for Windows NT 3.5 until we have a proper installer.
|
||||||
|
|
||||||
|
Run this with the current directory set to the Python ``root''.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import strop
|
||||||
|
|
||||||
|
del sys.path[1:]
|
||||||
|
|
||||||
|
try:
|
||||||
|
import nt
|
||||||
|
except ImportError:
|
||||||
|
print "This script should only be run on a Windows (NT or '95) system."
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
try:
|
||||||
|
sys.winver
|
||||||
|
print "This Python version appears to be", sys.winver
|
||||||
|
except NameError:
|
||||||
|
print "Huh? sys.winver is not defined!"
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
# Try to import a common module that *should* work.
|
||||||
|
print "Looking for Python root directory..."
|
||||||
|
while 1:
|
||||||
|
pwd = nt.getcwd()
|
||||||
|
##print "Could it be", `pwd`, "?"
|
||||||
|
try:
|
||||||
|
open("Lib\\os.py").close()
|
||||||
|
##print "It appears so."
|
||||||
|
break
|
||||||
|
except IOError:
|
||||||
|
##print "Hm, it doesn't appear to be. Try the parent directory."
|
||||||
|
try:
|
||||||
|
opwd = pwd
|
||||||
|
nt.chdir("..")
|
||||||
|
pwd = nt.getcwd()
|
||||||
|
if opwd == pwd:
|
||||||
|
##print "Seems like we're in the root already."
|
||||||
|
raise nt.error
|
||||||
|
except nt.error:
|
||||||
|
##print "Can't chdir to the parent -- we're stuck."
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
##print "Try again one level higher."
|
||||||
|
continue
|
||||||
|
print "Hey, would you like to help?"
|
||||||
|
print "Please enter the pathname of the Python root."
|
||||||
|
while 1:
|
||||||
|
try:
|
||||||
|
dirname = raw_input("Python root: ")
|
||||||
|
except EOFError:
|
||||||
|
print "OK, I give up."
|
||||||
|
sys.exit(1)
|
||||||
|
if not dirname:
|
||||||
|
continue
|
||||||
|
try:
|
||||||
|
nt.chdir(dirname)
|
||||||
|
except nt.error:
|
||||||
|
print "That directory doesn't seem to exist."
|
||||||
|
print "Please try again."
|
||||||
|
else:
|
||||||
|
break
|
||||||
|
pwd = nt.getcwd()
|
||||||
|
print "Python root directory is", pwd
|
||||||
|
sys.path[1:] = [".\\Lib", ".\\Lib\win", ".\\Bin", ".\\vc40"]
|
||||||
|
|
||||||
|
# Now we should be in a position to import win32api and win32con
|
||||||
|
|
||||||
|
try:
|
||||||
|
import win32api
|
||||||
|
except ImportError:
|
||||||
|
print "Blech. We *still* can't import win32api."
|
||||||
|
print "Giving up."
|
||||||
|
sys.exit(1)
|
||||||
|
try:
|
||||||
|
import win32con
|
||||||
|
except ImportError:
|
||||||
|
print "Beh. We have win32api but not win32con."
|
||||||
|
print "Making do with a dummy."
|
||||||
|
class win32con:
|
||||||
|
REG_NOTIFY_CHANGE_ATTRIBUTES = 0x00000002L
|
||||||
|
REG_NOTIFY_CHANGE_SECURITY = 0x00000008L
|
||||||
|
REG_RESOURCE_REQUIREMENTS_LIST = 10
|
||||||
|
REG_NONE = 0
|
||||||
|
REG_SZ = 1
|
||||||
|
REG_EXPAND_SZ = 2
|
||||||
|
REG_BINARY = 3
|
||||||
|
REG_DWORD = 4
|
||||||
|
REG_DWORD_LITTLE_ENDIAN = 4
|
||||||
|
REG_DWORD_BIG_ENDIAN = 5
|
||||||
|
REG_LINK = 6
|
||||||
|
REG_MULTI_SZ = 7
|
||||||
|
REG_RESOURCE_LIST = 8
|
||||||
|
REG_FULL_RESOURCE_DESCRIPTOR = 9
|
||||||
|
HKEY_CLASSES_ROOT = 0x80000000
|
||||||
|
HKEY_CURRENT_USER = 0x80000001
|
||||||
|
HKEY_LOCAL_MACHINE = 0x80000002
|
||||||
|
HKEY_USERS = 0x80000003
|
||||||
|
HKEY_PERFORMANCE_DATA = 0x80000004
|
||||||
|
HKEY_PERFORMANCE_TEXT = 0x80000050
|
||||||
|
HKEY_PERFORMANCE_NLSTEXT = 0x80000060
|
||||||
|
|
||||||
|
|
||||||
|
def listtree(handle, level=0):
|
||||||
|
i = 0
|
||||||
|
while 1:
|
||||||
|
try:
|
||||||
|
key = win32api.RegEnumKey(handle, i)
|
||||||
|
except win32api.error:
|
||||||
|
break
|
||||||
|
try:
|
||||||
|
value = win32api.RegQueryValue(handle, key)
|
||||||
|
except win32api.error, msg:
|
||||||
|
try:
|
||||||
|
msg = msg[2]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
value = "*** Error: %s" % str(msg)
|
||||||
|
print " "*level + "%s: %s" % (key, value)
|
||||||
|
subhandle = win32api.RegOpenKey(handle, key)
|
||||||
|
listtree(subhandle, level+1)
|
||||||
|
win32api.RegCloseKey(subhandle)
|
||||||
|
i = i+1
|
||||||
|
|
||||||
|
roothandle = win32con.HKEY_LOCAL_MACHINE
|
||||||
|
pythonkey = "Software\\Python"
|
||||||
|
try:
|
||||||
|
pythonhandle = win32api.RegOpenKey(roothandle, pythonkey)
|
||||||
|
except win32api.error:
|
||||||
|
pythonhandle = win32api.RegCreateKey(roothandle, pythonkey)
|
||||||
|
|
||||||
|
## listtree(pythonhandle)
|
||||||
|
## try:
|
||||||
|
## handle = win32api.RegOpenKey(pythonhandle, "JustTesting")
|
||||||
|
## except win32api.error, msg:
|
||||||
|
## try: msg = msg[2]
|
||||||
|
## except: pass
|
||||||
|
## ##print "Error opening, try creating instead:", msg
|
||||||
|
## handle = win32api.RegCreateKey(pythonhandle, "JustTesting")
|
||||||
|
## win32api.RegSetValue(handle, "test1", win32con.REG_SZ, "NO!")
|
||||||
|
## win32api.RegSetValue(handle, "test2", win32con.REG_SZ, "YES!")
|
||||||
|
## win32api.RegDeleteKey(handle, "test1")
|
||||||
|
## win32api.RegDeleteKey(handle, "test2")
|
||||||
|
## win32api.RegCloseKey(handle)
|
||||||
|
## win32api.RegDeleteKey(pythonhandle, "JustTesting")
|
||||||
|
## listtree(pythonhandle)
|
||||||
|
|
||||||
|
print "Setting PythonPath..."
|
||||||
|
corekey = "PythonCore\\%s" % sys.winver
|
||||||
|
try:
|
||||||
|
corehandle = win32api.RegOpenKey(pythonhandle, corekey)
|
||||||
|
except win32api.error, msg:
|
||||||
|
corehandle = win32api.RegCreateKey(pythonhandle, corekey)
|
||||||
|
path = []
|
||||||
|
pwd = nt.getcwd()
|
||||||
|
for i in ["Bin",
|
||||||
|
"Lib",
|
||||||
|
"Lib\\win",
|
||||||
|
"Lib\\tkinter",
|
||||||
|
"Lib\\test",
|
||||||
|
"Lib\\dos_8x3"]:
|
||||||
|
i = pwd + "\\" + i
|
||||||
|
path.append(i)
|
||||||
|
sys.path[1:] = path
|
||||||
|
pathvalue = strop.join(path, ";")
|
||||||
|
#print "Setting PythonPath to", pathvalue
|
||||||
|
win32api.RegSetValue(corehandle, "PythonPath", win32con.REG_SZ, pathvalue)
|
||||||
|
win32api.RegCloseKey(corehandle)
|
||||||
|
#listtree(pythonhandle)
|
||||||
|
win32api.RegCloseKey(pythonhandle)
|
||||||
|
|
||||||
|
print "Registering Python Interpreter as shell for *.py files..."
|
||||||
|
pwd = nt.getcwd()
|
||||||
|
interpreter = '"' + pwd + '\\Bin\\python.exe" -i %1'
|
||||||
|
print "Interpreter command is", interpreter
|
||||||
|
root = win32con.HKEY_CLASSES_ROOT
|
||||||
|
sz = win32con.REG_SZ
|
||||||
|
win32api.RegSetValue(root, ".py", sz, "Python.Script")
|
||||||
|
win32api.RegSetValue(root , "Python.Script", sz, "Python Script")
|
||||||
|
win32api.RegSetValue(root , "Python.Script\\Shell\\Open\\Command", sz,
|
||||||
|
interpreter)
|
||||||
|
|
||||||
|
import compileall
|
||||||
|
print "Compiling all library modules..."
|
||||||
|
compileall.main()
|
||||||
|
|
||||||
|
print "Installation complete."
|
||||||
|
|
||||||
|
envkeys = map(strop.upper, nt.environ.keys())
|
||||||
|
if 'PYTHONPATH' in envkeys:
|
||||||
|
print """
|
||||||
|
**********************************************************************
|
||||||
|
WARNING!
|
||||||
|
You have set the environment variable PYTHONPATH.
|
||||||
|
This will override the default Python module search path
|
||||||
|
and probably cause you to use an old or broken Python installation.
|
||||||
|
Go into your control panel *now* and delete PYTHONPATH!
|
||||||
|
**********************************************************************
|
||||||
|
"""
|
||||||
|
|
||||||
|
raw_input("Press Enter to exit: ")
|
||||||
|
sys.exit(0)
|
||||||
|
|
||||||
|
|
||||||
|
registry_doc = """Summary of the Win32 API Registry interfaces.
|
||||||
|
|
||||||
|
Concepts:
|
||||||
|
A _directory_ is a collection of key/value pairs.
|
||||||
|
You need a _handle_ for a directory to do anything with it.
|
||||||
|
There are some predefined keys, e.g. HKEY_LOCAL_MACHINE.
|
||||||
|
A _key_ is an ASCII string; NT file system conventions apply.
|
||||||
|
A _value_ has a type and some data; there are predefined types
|
||||||
|
(e.g. REG_SZ is a string, REG_DWORD is a 4-byte integer).
|
||||||
|
There's some fishiness in that in fact multiple, named values
|
||||||
|
can appear under each key, but this seems little used (in this
|
||||||
|
case, the value is best seen as a structured value).
|
||||||
|
A key can also refer to a _subdirectory_. In this case the
|
||||||
|
associated value is typically empty. To get a handle for a
|
||||||
|
subdirectory, use RegOpenKey(handle, key). The key can also
|
||||||
|
be a backslash-separated path, so you can go directly from one of
|
||||||
|
the predefined keys to the directory you are interested in.
|
||||||
|
|
||||||
|
Most common functions:
|
||||||
|
RegOpenKey(handle, keypath) -> handle
|
||||||
|
Get a handle for an existing subdirectory
|
||||||
|
RegCreateKey(handle, keypath) -> handle
|
||||||
|
Get a handle for a new subdirectory
|
||||||
|
RegCloseKey(handle)
|
||||||
|
Close a handle
|
||||||
|
RegGetValue(handle, subkey) -> string
|
||||||
|
Get the (unnamed) value stored as key in handle
|
||||||
|
RegSetValue(handle, subkey, type, value)
|
||||||
|
Set the (unnamed) value stored as key in handle, with given
|
||||||
|
type; type should be REG_SZ
|
||||||
|
RegSetValueEx(handle, name, reserved, type, value)
|
||||||
|
Set the value with given name to the given type and value;
|
||||||
|
currently reserved is ignored and type should be REG_SZ
|
||||||
|
|
||||||
|
Functions to list directory contents (start counting at 0, fail if done):
|
||||||
|
RegEnumKey(handle, i)
|
||||||
|
Return the i'th subkey
|
||||||
|
RegEnumValue(handle, i)
|
||||||
|
Return the i'th name and value
|
||||||
|
|
||||||
|
Lesser used functions:
|
||||||
|
RegFlushKey(handle)
|
||||||
|
Flush the changes to the handle to disk (like Unix sync())
|
||||||
|
RegSaveKey(handle, filename, reserved)
|
||||||
|
Save the contents to a disk file (broken?!)
|
||||||
|
RegLoadKey(handle, keypath, filename)
|
||||||
|
Load the contents from a disk file (lots of restrictions!)
|
||||||
|
"""
|
Loading…
Reference in New Issue