| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 1 | """Append module search paths for third-party packages to sys.path. | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 2 |  | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 3 | **************************************************************** | 
 | 4 | * This module is automatically imported during initialization. * | 
 | 5 | **************************************************************** | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 6 |  | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 7 | In earlier versions of Python (up to 1.5a3), scripts or modules that | 
 | 8 | needed to use site-specific modules would place ``import site'' | 
 | 9 | somewhere near the top of their code.  Because of the automatic | 
 | 10 | import, this is no longer necessary (but code that does it still | 
 | 11 | works). | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 12 |  | 
| Guido van Rossum | 0d8fcb2 | 1998-01-13 18:32:40 +0000 | [diff] [blame] | 13 | This will append site-specific paths to to the module search path.  On | 
 | 14 | Unix, it starts with sys.prefix and sys.exec_prefix (if different) and | 
 | 15 | appends lib/python<version>/site-packages as well as lib/site-python. | 
 | 16 | On other platforms (mainly Mac and Windows), it uses just sys.prefix | 
| Barry Warsaw | 62d2488 | 2001-03-23 17:53:49 +0000 | [diff] [blame] | 17 | \(and sys.exec_prefix, if different, but this is unlikely).  The | 
| Guido van Rossum | 62b297b | 1997-09-08 02:14:09 +0000 | [diff] [blame] | 18 | resulting directories, if they exist, are appended to sys.path, and | 
 | 19 | also inspected for path configuration files. | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 20 |  | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 21 | A path configuration file is a file whose name has the form | 
 | 22 | <package>.pth; its contents are additional directories (one per line) | 
 | 23 | to be added to sys.path.  Non-existing directories (or | 
 | 24 | non-directories) are never added to sys.path; no directory is added to | 
 | 25 | sys.path more than once.  Blank lines and lines beginning with | 
| Martin v. Löwis | bb0a4b7 | 2001-01-11 13:02:43 +0000 | [diff] [blame] | 26 | \code{#} are skipped. Lines starting with \code{import} are executed. | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 27 |  | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 28 | For example, suppose sys.prefix and sys.exec_prefix are set to | 
| Guido van Rossum | e720176 | 1998-11-25 15:57:47 +0000 | [diff] [blame] | 29 | /usr/local and there is a directory /usr/local/lib/python1.5/site-packages | 
| Guido van Rossum | 62b297b | 1997-09-08 02:14:09 +0000 | [diff] [blame] | 30 | with three subdirectories, foo, bar and spam, and two path | 
 | 31 | configuration files, foo.pth and bar.pth.  Assume foo.pth contains the | 
 | 32 | following: | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 33 |  | 
 | 34 |   # foo package configuration | 
 | 35 |   foo | 
 | 36 |   bar | 
 | 37 |   bletch | 
 | 38 |  | 
 | 39 | and bar.pth contains: | 
 | 40 |  | 
 | 41 |   # bar package configuration | 
 | 42 |   bar | 
 | 43 |  | 
 | 44 | Then the following directories are added to sys.path, in this order: | 
 | 45 |  | 
| Guido van Rossum | 62b297b | 1997-09-08 02:14:09 +0000 | [diff] [blame] | 46 |   /usr/local/lib/python1.5/site-packages/bar | 
 | 47 |   /usr/local/lib/python1.5/site-packages/foo | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 48 |  | 
 | 49 | Note that bletch is omitted because it doesn't exist; bar precedes foo | 
 | 50 | because bar.pth comes alphabetically before foo.pth; and spam is | 
 | 51 | omitted because it is not mentioned in either path configuration file. | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 52 |  | 
 | 53 | After these path manipulations, an attempt is made to import a module | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 54 | named sitecustomize, which can perform arbitrary additional | 
 | 55 | site-specific customizations.  If this import fails with an | 
 | 56 | ImportError exception, it is silently ignored. | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 57 |  | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 58 | """ | 
 | 59 |  | 
 | 60 | import sys, os | 
 | 61 |  | 
| Guido van Rossum | d74fb6b | 2001-03-02 06:43:49 +0000 | [diff] [blame] | 62 | if os.sep==".": | 
 | 63 |     endsep = "/" | 
 | 64 | else: | 
 | 65 |     endsep = "." | 
 | 66 |  | 
 | 67 |  | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 68 | def makepath(*paths): | 
 | 69 |     dir = os.path.join(*paths) | 
 | 70 |     return os.path.normcase(os.path.abspath(dir)) | 
 | 71 |  | 
 | 72 | L = sys.modules.values() | 
 | 73 | for m in L: | 
| Barry Warsaw | 62d2488 | 2001-03-23 17:53:49 +0000 | [diff] [blame] | 74 |     if hasattr(m, "__file__") and m.__file__: | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 75 |         m.__file__ = makepath(m.__file__) | 
 | 76 | del m, L | 
 | 77 |  | 
 | 78 | # This ensures that the initial path provided by the interpreter contains | 
 | 79 | # only absolute pathnames, even if we're running from the build directory. | 
 | 80 | L = [] | 
 | 81 | for dir in sys.path: | 
 | 82 |     dir = makepath(dir) | 
 | 83 |     if dir not in L: | 
 | 84 |         L.append(dir) | 
 | 85 | sys.path[:] = L | 
 | 86 | del dir, L | 
 | 87 |  | 
| Guido van Rossum | 48eb9cd | 2001-01-19 21:54:59 +0000 | [diff] [blame] | 88 | # Append ./build/lib.<platform> in case we're running in the build dir | 
 | 89 | # (especially for Guido :-) | 
 | 90 | if os.name == "posix" and os.path.basename(sys.path[-1]) == "Modules": | 
 | 91 |     from distutils.util import get_platform | 
 | 92 |     s = "build/lib.%s-%.3s" % (get_platform(), sys.version) | 
 | 93 |     s = os.path.join(os.path.dirname(sys.path[-1]), s) | 
 | 94 |     sys.path.append(s) | 
 | 95 |     del get_platform, s | 
 | 96 |  | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 97 | def addsitedir(sitedir): | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 98 |     sitedir = makepath(sitedir) | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 99 |     if sitedir not in sys.path: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 100 |         sys.path.append(sitedir)        # Add path component | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 101 |     try: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 102 |         names = os.listdir(sitedir) | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 103 |     except os.error: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 104 |         return | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 105 |     names = map(os.path.normcase, names) | 
 | 106 |     names.sort() | 
 | 107 |     for name in names: | 
| Guido van Rossum | d74fb6b | 2001-03-02 06:43:49 +0000 | [diff] [blame] | 108 |         if name[-4:] == endsep + "pth": | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 109 |             addpackage(sitedir, name) | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 110 |  | 
 | 111 | def addpackage(sitedir, name): | 
 | 112 |     fullname = os.path.join(sitedir, name) | 
 | 113 |     try: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 114 |         f = open(fullname) | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 115 |     except IOError: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 116 |         return | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 117 |     while 1: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 118 |         dir = f.readline() | 
 | 119 |         if not dir: | 
 | 120 |             break | 
 | 121 |         if dir[0] == '#': | 
 | 122 |             continue | 
| Martin v. Löwis | bb0a4b7 | 2001-01-11 13:02:43 +0000 | [diff] [blame] | 123 |         if dir.startswith("import"): | 
 | 124 |             exec dir | 
 | 125 |             continue | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 126 |         if dir[-1] == '\n': | 
 | 127 |             dir = dir[:-1] | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 128 |         dir = makepath(sitedir, dir) | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 129 |         if dir not in sys.path and os.path.exists(dir): | 
 | 130 |             sys.path.append(dir) | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 131 |  | 
 | 132 | prefixes = [sys.prefix] | 
 | 133 | if sys.exec_prefix != sys.prefix: | 
 | 134 |     prefixes.append(sys.exec_prefix) | 
 | 135 | for prefix in prefixes: | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 136 |     if prefix: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 137 |         if os.sep == '/': | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 138 |             sitedirs = [makepath(prefix, | 
 | 139 |                                  "lib", | 
 | 140 |                                  "python" + sys.version[:3], | 
 | 141 |                                  "site-packages"), | 
 | 142 |                         makepath(prefix, "lib", "site-python")] | 
| Jack Jansen | d49056c | 2000-12-12 22:39:04 +0000 | [diff] [blame] | 143 |         elif os.sep == ':': | 
 | 144 |             sitedirs = [makepath(prefix, "lib", "site-packages")] | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 145 |         else: | 
 | 146 |             sitedirs = [prefix] | 
 | 147 |         for sitedir in sitedirs: | 
 | 148 |             if os.path.isdir(sitedir): | 
 | 149 |                 addsitedir(sitedir) | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 150 |  | 
| Guido van Rossum | d89fa0c | 1998-08-07 18:01:14 +0000 | [diff] [blame] | 151 | # Define new built-ins 'quit' and 'exit'. | 
 | 152 | # These are simply strings that display a hint on how to exit. | 
 | 153 | if os.sep == ':': | 
 | 154 |     exit = 'Use Cmd-Q to quit.' | 
 | 155 | elif os.sep == '\\': | 
 | 156 |     exit = 'Use Ctrl-Z plus Return to exit.' | 
 | 157 | else: | 
 | 158 |     exit = 'Use Ctrl-D (i.e. EOF) to exit.' | 
 | 159 | import __builtin__ | 
 | 160 | __builtin__.quit = __builtin__.exit = exit | 
 | 161 | del exit | 
 | 162 |  | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 163 | # interactive prompt objects for printing the license text, a list of | 
 | 164 | # contributors and the copyright notice. | 
 | 165 | class _Printer: | 
 | 166 |     MAXLINES = 23 | 
 | 167 |  | 
| Guido van Rossum | f19a7ac | 2000-10-03 17:11:37 +0000 | [diff] [blame] | 168 |     def __init__(self, name, data, files=(), dirs=()): | 
 | 169 |         self.__name = name | 
 | 170 |         self.__data = data | 
 | 171 |         self.__files = files | 
 | 172 |         self.__dirs = dirs | 
 | 173 |         self.__lines = None | 
 | 174 |  | 
 | 175 |     def __setup(self): | 
 | 176 |         if self.__lines: | 
 | 177 |             return | 
 | 178 |         data = None | 
 | 179 |         for dir in self.__dirs: | 
 | 180 |             for file in self.__files: | 
 | 181 |                 file = os.path.join(dir, file) | 
 | 182 |                 try: | 
 | 183 |                     fp = open(file) | 
 | 184 |                     data = fp.read() | 
 | 185 |                     fp.close() | 
 | 186 |                     break | 
 | 187 |                 except IOError: | 
 | 188 |                     pass | 
 | 189 |             if data: | 
 | 190 |                 break | 
 | 191 |         if not data: | 
 | 192 |             data = self.__data | 
 | 193 |         self.__lines = data.split('\n') | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 194 |         self.__linecnt = len(self.__lines) | 
 | 195 |  | 
 | 196 |     def __repr__(self): | 
| Guido van Rossum | f19a7ac | 2000-10-03 17:11:37 +0000 | [diff] [blame] | 197 |         self.__setup() | 
 | 198 |         if len(self.__lines) <= self.MAXLINES: | 
 | 199 |             return "\n".join(self.__lines) | 
 | 200 |         else: | 
 | 201 |             return "Type %s() to see the full %s text" % ((self.__name,)*2) | 
 | 202 |  | 
 | 203 |     def __call__(self): | 
 | 204 |         self.__setup() | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 205 |         prompt = 'Hit Return for more, or q (and Return) to quit: ' | 
 | 206 |         lineno = 0 | 
 | 207 |         while 1: | 
 | 208 |             try: | 
 | 209 |                 for i in range(lineno, lineno + self.MAXLINES): | 
 | 210 |                     print self.__lines[i] | 
 | 211 |             except IndexError: | 
 | 212 |                 break | 
 | 213 |             else: | 
 | 214 |                 lineno += self.MAXLINES | 
 | 215 |                 key = None | 
 | 216 |                 while key is None: | 
 | 217 |                     key = raw_input(prompt) | 
 | 218 |                     if key not in ('', 'q'): | 
 | 219 |                         key = None | 
 | 220 |                 if key == 'q': | 
 | 221 |                     break | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 222 |  | 
| Guido van Rossum | f19a7ac | 2000-10-03 17:11:37 +0000 | [diff] [blame] | 223 | __builtin__.copyright = _Printer("copyright", sys.copyright) | 
| Barry Warsaw | 23f26ce | 2000-12-06 22:20:07 +0000 | [diff] [blame] | 224 | if sys.platform[:4] == 'java': | 
 | 225 |     __builtin__.credits = _Printer( | 
 | 226 |         "credits", | 
 | 227 |         "Jython is maintained by the Jython developers (www.jython.org).") | 
 | 228 | else: | 
 | 229 |     __builtin__.credits = _Printer("credits", """\ | 
 | 230 | Thanks to CWI, CNRI, BeOpen.com, Digital Creations and a cast of thousands | 
 | 231 | for supporting Python development.  See www.python.org for more information.""") | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 232 | here = os.path.dirname(os.__file__) | 
| Guido van Rossum | f19a7ac | 2000-10-03 17:11:37 +0000 | [diff] [blame] | 233 | __builtin__.license = _Printer( | 
 | 234 |     "license", "See http://www.pythonlabs.com/products/python2.0/license.html", | 
 | 235 |     ["LICENSE.txt", "LICENSE"], | 
| Barry Warsaw | 62d2488 | 2001-03-23 17:53:49 +0000 | [diff] [blame] | 236 |     [os.path.join(here, os.pardir), here, os.curdir]) | 
| Guido van Rossum | d125239 | 2000-09-05 04:39:55 +0000 | [diff] [blame] | 237 |  | 
 | 238 |  | 
| Fredrik Lundh | 3fded4b | 2000-07-15 20:58:44 +0000 | [diff] [blame] | 239 | # Set the string encoding used by the Unicode implementation.  The | 
 | 240 | # default is 'ascii', but if you're willing to experiment, you can | 
 | 241 | # change this. | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 242 |  | 
| Marc-André Lemburg | 09cad08 | 2000-09-18 11:06:00 +0000 | [diff] [blame] | 243 | encoding = "ascii" # Default value set by _PyUnicode_Init() | 
| Fredrik Lundh | 47ac126 | 2000-07-15 20:45:23 +0000 | [diff] [blame] | 244 |  | 
 | 245 | if 0: | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 246 |     # Enable to support locale aware default string encodings. | 
| Fredrik Lundh | 47ac126 | 2000-07-15 20:45:23 +0000 | [diff] [blame] | 247 |     import locale | 
 | 248 |     loc = locale.getdefaultlocale() | 
 | 249 |     if loc[1]: | 
 | 250 |         encoding = loc[1] | 
 | 251 |  | 
 | 252 | if 0: | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 253 |     # Enable to switch off string to Unicode coercion and implicit | 
 | 254 |     # Unicode to string conversion. | 
| Fredrik Lundh | 47ac126 | 2000-07-15 20:45:23 +0000 | [diff] [blame] | 255 |     encoding = "undefined" | 
 | 256 |  | 
| Marc-André Lemburg | 09cad08 | 2000-09-18 11:06:00 +0000 | [diff] [blame] | 257 | if encoding != "ascii": | 
 | 258 |     sys.setdefaultencoding(encoding) | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 259 |  | 
 | 260 | # | 
 | 261 | # Run custom site specific code, if available. | 
 | 262 | # | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 263 | try: | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 264 |     import sitecustomize | 
| Guido van Rossum | e57c96e | 1996-08-17 19:56:26 +0000 | [diff] [blame] | 265 | except ImportError: | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 266 |     pass | 
 | 267 |  | 
 | 268 | # | 
 | 269 | # Remove sys.setdefaultencoding() so that users cannot change the | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 270 | # encoding after initialization.  The test for presence is needed when | 
| Barry Warsaw | 23f26ce | 2000-12-06 22:20:07 +0000 | [diff] [blame] | 271 | # this module is run as a script, because this code is executed twice. | 
| Marc-André Lemburg | 990bbe9 | 2000-06-07 09:12:09 +0000 | [diff] [blame] | 272 | # | 
| Fred Drake | 38cb9f1 | 2000-09-28 16:52:36 +0000 | [diff] [blame] | 273 | if hasattr(sys, "setdefaultencoding"): | 
 | 274 |     del sys.setdefaultencoding | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 275 |  | 
 | 276 | def _test(): | 
 | 277 |     print "sys.path = [" | 
 | 278 |     for dir in sys.path: | 
| Guido van Rossum | 45e2fbc | 1998-03-26 21:13:24 +0000 | [diff] [blame] | 279 |         print "    %s," % `dir` | 
| Guido van Rossum | f30bec7 | 1997-08-29 22:30:45 +0000 | [diff] [blame] | 280 |     print "]" | 
 | 281 |  | 
 | 282 | if __name__ == '__main__': | 
 | 283 |     _test() |