← Back to team overview

touch-packages team mailing list archive

[Bug 1446828] Re: gdb pretty printers do not auto-load on Trusty

 

Hello Simon, or anyone else affected,

Accepted gcc-4.8 into trusty-proposed. The package will build now and be
available at
https://launchpad.net/ubuntu/+source/gcc-4.8/4.8.4-2ubuntu1~14.04.1 in a
few hours, and then in the -proposed repository.

Please help us by testing this new package.  See
https://wiki.ubuntu.com/Testing/EnableProposed for documentation how to
enable and use -proposed.  Your feedback will aid us getting this update
out to other Ubuntu users.

If this package fixes the bug for you, please add a comment to this bug,
mentioning the version of the package you tested, and change the tag
from verification-needed to verification-done. If it does not fix the
bug for you, please add a comment stating that, and change the tag to
verification-failed.  In either case, details of your testing will help
us make a better decision.

Further information regarding the verification process can be found at
https://wiki.ubuntu.com/QATeam/PerformingSRUVerification .  Thank you in
advance!

** Changed in: gcc-4.8 (Ubuntu Trusty)
       Status: Confirmed => Fix Committed

** Tags added: verification-needed

-- 
You received this bug notification because you are a member of Ubuntu
Touch seeded packages, which is subscribed to gcc-4.8 in Ubuntu.
https://bugs.launchpad.net/bugs/1446828

Title:
  gdb pretty printers do not auto-load on Trusty

Status in gcc-4.8 package in Ubuntu:
  Fix Released
Status in gcc-4.8 source package in Trusty:
  Fix Committed

Bug description:
  On Ubuntu 14.04.2 (Trusty), the file in libstdc++6-4.8-dbg to auto-
  load the pretty printers doesn't resolve the right path to the
  printers. To reproduce, on a fresh install:

  $ cat test.cpp
  #include <vector>
  int main() {
    std::vector<int> v;
    v.push_back(1);
    return 0;
  }
  $ g++ test.cpp -g
  $ gdb a.out -ex start
  Reading symbols from a.out...done.
  Temporary breakpoint 1 at 0x400956: file test.cpp, line 3.
  Starting program: /home/emaisin/a.out 
  Traceback (most recent call last):
    File "/usr/lib/debug/usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.19-gdb.py", line 63, in <module>
      from libstdcxx.v6.printers import register_libstdcxx_printers
  ImportError: No module named 'libstdcxx'

  Temporary breakpoint 1, main () at test.cpp:3
  3	  std::vector<int> v;
  (gdb) 

  It seems like the fixup for multiarch actually adds an extra "..":

      if not os.path.basename(os.path.dirname(__file__)).startswith('lib'):
          backdirs += 1 # multiarch subdir

  Removing these two lines almost makes it work:

  $ gdb a.out -ex start
  Reading symbols from a.out...done.
  Temporary breakpoint 1 at 0x400956: file test.cpp, line 3.
  Starting program: /home/emaisin/a.out 
  Traceback (most recent call last):
    File "/usr/lib/debug/usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.19-gdb.py", line 63, in <module>
      from libstdcxx.v6.printers import register_libstdcxx_printers
    File "/usr/lib/x86_64-linux-gnu/../../share/gcc-4.8/python/libstdcxx/v6/printers.py", line 54
      raise ValueError, "Cannot find type %s::%s" % (str(orig), name)
                      ^
  SyntaxError: invalid syntax

  Temporary breakpoint 1, main () at test.cpp:3
  3	  std::vector<int> v;

  
  That last problem is tracked in bug #1256419, which is still a pending issue in Trusty.

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/gcc-4.8/+bug/1446828/+subscriptions


References