mirror of git://gcc.gnu.org/git/gcc.git
hook.in: Do not fail when there is no current objfile.
* python/hook.in: Do not fail when there is no current objfile. Use os.path.normpath. From-SVN: r148626
This commit is contained in:
parent
2cb0a60da1
commit
6ba49852d8
|
|
@ -1,3 +1,8 @@
|
||||||
|
2009-06-17 Tom Tromey <tromey@redhat.com>
|
||||||
|
|
||||||
|
* python/hook.in: Do not fail when there is no current objfile.
|
||||||
|
Use os.path.normpath.
|
||||||
|
|
||||||
2009-06-16 Jonathan Wakely <jwakely.gcc@gmail.com>
|
2009-06-16 Jonathan Wakely <jwakely.gcc@gmail.com>
|
||||||
|
|
||||||
* libsupc++/exception_ptr.h (exception_ptr::swap(exception_ptr&&)):
|
* libsupc++/exception_ptr.h (exception_ptr::swap(exception_ptr&&)):
|
||||||
|
|
|
||||||
|
|
@ -22,33 +22,38 @@ import os.path
|
||||||
pythondir = '@pythondir@'
|
pythondir = '@pythondir@'
|
||||||
libdir = '@toolexeclibdir@'
|
libdir = '@toolexeclibdir@'
|
||||||
|
|
||||||
# Update module path. We want to find the relative path from libdir
|
# This file might be loaded when there is no current objfile. This
|
||||||
# to pythondir, and then we want to apply that relative path to the
|
# can happen if the user loads it manually. In this case we don't
|
||||||
# directory holding the objfile with which this file is associated.
|
# update sys.path; instead we just hope the user managed to do that
|
||||||
# This preserves relocatability of the gcc tree.
|
# beforehand.
|
||||||
|
if gdb.current_objfile () is not None:
|
||||||
|
# Update module path. We want to find the relative path from libdir
|
||||||
|
# to pythondir, and then we want to apply that relative path to the
|
||||||
|
# directory holding the objfile with which this file is associated.
|
||||||
|
# This preserves relocatability of the gcc tree.
|
||||||
|
|
||||||
# Do a simple normalization that removes duplicate separators.
|
# Do a simple normalization that removes duplicate separators.
|
||||||
pythondir = os.path.join (*['/'] + pythondir.split (os.sep))
|
pythondir = os.path.normpath (pythondir)
|
||||||
libdir = os.path.join (*['/'] + libdir.split (os.sep))
|
libdir = os.path.normpath (libdir)
|
||||||
|
|
||||||
prefix = os.path.commonprefix ([libdir, pythondir])
|
prefix = os.path.commonprefix ([libdir, pythondir])
|
||||||
# In some bizarre configuration we might have found a match in the
|
# In some bizarre configuration we might have found a match in the
|
||||||
# middle of a directory name.
|
# middle of a directory name.
|
||||||
if prefix[-1] != '/':
|
if prefix[-1] != '/':
|
||||||
prefix = os.path.dirname (prefix)
|
prefix = os.path.dirname (prefix)
|
||||||
|
|
||||||
# Strip off the prefix.
|
# Strip off the prefix.
|
||||||
pythondir = pythondir[len (prefix):]
|
pythondir = pythondir[len (prefix):]
|
||||||
libdir = libdir[len (prefix):]
|
libdir = libdir[len (prefix):]
|
||||||
|
|
||||||
# Compute the ".."s needed to get from libdir to the prefix.
|
# Compute the ".."s needed to get from libdir to the prefix.
|
||||||
dotdots = ('..' + os.sep) * len (libdir.split (os.sep))
|
dotdots = ('..' + os.sep) * len (libdir.split (os.sep))
|
||||||
|
|
||||||
objfile = gdb.current_objfile ().filename
|
objfile = gdb.current_objfile ().filename
|
||||||
dir = os.path.join (os.path.dirname (objfile), dotdots, pythondir)
|
dir = os.path.join (os.path.dirname (objfile), dotdots, pythondir)
|
||||||
|
|
||||||
if not dir in sys.path:
|
if not dir in sys.path:
|
||||||
sys.path.insert(0, dir)
|
sys.path.insert(0, dir)
|
||||||
|
|
||||||
# Load the pretty-printers.
|
# Load the pretty-printers.
|
||||||
from libstdcxx.v6.printers import register_libstdcxx_printers
|
from libstdcxx.v6.printers import register_libstdcxx_printers
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue