From 921069b6c3f48329a7a96528249c8b42e03b5468 Mon Sep 17 00:00:00 2001 From: "Gustavo J. A. M. Carneiro" Date: Sun, 23 Apr 2006 12:19:45 +0000 Subject: Bug 338945 – Make pygtk.py relocatable MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ChangeLog | 9 ++++++ Makefile.am | 9 ++---- pygtk.py | 95 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ pygtk.py.in | 94 ------------------------------------------------------------ 4 files changed, 106 insertions(+), 101 deletions(-) create mode 100644 pygtk.py delete mode 100644 pygtk.py.in diff --git a/ChangeLog b/ChangeLog index b87b4b1..e6e82ad 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2006-04-23 John Ehresman + + reviewed by: Gustavo + + * Makefile.am: + * pygtk.py: + * pygtk.py.in: + Bug 338945: Make pygtk.py relocatable + 2006-04-18 John Ehresman * dsextras.py: Add compiler / linker flags from pkgconfig-2.0.pc diff --git a/Makefile.am b/Makefile.am index b506a01..c62bde3 100644 --- a/Makefile.am +++ b/Makefile.am @@ -11,7 +11,7 @@ EXTRA_DIST = \ PKG-INFO \ PKG-INFO.in \ setup.py \ - pygtk.py.in \ + pygtk.py \ dsextras.py INCLUDES = $(PYTHON_INCLUDES) $(GLIB_CFLAGS) -I$(top_srcdir)/gobject @@ -25,13 +25,8 @@ pkgpyexecdir = $(pyexecdir)/gtk-2.0 pkgpyexec_PYTHON = dsextras.py pkgpyexec_LTLIBRARIES = -pygtk.py: pygtk.py.in - sed -e s!\@pyexecdir\@!@pyexecdir@! \ - < $< > $@ -pygtk.py: Makefile - # python -nodist_pyexec_PYTHON = pygtk.py +pyexec_PYTHON = pygtk.py pyexec_LTLIBRARIES = noinst_PYTHON = ltihooks.py diff --git a/pygtk.py b/pygtk.py new file mode 100644 index 0000000..77fef81 --- /dev/null +++ b/pygtk.py @@ -0,0 +1,95 @@ +# -*- Mode: Python; py-indent-offset: 4 -*- +# pygtk - Python bindings for the GTK+ widget set. +# Copyright (C) 1998-2002 James Henstridge +# +# pygtk.py: pygtk version selection code. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 +# USA + +import fnmatch +import glob +import os +import os.path +import sys + +__all__ = ['require'] + +_our_dir = os.path.dirname(os.path.abspath(os.path.normpath(__file__))) +_pygtk_2_0_dir = os.path.normpath('%s/gtk-2.0' % _our_dir) + +_pygtk_dir_pat = 'gtk-[0-9].[0-9]' + +_pygtk_required_version = None + +def _get_available_versions(): + versions = {} + for dir in sys.path: + if not dir: + dir = os.getcwd() + + if not os.path.isdir(dir): + continue + + # if the dir is a pygtk dir, skip it + if fnmatch.fnmatchcase(os.path.basename(dir), _pygtk_dir_pat): + continue + + for filename in glob.glob(os.path.join(dir, _pygtk_dir_pat)): + pathname = os.path.join(dir, filename) + + # skip non directories + if not os.path.isdir(pathname): + continue + + # skip empty directories + if not os.listdir(pathname): + continue + + if not versions.has_key(filename[-3:]): + versions[filename[-3:]] = pathname + return versions + +def require20(): + if _pygtk_2_0_dir not in sys.path: + sys.path.insert(0, _pygtk_2_0_dir) + +def require(version): + if version == '2.0': + return require20() + + global _pygtk_required_version + + if _pygtk_required_version != None: + assert _pygtk_required_version == version, \ + "a different version of gtk was already required" + return + + assert not sys.modules.has_key('gtk'), \ + "pygtk.require() must be called before importing gtk" + + versions = _get_available_versions() + assert versions.has_key(version), \ + "required version '%s' not found on system" % version + + # remove any pygtk dirs first ... + for dir in sys.path: + if fnmatch.fnmatchcase(os.path.basename(dir), _pygtk_dir_pat): + sys.path.remove(dir) + + # prepend the pygtk path ... + sys.path.insert(0, versions[version]) + + _pygtk_required_version = version diff --git a/pygtk.py.in b/pygtk.py.in deleted file mode 100644 index c860c13..0000000 --- a/pygtk.py.in +++ /dev/null @@ -1,94 +0,0 @@ -# -*- Mode: Python; py-indent-offset: 4 -*- -# pygtk - Python bindings for the GTK+ widget set. -# Copyright (C) 1998-2002 James Henstridge -# -# pygtk.py: pygtk version selection code. -# -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -# USA - -import fnmatch -import glob -import os -import os.path -import sys - -__all__ = ['require'] - -_pygtk_2_0_dir = os.path.normpath('@pyexecdir@/gtk-2.0') - -_pygtk_dir_pat = 'gtk-[0-9].[0-9]' - -_pygtk_required_version = None - -def _get_available_versions(): - versions = {} - for dir in sys.path: - if not dir: - dir = os.getcwd() - - if not os.path.isdir(dir): - continue - - # if the dir is a pygtk dir, skip it - if fnmatch.fnmatchcase(os.path.basename(dir), _pygtk_dir_pat): - continue - - for filename in glob.glob(os.path.join(dir, _pygtk_dir_pat)): - pathname = os.path.join(dir, filename) - - # skip non directories - if not os.path.isdir(pathname): - continue - - # skip empty directories - if not os.listdir(pathname): - continue - - if not versions.has_key(filename[-3:]): - versions[filename[-3:]] = pathname - return versions - -def require20(): - if _pygtk_2_0_dir not in sys.path: - sys.path.insert(0, _pygtk_2_0_dir) - -def require(version): - if version == '2.0': - return require20() - - global _pygtk_required_version - - if _pygtk_required_version != None: - assert _pygtk_required_version == version, \ - "a different version of gtk was already required" - return - - assert not sys.modules.has_key('gtk'), \ - "pygtk.require() must be called before importing gtk" - - versions = _get_available_versions() - assert versions.has_key(version), \ - "required version '%s' not found on system" % version - - # remove any pygtk dirs first ... - for dir in sys.path: - if fnmatch.fnmatchcase(os.path.basename(dir), _pygtk_dir_pat): - sys.path.remove(dir) - - # prepend the pygtk path ... - sys.path.insert(0, versions[version]) - - _pygtk_required_version = version -- cgit