gdb python: кто-нибудь может объяснить мне, как использовать этот скрипт, написанный в этом посте?

Как это сделать для кода c..? Является ли это возможным..? Я прочитал этот пост. Я также хочу делать подобные вещи, но я не могу использовать данный обновленный скрипт по ссылке Скрипты GDB-Python: любые образцы, итерирующие поля структуры C/C++

Я выполнил следующие шаги для тестирования: мое имя исходного кода было: test.c и pretty.py

gcc -g test.c

gdb test

(gdb) source pretty.py

(gdb) run

(gdb) print <stcruct object>

Как использовать этот скрипт?


person Baijnath Jaiswal    schedule 10.05.2013    source источник
comment
Привет всем.. Жду ваших ответов.......   -  person Baijnath Jaiswal    schedule 13.05.2013


Ответы (1)


Этот сценарий реализует новую команду GDB, wzd, которая принимает структуру C в качестве аргумента. Вы можете узнать из строки документа Python после class PrintGList

"""print fields of a struct: wzd struct_object
Iterate through the fields of a struct, and display
a human-readable form of the objects."""

Вы ожидали, что сценарий реализует красивый принтер GDB для пользовательского типа данных и изменит то, что печатается, когда вы используете команду GDB print, но сценарий подключается не так.

Имя класса PrintGList говорит о том, что код создан из скрипта, выводящего связанные списки в библиотеке glib. Еще раз скопируйте и вставьте забастовки по кодированию ;) Я исправил несколько мелких ошибок и очистил приведенный ниже код (wzd.py):

import gdb

def _type_is_container(t):
    return t.code == gdb.TYPE_CODE_STRUCT

class WZD(gdb.Command):
    '''print fields of a struct: wzd struct_object

Iterate through the fields of a struct, and display
a human-readable form of the objects.'''

    def __init__(self):
        gdb.Command.__init__(self, "wzd", gdb.COMMAND_DATA, gdb.COMPLETE_SYMBOL, True)

    def invoke(self, arg, from_tty):

        arg_list = gdb.string_to_argv(arg)
        if len(arg_list) < 1:
            print "usage: wzd struct"
            return

        n = arg_list[0]
        l = gdb.parse_and_eval(arg_list[0])
        (t, m) = (l.type, l.type.tag)

        print "  variable %s " % n, " type %s " % t

        if l.type.code == gdb.TYPE_CODE_STRUCT:
            print "Found a struct  %s " % n
            self._print_fields(n, t)
        else:
            print "Found no struct"

    def _print_fields(self, n, typeobject):
        print typeobject
        flds = typeobject.fields()
        for x in flds:
            sn = n + "." + x.name
            if _type_is_container(x.type):
                tag_msg = ', tag: %r' % (x.type.tag,)
            else:
                tag_msg = ''
            print '  field %r type %s (code: %s%s)' % (sn, x.type, x.type.code, tag_msg)
            if _type_is_container(x.type):
                print "Found sub level struct  %s " % sn
                sl = gdb.parse_and_eval(sn)
                sm = sl.type.tag
                st = sl.type
                self._print_fields(sn, x.type)

    def _deep_items (self, type_):
        for k, v in type_.iteritems():
            if k:
                print " k v %s " % k , " %s " % v
            else:
                print "   v    ",      " %s " % v

WZD()

Тестовая программа (struct-read.c):

#include <assert.h>
#include <stdio.h>

/* https://github.com/scottt/debugbreak */
#include <debugbreak/debugbreak.h>

struct T {
    int x, y;
};

struct S {
    struct T t;
    char b;
};

int main()
{
    int r;
    struct S s;
    r = scanf("%d%d%c", &s.t.x, &s.t.y, &s.b);
    assert(r == 3);
    debug_break();

    return 0;
}

Пример сеанса GDB:

$ echo 1 2 x > in
$ gdb -q -x wzd.py struct-read
<...>

(gdb) run < in
<...>
Program received signal SIGTRAP, Trace/breakpoint trap.
main () at struct-read.c:25
25  }

(gdb) wzd s
  variable s   type struct S 
Found a struct  s 
struct S
  field 's.t' type struct T (code: 3, tag: 'T')
Found sub level struct  s.t 
struct T
  field 's.t.x' type int (code: 8)
  field 's.t.y' type int (code: 8)
  field 's.b' type char (code: 8)
person scottt    schedule 13.05.2013
comment
Большое спасибо, Скотт. :-) - person Baijnath Jaiswal; 14.05.2013
comment
@BaijnathJaiswal, пожалуйста. Я хочу подчеркнуть, что приведенный выше код Python действительно не очень хорошо написан или чист. Если у вас есть определенная структура данных, которую вы хотите обработать с помощью Python и GDB, рассмотрите возможность публикации еще одного вопроса на SO, если у вас возникнут проблемы. - person scottt; 14.05.2013
comment
Конечно..! и еще раз спасибо, ваш ответ был очень полезен для меня. :-) - person Baijnath Jaiswal; 14.05.2013
comment
@ Скотт, можем ли мы напечатать все глобальные и локальные переменные (с соответствующими значениями) одинаковыми способами? - person Baijnath Jaiswal; 14.05.2013
comment
@BaijnathJaiswal, да, см. stackoverflow.com/a/16268295/676030 и stackoverflow.com/a/15312719/676030 - person scottt; 14.05.2013
comment
@ Скотт, спасибо. Хорошая работа. но скрипт по этой ссылке stackoverflow.com/a/16268295/676030 не извлекает все глобальные переменные. На самом деле я выгляжу похоже, но хочу получить все глобальные переменные (локальные, если возможно) и их значения в удобочитаемой форме. Другая ссылка печатает значения, но я думаю, что это просто автоматизация шагов gdb. - person Baijnath Jaiswal; 14.05.2013
comment
@ scottt, извините, мое наблюдение было неверным, ваш скрипт по этой ссылке stackoverflow.com/a/16268295/676030 загружается все переменные. И с помощью symbol.value() я также могу распечатать соответствующие значения. Но проблема в том, что нам нужно снова запустить код (gdb) start. Можем ли мы извлечь то же самое из файла coredump (без повторного выполнения кода)? - person Baijnath Jaiswal; 15.05.2013
comment
@ scottt, скажите, пожалуйста, можно ли извлечь stucts и sub-structs без повторного выполнения двоичного кода? - person Baijnath Jaiswal; 21.05.2013
comment
@BaijnathJaiswal, да, это возможно. Проверка данных из основных файлов, когда у вас есть соответствующий двоичный файл с отладочной информацией, должна просто работать. - person scottt; 21.05.2013