2009-12-08 Phil Muldoon <pmuldoon@redhat.com>
PR python/10804 * python/py-type.c (typy_range): New Function. 2009-12-08 Phil Muldoon <pmuldoon@redhat.com> * gdb.python/py-type.exp (test_range): New test. 2009-12-08 Phil Muldoon <pmuldoon@redhat.com> * gdb.texinfo (Types In Python): Describe range function.
This commit is contained in:
parent
40b5c9fb4b
commit
361ae04250
@ -1,3 +1,9 @@
|
||||
2009-12-08 Phil Muldoon <pmuldoon@redhat.com>
|
||||
|
||||
PR python/10804
|
||||
|
||||
* python/py-type.c (typy_range): New Function.
|
||||
|
||||
2009-12-07 Doug Evans <dje@google.com>
|
||||
|
||||
* charset.c: Include environ.h.
|
||||
|
@ -1,3 +1,7 @@
|
||||
2009-12-08 Phil Muldoon <pmuldoon@redhat.com>
|
||||
|
||||
* gdb.texinfo (Types In Python): Describe range function.
|
||||
|
||||
2009-12-03 Richard Ward <richard.j.ward1@googlemail.com>
|
||||
|
||||
* gdb.texinfo (Types In Python): Describe "is_base_class".
|
||||
|
@ -19654,6 +19654,13 @@ variant of this type. That is, the result is neither @code{const} nor
|
||||
@code{volatile}.
|
||||
@end defmethod
|
||||
|
||||
@defmethod Type range
|
||||
Return a Python @code{Tuple} object that contains two elements: the
|
||||
low bound of the argument type and the high bound of that type. If
|
||||
the type does not have a range, @value{GDBN} will raise a
|
||||
@code{RuntimeError} exception.
|
||||
@end defmethod
|
||||
|
||||
@defmethod Type reference
|
||||
Return a new @code{gdb.Type} object which represents a reference to this
|
||||
type.
|
||||
|
@ -273,6 +273,70 @@ typy_pointer (PyObject *self, PyObject *args)
|
||||
return type_to_type_object (type);
|
||||
}
|
||||
|
||||
/* Return the range of a type represented by SELF. The return type is
|
||||
a tuple. The first element of the tuple contains the low bound,
|
||||
while the second element of the tuple contains the high bound. */
|
||||
static PyObject *
|
||||
typy_range (PyObject *self, PyObject *args)
|
||||
{
|
||||
struct type *type = ((type_object *) self)->type;
|
||||
PyObject *result;
|
||||
PyObject *low_bound = NULL, *high_bound = NULL;
|
||||
LONGEST low, high;
|
||||
|
||||
if (TYPE_CODE (type) != TYPE_CODE_ARRAY
|
||||
&& TYPE_CODE (type) != TYPE_CODE_STRING
|
||||
&& TYPE_CODE (type) != TYPE_CODE_RANGE)
|
||||
{
|
||||
PyErr_SetString (PyExc_RuntimeError,
|
||||
"This type does not have a range.");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
switch (TYPE_CODE (type))
|
||||
{
|
||||
case TYPE_CODE_ARRAY:
|
||||
case TYPE_CODE_STRING:
|
||||
low = TYPE_LOW_BOUND (TYPE_INDEX_TYPE (type));
|
||||
high = TYPE_HIGH_BOUND (TYPE_INDEX_TYPE (type));
|
||||
break;
|
||||
case TYPE_CODE_RANGE:
|
||||
low = TYPE_LOW_BOUND (type);
|
||||
high = TYPE_HIGH_BOUND (type);
|
||||
break;
|
||||
}
|
||||
|
||||
low_bound = PyLong_FromLong (low);
|
||||
if (!low_bound)
|
||||
goto failarg;
|
||||
|
||||
high_bound = PyLong_FromLong (high);
|
||||
if (!high_bound)
|
||||
goto failarg;
|
||||
|
||||
result = PyTuple_New (2);
|
||||
if (!result)
|
||||
goto failarg;
|
||||
|
||||
if (PyTuple_SetItem (result, 0, low_bound) != 0)
|
||||
{
|
||||
Py_DECREF (result);
|
||||
goto failarg;
|
||||
}
|
||||
if (PyTuple_SetItem (result, 1, high_bound) != 0)
|
||||
{
|
||||
Py_DECREF (high_bound);
|
||||
Py_DECREF (result);
|
||||
return NULL;
|
||||
}
|
||||
return result;
|
||||
|
||||
failarg:
|
||||
Py_XDECREF (high_bound);
|
||||
Py_XDECREF (low_bound);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Return a Type object which represents a reference to SELF. */
|
||||
static PyObject *
|
||||
typy_reference (PyObject *self, PyObject *args)
|
||||
@ -699,6 +763,9 @@ Each field is a dictionary." },
|
||||
{ "pointer", typy_pointer, METH_NOARGS,
|
||||
"pointer () -> Type\n\
|
||||
Return a type of pointer to this type." },
|
||||
{ "range", typy_range, METH_NOARGS,
|
||||
"range () -> tuple\n\
|
||||
Return a tuple containing the lower and upper range for this type."},
|
||||
{ "reference", typy_reference, METH_NOARGS,
|
||||
"reference () -> Type\n\
|
||||
Return a type of reference to this type." },
|
||||
|
@ -1,3 +1,7 @@
|
||||
2009-12-08 Phil Muldoon <pmuldoon@redhat.com>
|
||||
|
||||
* gdb.python/py-type.exp (test_range): New test.
|
||||
|
||||
2009-12-03 Phil Muldoon <pmuldoon@redhat.com>
|
||||
|
||||
PR python/10805
|
||||
|
@ -102,6 +102,29 @@ proc test_base_class {} {
|
||||
gdb_test "python print fields\[1\].is_base_class" "False" "Check base class"
|
||||
}
|
||||
|
||||
proc test_range {} {
|
||||
|
||||
# Test a valid range request.
|
||||
gdb_py_test_silent_cmd "print ar" "print value" 1
|
||||
gdb_py_test_silent_cmd "python ar = gdb.history (0)" "get value from history" 1
|
||||
gdb_test "python print len(ar.type.range())" "2" "Check correct tuple length"
|
||||
gdb_test "python print ar.type.range()\[0\]" "0" "Check low range"
|
||||
gdb_test "python print ar.type.range()\[1\]" "1" "Check high range"
|
||||
|
||||
# Test a range request on a ranged type.
|
||||
gdb_py_test_silent_cmd "print ar" "print value" 1
|
||||
gdb_py_test_silent_cmd "python ar = gdb.history (0)" "get value from history" 1
|
||||
gdb_py_test_silent_cmd "python fields = ar.type.fields()" "get fields" 1
|
||||
gdb_test "python print fields\[0\].type.range()\[0\]" "0" "Check range type low bound"
|
||||
gdb_test "python print fields\[0\].type.range()\[1\]" "1" "Check range type high bound"
|
||||
|
||||
# Test where a range does not exist.
|
||||
gdb_py_test_silent_cmd "print st" "print value" 1
|
||||
gdb_py_test_silent_cmd "python st = gdb.history (0)" "get value from history" 1
|
||||
gdb_test "python print st.type.range()" "RuntimeError: This type does not have a range.*" "Check range for non ranged type."
|
||||
}
|
||||
|
||||
|
||||
# Perform C Tests.
|
||||
build_inferior "c"
|
||||
restart_gdb "break to inspect struct and array."
|
||||
@ -112,3 +135,4 @@ build_inferior "c++"
|
||||
restart_gdb "break to inspect struct and array."
|
||||
test_fields "c++"
|
||||
test_base_class
|
||||
test_range
|
||||
|
Loading…
x
Reference in New Issue
Block a user