forked from Imagelibrary/binutils-gdb
PR python/18438
gdb/ChangeLog: * python/py-lazy-string.c (stpy_convert_to_value): Use gdbpy_gdb_memory_error not PyExc_MemoryError. (gdbpy_create_lazy_string_object): Ditto. gdb/testsuite/ChangeLog: * gdb.python/py-lazy-string.c: New file. * gdb.python/py-lazy-string.exp: New file. * gdb.python/py-prettyprint.c (lazystring) <len>: New member. (main): Update. Add estring3. * gdb.python/py-prettyprint.exp: Add tests for strings at address 0. * gdb.python/py-prettyprint.py (pp_ls): Handle length.
This commit is contained in:
@@ -1,3 +1,10 @@
|
|||||||
|
2015-05-26 Doug Evans <dje@google.com>
|
||||||
|
|
||||||
|
PR python/18438
|
||||||
|
* python/py-lazy-string.c (stpy_convert_to_value): Use
|
||||||
|
gdbpy_gdb_memory_error not PyExc_MemoryError.
|
||||||
|
(gdbpy_create_lazy_string_object): Ditto.
|
||||||
|
|
||||||
2015-05-26 Andrew Burgess <andrew.burgess@embecosm.com>
|
2015-05-26 Andrew Burgess <andrew.burgess@embecosm.com>
|
||||||
|
|
||||||
* tui/tui-regs.c (tui_reg_next_command): Compare against NULL.
|
* tui/tui-regs.c (tui_reg_next_command): Compare against NULL.
|
||||||
|
|||||||
@@ -99,7 +99,7 @@ stpy_convert_to_value (PyObject *self, PyObject *args)
|
|||||||
|
|
||||||
if (self_string->address == 0)
|
if (self_string->address == 0)
|
||||||
{
|
{
|
||||||
PyErr_SetString (PyExc_MemoryError,
|
PyErr_SetString (gdbpy_gdb_memory_error,
|
||||||
_("Cannot create a value from NULL."));
|
_("Cannot create a value from NULL."));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@@ -133,7 +133,7 @@ gdbpy_create_lazy_string_object (CORE_ADDR address, long length,
|
|||||||
|
|
||||||
if (address == 0 && length != 0)
|
if (address == 0 && length != 0)
|
||||||
{
|
{
|
||||||
PyErr_SetString (PyExc_MemoryError,
|
PyErr_SetString (gdbpy_gdb_memory_error,
|
||||||
_("Cannot create a lazy string with address 0x0, " \
|
_("Cannot create a lazy string with address 0x0, " \
|
||||||
"and a non-zero length."));
|
"and a non-zero length."));
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|||||||
@@ -1,3 +1,12 @@
|
|||||||
|
2015-05-26 Doug Evans <dje@google.com>
|
||||||
|
|
||||||
|
* gdb.python/py-lazy-string.c: New file.
|
||||||
|
* gdb.python/py-lazy-string.exp: New file.
|
||||||
|
* gdb.python/py-prettyprint.c (lazystring) <len>: New member.
|
||||||
|
(main): Update. Add estring3.
|
||||||
|
* gdb.python/py-prettyprint.exp: Add tests for strings at address 0.
|
||||||
|
* gdb.python/py-prettyprint.py (pp_ls): Handle length.
|
||||||
|
|
||||||
2015-05-26 Omair Javaid <omair.javaid@linaro.org>
|
2015-05-26 Omair Javaid <omair.javaid@linaro.org>
|
||||||
Yao Qi <yao.qi@linaro.org>
|
Yao Qi <yao.qi@linaro.org>
|
||||||
|
|
||||||
|
|||||||
24
gdb/testsuite/gdb.python/py-lazy-string.c
Normal file
24
gdb/testsuite/gdb.python/py-lazy-string.c
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
/* This testcase is part of GDB, the GNU debugger.
|
||||||
|
|
||||||
|
Copyright 2015 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
int
|
||||||
|
main ()
|
||||||
|
{
|
||||||
|
const char *null = 0;
|
||||||
|
|
||||||
|
return 0; /* break here */
|
||||||
|
}
|
||||||
42
gdb/testsuite/gdb.python/py-lazy-string.exp
Normal file
42
gdb/testsuite/gdb.python/py-lazy-string.exp
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
# Copyright (C) 2015 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
# This file is part of the GDB testsuite. It tests lazy string support
|
||||||
|
# not tested by py-prettyprinter.exp.
|
||||||
|
|
||||||
|
load_lib gdb-python.exp
|
||||||
|
|
||||||
|
standard_testfile
|
||||||
|
|
||||||
|
if {[prepare_for_testing $testfile.exp $testfile $srcfile {debug c++}]} {
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Skip all tests if Python scripting is not enabled.
|
||||||
|
if { [skip_python_tests] } { continue }
|
||||||
|
|
||||||
|
if ![runto_main ] {
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
|
||||||
|
gdb_breakpoint [gdb_get_line_number "break here"]
|
||||||
|
gdb_continue_to_breakpoint "break here"
|
||||||
|
|
||||||
|
gdb_test_no_output "python null = gdb.parse_and_eval(\"null\")"
|
||||||
|
|
||||||
|
gdb_test "python print null.lazy_string(length=0).value()" \
|
||||||
|
"gdb.MemoryError: Cannot create a value from NULL.*Error while executing Python code."
|
||||||
|
gdb_test "python print null.lazy_string(length=3).value()" \
|
||||||
|
"gdb.MemoryError: Cannot create a lazy string with address 0x0, and a non-zero length.*Error while executing Python code."
|
||||||
@@ -42,6 +42,8 @@ struct ns {
|
|||||||
|
|
||||||
struct lazystring {
|
struct lazystring {
|
||||||
const char *lazy_str;
|
const char *lazy_str;
|
||||||
|
/* If -1, don't pass length to gdb.lazy_string(). */
|
||||||
|
int len;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct hint_error {
|
struct hint_error {
|
||||||
@@ -270,7 +272,7 @@ main ()
|
|||||||
nostring_type nstype, nstype2;
|
nostring_type nstype, nstype2;
|
||||||
struct memory_error me;
|
struct memory_error me;
|
||||||
struct ns ns, ns2;
|
struct ns ns, ns2;
|
||||||
struct lazystring estring, estring2;
|
struct lazystring estring, estring2, estring3;
|
||||||
struct hint_error hint_error;
|
struct hint_error hint_error;
|
||||||
struct children_as_list children_as_list;
|
struct children_as_list children_as_list;
|
||||||
|
|
||||||
@@ -295,10 +297,15 @@ main ()
|
|||||||
ns2.null_str = NULL;
|
ns2.null_str = NULL;
|
||||||
ns2.length = 20;
|
ns2.length = 20;
|
||||||
|
|
||||||
estring.lazy_str = "embedded x\201\202\203\204" ;
|
estring.lazy_str = "embedded x\201\202\203\204";
|
||||||
|
estring.len = -1;
|
||||||
|
|
||||||
/* Incomplete UTF-8, but ok Latin-1. */
|
/* Incomplete UTF-8, but ok Latin-1. */
|
||||||
estring2.lazy_str = "embedded x\302";
|
estring2.lazy_str = "embedded x\302";
|
||||||
|
estring2.len = -1;
|
||||||
|
|
||||||
|
estring3.lazy_str = NULL;
|
||||||
|
estring3.len = 42;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
S cps;
|
S cps;
|
||||||
|
|||||||
@@ -92,6 +92,8 @@ proc run_lang_tests {exefile lang} {
|
|||||||
gdb_test "print cstring" " = \"const string\""
|
gdb_test "print cstring" " = \"const string\""
|
||||||
|
|
||||||
gdb_test "print estring" " = \"embedded x\\\\201\\\\202\\\\203\\\\204\""
|
gdb_test "print estring" " = \"embedded x\\\\201\\\\202\\\\203\\\\204\""
|
||||||
|
gdb_test "print estring3" \
|
||||||
|
" = <error reading variable: Cannot create a lazy string with address 0x0, and a non-zero length.>"
|
||||||
|
|
||||||
gdb_test_no_output "python pp_ls_encoding = 'UTF-8'"
|
gdb_test_no_output "python pp_ls_encoding = 'UTF-8'"
|
||||||
gdb_test "print estring2" "\"embedded \", <incomplete sequence \\\\302>"
|
gdb_test "print estring2" "\"embedded \", <incomplete sequence \\\\302>"
|
||||||
|
|||||||
@@ -152,8 +152,18 @@ class pp_ls (object):
|
|||||||
self.val = val
|
self.val = val
|
||||||
|
|
||||||
def to_string(self):
|
def to_string(self):
|
||||||
|
length = self.val['len']
|
||||||
if pp_ls_encoding is not None:
|
if pp_ls_encoding is not None:
|
||||||
return self.val['lazy_str'].lazy_string(encoding = pp_ls_encoding)
|
if length >= 0:
|
||||||
|
return self.val['lazy_str'].lazy_string(
|
||||||
|
encoding = pp_ls_encoding,
|
||||||
|
length = length)
|
||||||
|
else:
|
||||||
|
return self.val['lazy_str'].lazy_string(
|
||||||
|
encoding = pp_ls_encoding)
|
||||||
|
else:
|
||||||
|
if length >= 0:
|
||||||
|
return self.val['lazy_str'].lazy_string(length = length)
|
||||||
else:
|
else:
|
||||||
return self.val['lazy_str'].lazy_string()
|
return self.val['lazy_str'].lazy_string()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user