2010-04-08 Phil Muldoon <pmuldoon@redhat.com>

PR python/11417

	* python/py-lazy-string.c (stpy_convert_to_value): Check for
          a NULL address.
	  (gdbpy_create_lazy_string_object): Allow strings with a NULL
          address and a zero length.

2010-04-08  Phil Muldoon  <pmuldoon@redhat.com>

	* gdb.python/py-value: Add null string variable.
	  (test_lazy_string): Test zero length, NULL address lazy
	  strings.
This commit is contained in:
Phil Muldoon 2010-04-08 10:28:42 +00:00
parent f8c4f48020
commit fff5cc649e
5 changed files with 32 additions and 3 deletions

View file

@ -1,3 +1,12 @@
2010-04-08 Phil Muldoon <pmuldoon@redhat.com>
PR python/11417
* python/py-lazy-string.c (stpy_convert_to_value): Check for
a NULL address.
(gdbpy_create_lazy_string_object): Allow strings with a NULL
address and a zero length.
2010-04-08 Hui Zhu <teawater@gmail.com> 2010-04-08 Hui Zhu <teawater@gmail.com>
* i386-tdep.c (i386_process_record): Add support for insn * i386-tdep.c (i386_process_record): Add support for insn

View file

@ -94,6 +94,13 @@ stpy_convert_to_value (PyObject *self, PyObject *args)
lazy_string_object *self_string = (lazy_string_object *) self; lazy_string_object *self_string = (lazy_string_object *) self;
struct value *val; struct value *val;
if (self_string->address == 0)
{
PyErr_SetString (PyExc_MemoryError,
"Cannot create a value from NULL");
return NULL;
}
val = value_at_lazy (self_string->type, self_string->address); val = value_at_lazy (self_string->type, self_string->address);
return value_to_value_object (val); return value_to_value_object (val);
} }
@ -111,10 +118,11 @@ gdbpy_create_lazy_string_object (CORE_ADDR address, long length,
{ {
lazy_string_object *str_obj = NULL; lazy_string_object *str_obj = NULL;
if (address == 0) if (address == 0 && length != 0)
{ {
PyErr_SetString (PyExc_MemoryError, PyErr_SetString (PyExc_MemoryError,
"Cannot create a lazy string from a GDB-side string."); _("Cannot create a lazy string with address 0x0, " \
"and a non-zero length."));
return NULL; return NULL;
} }

View file

@ -1,3 +1,9 @@
2010-04-08 Phil Muldoon <pmuldoon@redhat.com>
* gdb.python/py-value: Add null string variable.
(test_lazy_string): Test zero length, NULL address lazy
strings.
2010-04-07 H.J. Lu <hongjiu.lu@intel.com> 2010-04-07 H.J. Lu <hongjiu.lu@intel.com>
* gdb.arch/i386-avx.c: New. * gdb.arch/i386-avx.c: New.

View file

@ -59,7 +59,7 @@ main (int argc, char *argv[])
int *p = a; int *p = a;
int i = 2; int i = 2;
int *ptr_i = &i; int *ptr_i = &i;
const char *sn = 0;
s.a = 3; s.a = 3;
s.b = 5; s.b = 5;
u.a = 7; u.a = 7;

View file

@ -267,6 +267,12 @@ proc test_lazy_strings {} {
gdb_py_test_silent_cmd "python lstr = sptr.lazy_string()" "Aquire lazy string" 1 gdb_py_test_silent_cmd "python lstr = sptr.lazy_string()" "Aquire lazy string" 1
gdb_test "python print lstr.type" "const char \*." "Test type name equality" gdb_test "python print lstr.type" "const char \*." "Test type name equality"
gdb_test "python print sptr.type" "const char \*." "Test type name equality" gdb_test "python print sptr.type" "const char \*." "Test type name equality"
gdb_test "print sn" "0x0"
gdb_py_test_silent_cmd "python snptr = gdb.history (0)" "Get value from history" 1
gdb_test "python snstr = snptr.lazy_string(length=5)" ".*Cannot create a lazy string with address.*" "Test lazy string"
gdb_py_test_silent_cmd "python snstr = snptr.lazy_string(length=0)" "Succesfully create a lazy string" 1
gdb_test "python print snstr.length" "0" "Test lazy string length"
gdb_test "python print snstr.address" "0" "Test lazy string address"
} }