Ashot
Ashot

Reputation: 10959

gdb error: Couldn't find method (null)what

  ?58                  pinNodes.push_back(node);                                                                                                                            ?
   ?59              }                                                                                                                                                        ?
   ?60              nlb::application::Application::instance().interpreter().eval(QString("unset %1").arg(pinIterListVarName));                                               ?
   ?61                                                                                                                                                                       ?
   ?62              if (!pinNodes.empty()) {                                                                                                                                 ?
   ?63                  insert(0, pinNodes.begin(), pinNodes.end());                                                                                                         ?
   ?64              }                                                                                                                                                        ?
   ?65          } catch (const std::exception& e) {                                                                                                                          ?
B+>?66              SA_ASSERT(false, e.what());                                                                                                                              ?
   ?67          }                                                                                                                                                            ?
   ?68      }           

This is from gdb. I have set breakpoint to failing assert. When I am trying to print the reason of failure using p e.what() gdb prints Couldn't find method (null)what

Printing e gives that is is incomplete.

(gdb) p e
$4 = (const struct std::exception &) @0x58f1990: <incomplete type>

How I can print it?

If SA_ASSERT's condition is false it calls this

void printTrace(unsigned int startDepth, QString& buff)
{

    const size_t maxDepth = 200;
    size_t stackDepth;
    void *stackAddrs[maxDepth];
    char **stackStrings;

    stackDepth = backtrace(stackAddrs, maxDepth);
    stackStrings = backtrace_symbols(stackAddrs, stackDepth);

    buff += "Call stack\n";

    unsigned int line = 1;

    for (size_t i = startDepth; i < stackDepth; i++) {
        size_t sz = 500; // just a guess, template names will go much wider
        char *function = reinterpret_cast<char*>(malloc(sz));
        char *begin = 0, *end = 0;
        // find the parentheses and address offset surrounding the mangled name
        for (char *j = stackStrings[i]; *j != 0; ++j) {
            if (*j == '(') {
                begin = j;
            } else if (*j == '+') {
                end = j;
            }
        }
        if (begin && end) {
            begin++;
            *end = 0;
            // found our mangled name, now in [begin, end)
            int status;
            char *ret = abi::__cxa_demangle(begin, function, &sz, &status);
            if (ret) {
                // return value may be a realloc() of the input
                function = ret;
            } else {
                // demangling failed, just pretend it's a C function
                // with no args
                std::strncpy(function, begin, sz);
                std::strncat(function, "()", sz);
                function[sz-1] = ' ';
            }
            buff += QString::number(line++) + QString(")    ") + function + "\n";
        } else {
            // didn't find the mangled name, just print the whole line
            buff += QString::number(line++) + QString(")    ") + stackStrings[i] + "\n";
        }
        free(function);
    }

    free(stackStrings); // malloc()ed by backtrace_symbols

}

The gdb version

GNU gdb 6.8
Copyright (C) 2008 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-unknown-linux-gnu".

Upvotes: 2

Views: 4331

Answers (1)

Tom Tromey
Tom Tromey

Reputation: 22519

An incomplete type means you are missing some debuginfo. Without it, gdb can't do much. For example it can't print an object of that type, because it doesn't know how the type is laid out.

Version 6.8 is quite old. You should upgrade if you can. There have been many, many bug fixes to C++ support since then.

The "(null)" looks like a gdb bug. This is what happens when you try to printf NULL (at least with glibc). However, it is probable that this bug has been fixed sometime in the last 5 years.

Upvotes: 2

Related Questions