]>
git.saurik.com Git - wxWidgets.git/blob - wxPython/wxversion/wxversion.py
1 #----------------------------------------------------------------------
3 # Purpose: Allows a wxPython program to search for alternate
4 # installations of the wxPython packages and modify sys.path
5 # so they will be found when "import wx" is done.
9 # Created: 24-Sept-2004
11 # Copyright: (c) 2004 by Total Control Software
12 # Licence: wxWindows license
13 #----------------------------------------------------------------------
16 If you have more than one version of wxPython installed this module
17 allows your application to choose which version of wxPython will be
18 imported when it does 'import wx'. You use it like this:
21 wxversion.require('2.4')
24 Of course the default wxPython version can also be controlled by
25 setting PYTHONPATH or by editing the wx.pth path configuration file,
26 but using wxversion will allow an application to manage the version
27 selection itself rather than depend on the user to setup the
28 environment correctly.
30 It works by searching the sys.path for directories matching wx-* and
31 then comparing them to what was passed to the require function. If a
32 match is found then that path is inserted into sys.path.
35 import sys
, os
, glob
, fnmatch
40 def require(versions
):
42 Search for a wxPython installation that matches version.
44 :param version: Specifies the version to look for, it can either be
45 a sting or a list of strings. Each string is
46 compared to the installed wxPythons and the best
47 match is added to the sys.path, allowing an 'import
48 wx' to find that version.
50 The version string is composed of the dotted
51 version number (at least 2 of the 4 components)
52 optionally followed by hyphen ('-') separated
53 options (wx port, unicode/ansi, flavour, etc.) A
54 match is determined by how much of the installed
55 version matches what is given in the version
56 parameter. If the version number components don't
57 match then the score is zero, otherwise the score
58 is increased for every specified optional component
59 that is specified and that matches.
61 assert not sys
.modules
.has_key('wx') and not sys
.modules
.has_key('wxPython'), \
62 "wxversion.require() must be called before wxPython is imported"
66 if type(versions
) == str:
69 packages
= _find_installed()
72 score
= pkg
.Score(_wxPackageInfo(ver
))
77 assert bestMatch
is not None, \
78 "Required version of wxPython not found"
80 sys
.path
.insert(0, bestMatch
.pathname
)
85 _pattern
= "wx-[0-9].*"
86 def _find_installed():
91 # empty means to look in the current dir
95 # skip it if it's not a package dir
96 if not os
.path
.isdir(pth
):
99 base
= os
.path
.basename(pth
)
101 # if it's a wx path that's already in the sys.path then mark
102 # it for removal and then skip it
103 if fnmatch
.fnmatchcase(base
, _pattern
):
107 # now look in the dir for matching subdirs
108 for name
in glob
.glob(os
.path
.join(pth
, _pattern
)):
109 # make sure it's a directory
110 if not os
.path
.isdir(name
):
112 # and has a wx subdir
113 if not os
.path
.exists(os
.path
.join(name
, 'wx')):
115 installed
.append(_wxPackageInfo(name
, True))
118 del sys
.path
[sys
.path
.index(rem
)]
125 class _wxPackageInfo(object):
126 def __init__(self
, pathname
, stripFirst
=False):
127 self
.pathname
= pathname
128 base
= os
.path
.basename(pathname
)
129 segments
= base
.split('-')
131 segments
= segments
[1:]
132 self
.version
= tuple([int(x
) for x
in segments
[0].split('.')])
133 self
.options
= segments
[1:]
136 def Score(self
, other
):
138 # whatever version components given in other must match exactly
139 if len(self
.version
) > len(other
.version
):
140 v
= self
.version
[:len(other
.version
)]
143 if v
!= other
.version
:
146 for opt
in other
.options
:
147 if opt
in self
.options
:
152 # TODO: factor self.options into the sort order?
153 def __lt__(self
, other
):
154 return self
.version
< other
.version
155 def __gt__(self
, other
):
156 return self
.version
> other
.version
157 def __eq__(self
, other
):
158 return self
.version
== other
.version
164 if __name__
== '__main__':
167 savepath
= sys
.path
[:]
169 print "Asked for %s:\t got: %s" % (version
, sys
.path
[0])
170 pprint
.pprint(sys
.path
)
172 sys
.path
= savepath
[:]
175 # make some test dirs
178 'wx-2.5.2.9-gtk2-unicode',
179 'wx-2.5.2.9-gtk-ansi',
181 'wx-2.5.2.8-gtk2-unicode',
184 d
= os
.path
.join('/tmp', name
)
186 os
.mkdir(os
.path
.join(d
, 'wx'))
188 # setup sys.path to see those dirs
189 sys
.path
.append('/tmp')
200 # There isn't a unicode match for this one, but it will give the best
201 # available 2.4. Should it give an error instead? I don't think so...
205 # expecting an error on this one
207 except AssertionError:
208 print "Asked for 2.6:\t got: Assertion"
210 # Try asking for multiple versions
211 test(["2.6", "2.5.3", "2.5.2-gtk2"])
215 d
= os
.path
.join('/tmp', name
)
216 os
.rmdir(os
.path
.join(d
, 'wx'))