1 /* Python interface to values.
3 Copyright (C) 2008, 2009 Free Software Foundation, Inc.
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
21 #include "gdb_assert.h"
24 #include "exceptions.h"
29 /* List of all values which are currently exposed to Python. It is
30 maintained so that when an objfile is discarded, preserve_values
31 can copy the values' types if needed. This is declared
32 unconditionally to reduce the number of uses of HAVE_PYTHON in the
34 /* This variable is unnecessarily initialized to NULL in order to
35 work around a linker bug on MacOS. */
36 struct value
*values_in_python
= NULL
;
40 #include "python-internal.h"
42 /* Even though Python scalar types directly map to host types, we use
43 target types here to remain consistent with the the values system in
44 GDB (which uses target arithmetic). */
46 /* Python's integer type corresponds to C's long type. */
47 #define builtin_type_pyint builtin_type (current_gdbarch)->builtin_long
49 /* Python's float type corresponds to C's double type. */
50 #define builtin_type_pyfloat builtin_type (current_gdbarch)->builtin_double
52 /* Python's long type corresponds to C's long long type. */
53 #define builtin_type_pylong builtin_type (current_gdbarch)->builtin_long_long
55 #define builtin_type_pybool \
56 language_bool_type (current_language, current_gdbarch)
64 /* Called by the Python interpreter when deallocating a value object. */
66 valpy_dealloc (PyObject
*obj
)
68 value_object
*self
= (value_object
*) obj
;
70 value_remove_from_list (&values_in_python
, self
->value
);
72 if (!self
->owned_by_gdb
)
73 value_free (self
->value
);
74 self
->ob_type
->tp_free (self
);
77 /* Called when a new gdb.Value object needs to be allocated. */
79 valpy_new (PyTypeObject
*subtype
, PyObject
*args
, PyObject
*keywords
)
81 struct value
*value
= NULL
; /* Initialize to appease gcc warning. */
82 value_object
*value_obj
;
84 if (PyTuple_Size (args
) != 1)
86 PyErr_SetString (PyExc_TypeError
, _("Value object creation takes only "
91 value_obj
= (value_object
*) subtype
->tp_alloc (subtype
, 1);
92 if (value_obj
== NULL
)
94 PyErr_SetString (PyExc_MemoryError
, _("Could not allocate memory to "
95 "create Value object."));
99 value
= convert_value_from_python (PyTuple_GetItem (args
, 0));
102 subtype
->tp_free (value_obj
);
106 value_obj
->value
= value
;
107 value_obj
->owned_by_gdb
= 0;
108 release_value (value
);
109 value_prepend_to_list (&values_in_python
, value
);
111 return (PyObject
*) value_obj
;
114 /* Given a value of a pointer type, apply the C unary * operator to it. */
116 valpy_dereference (PyObject
*self
, PyObject
*args
)
118 struct value
*res_val
= NULL
; /* Initialize to appease gcc warning. */
119 volatile struct gdb_exception except
;
121 TRY_CATCH (except
, RETURN_MASK_ALL
)
123 res_val
= value_ind (((value_object
*) self
)->value
);
125 GDB_PY_HANDLE_EXCEPTION (except
);
127 return value_to_value_object (res_val
);
130 /* Return "&value". */
132 valpy_address (PyObject
*self
, PyObject
*args
)
134 struct value
*res_val
= NULL
; /* Initialize to appease gcc warning. */
135 volatile struct gdb_exception except
;
137 TRY_CATCH (except
, RETURN_MASK_ALL
)
139 res_val
= value_addr (((value_object
*) self
)->value
);
141 GDB_PY_HANDLE_EXCEPTION (except
);
143 return value_to_value_object (res_val
);
146 /* Implementation of gdb.Value.string ([encoding] [, errors]) -> string
147 Return Unicode string with value contents. If ENCODING is not given,
148 the string is assumed to be encoded in the target's charset. */
150 valpy_string (PyObject
*self
, PyObject
*args
, PyObject
*kw
)
154 struct value
*value
= ((value_object
*) self
)->value
;
155 volatile struct gdb_exception except
;
157 const char *encoding
= NULL
;
158 const char *errors
= NULL
;
159 const char *user_encoding
= NULL
;
160 const char *la_encoding
= NULL
;
161 static char *keywords
[] = { "encoding", "errors" };
163 if (!PyArg_ParseTupleAndKeywords (args
, kw
, "|ss", keywords
,
164 &user_encoding
, &errors
))
167 TRY_CATCH (except
, RETURN_MASK_ALL
)
169 LA_GET_STRING (value
, &buffer
, &length
, &la_encoding
);
171 GDB_PY_HANDLE_EXCEPTION (except
);
173 encoding
= (user_encoding
&& *user_encoding
) ? user_encoding
: la_encoding
;
174 unicode
= PyUnicode_Decode (buffer
, length
, encoding
, errors
);
181 valpy_length (PyObject
*self
)
183 /* We don't support getting the number of elements in a struct / class. */
184 PyErr_SetString (PyExc_NotImplementedError
,
185 "Invalid operation on gdb.Value.");
189 /* Given string name of an element inside structure, return its value
192 valpy_getitem (PyObject
*self
, PyObject
*key
)
194 value_object
*self_value
= (value_object
*) self
;
196 struct value
*idx
= NULL
;
197 struct value
*res_val
= NULL
; /* Initialize to appease gcc warning. */
198 volatile struct gdb_exception except
;
200 if (gdbpy_is_string (key
))
202 field
= python_string_to_host_string (key
);
207 TRY_CATCH (except
, RETURN_MASK_ALL
)
209 struct value
*tmp
= self_value
->value
;
212 res_val
= value_struct_elt (&tmp
, NULL
, field
, 0, NULL
);
215 /* Assume we are attempting an array access, and let the
216 value code throw an exception if the index has an invalid
218 struct value
*idx
= convert_value_from_python (key
);
222 res_val
= value_subscript (tmp
, idx
);
227 GDB_PY_HANDLE_EXCEPTION (except
);
229 return value_to_value_object (res_val
);
233 valpy_setitem (PyObject
*self
, PyObject
*key
, PyObject
*value
)
235 PyErr_Format (PyExc_NotImplementedError
,
236 _("Setting of struct elements is not currently supported."));
240 /* Called by the Python interpreter to obtain string representation
243 valpy_str (PyObject
*self
)
248 struct cleanup
*old_chain
;
250 struct value_print_options opts
;
251 volatile struct gdb_exception except
;
253 get_user_print_options (&opts
);
256 stb
= mem_fileopen ();
257 old_chain
= make_cleanup_ui_file_delete (stb
);
259 TRY_CATCH (except
, RETURN_MASK_ALL
)
261 common_val_print (((value_object
*) self
)->value
, stb
, 0,
262 &opts
, current_language
);
263 s
= ui_file_xstrdup (stb
, &dummy
);
265 GDB_PY_HANDLE_EXCEPTION (except
);
267 do_cleanups (old_chain
);
269 result
= PyUnicode_Decode (s
, strlen (s
), host_charset (), NULL
);
275 /* Implements gdb.Value.is_optimized_out. */
277 valpy_get_is_optimized_out (PyObject
*self
, void *closure
)
279 struct value
*value
= ((value_object
*) self
)->value
;
281 if (value_optimized_out (value
))
302 /* If TYPE is a reference, return the target; otherwise return TYPE. */
303 #define STRIP_REFERENCE(TYPE) \
304 ((TYPE_CODE (TYPE) == TYPE_CODE_REF) ? (TYPE_TARGET_TYPE (TYPE)) : (TYPE))
306 /* Returns a value object which is the result of applying the operation
307 specified by OPCODE to the given arguments. */
309 valpy_binop (enum valpy_opcode opcode
, PyObject
*self
, PyObject
*other
)
311 struct value
*res_val
= NULL
; /* Initialize to appease gcc warning. */
312 volatile struct gdb_exception except
;
314 TRY_CATCH (except
, RETURN_MASK_ALL
)
316 struct value
*arg1
, *arg2
;
318 /* If the gdb.Value object is the second operand, then it will be passed
319 to us as the OTHER argument, and SELF will be an entirely different
320 kind of object, altogether. Because of this, we can't assume self is
321 a gdb.Value object and need to convert it from python as well. */
322 arg1
= convert_value_from_python (self
);
326 arg2
= convert_value_from_python (other
);
334 struct type
*ltype
= value_type (arg1
);
335 struct type
*rtype
= value_type (arg2
);
337 CHECK_TYPEDEF (ltype
);
338 ltype
= STRIP_REFERENCE (ltype
);
339 CHECK_TYPEDEF (rtype
);
340 rtype
= STRIP_REFERENCE (rtype
);
342 if (TYPE_CODE (ltype
) == TYPE_CODE_PTR
)
343 res_val
= value_ptradd (arg1
, arg2
);
344 else if (TYPE_CODE (rtype
) == TYPE_CODE_PTR
)
345 res_val
= value_ptradd (arg2
, arg1
);
347 res_val
= value_binop (arg1
, arg2
, BINOP_ADD
);
352 struct type
*ltype
= value_type (arg1
);
353 struct type
*rtype
= value_type (arg2
);
355 CHECK_TYPEDEF (ltype
);
356 ltype
= STRIP_REFERENCE (ltype
);
357 CHECK_TYPEDEF (rtype
);
358 rtype
= STRIP_REFERENCE (rtype
);
360 if (TYPE_CODE (ltype
) == TYPE_CODE_PTR
)
362 if (TYPE_CODE (rtype
) == TYPE_CODE_PTR
)
363 /* A ptrdiff_t for the target would be preferable
365 res_val
= value_from_longest (builtin_type_pyint
,
366 value_ptrdiff (arg1
, arg2
));
368 res_val
= value_ptrsub (arg1
, arg2
);
371 res_val
= value_binop (arg1
, arg2
, BINOP_SUB
);
375 res_val
= value_binop (arg1
, arg2
, BINOP_MUL
);
378 res_val
= value_binop (arg1
, arg2
, BINOP_DIV
);
381 res_val
= value_binop (arg1
, arg2
, BINOP_REM
);
384 res_val
= value_binop (arg1
, arg2
, BINOP_EXP
);
387 res_val
= value_binop (arg1
, arg2
, BINOP_LSH
);
390 res_val
= value_binop (arg1
, arg2
, BINOP_RSH
);
393 res_val
= value_binop (arg1
, arg2
, BINOP_BITWISE_AND
);
396 res_val
= value_binop (arg1
, arg2
, BINOP_BITWISE_IOR
);
399 res_val
= value_binop (arg1
, arg2
, BINOP_BITWISE_XOR
);
403 GDB_PY_HANDLE_EXCEPTION (except
);
405 return res_val
? value_to_value_object (res_val
) : NULL
;
409 valpy_add (PyObject
*self
, PyObject
*other
)
411 return valpy_binop (VALPY_ADD
, self
, other
);
415 valpy_subtract (PyObject
*self
, PyObject
*other
)
417 return valpy_binop (VALPY_SUB
, self
, other
);
421 valpy_multiply (PyObject
*self
, PyObject
*other
)
423 return valpy_binop (VALPY_MUL
, self
, other
);
427 valpy_divide (PyObject
*self
, PyObject
*other
)
429 return valpy_binop (VALPY_DIV
, self
, other
);
433 valpy_remainder (PyObject
*self
, PyObject
*other
)
435 return valpy_binop (VALPY_REM
, self
, other
);
439 valpy_power (PyObject
*self
, PyObject
*other
, PyObject
*unused
)
441 /* We don't support the ternary form of pow. I don't know how to express
442 that, so let's just throw NotImplementedError to at least do something
444 if (unused
!= Py_None
)
446 PyErr_SetString (PyExc_NotImplementedError
,
447 "Invalid operation on gdb.Value.");
451 return valpy_binop (VALPY_POW
, self
, other
);
455 valpy_negative (PyObject
*self
)
457 struct value
*val
= NULL
;
458 volatile struct gdb_exception except
;
460 TRY_CATCH (except
, RETURN_MASK_ALL
)
462 val
= value_neg (((value_object
*) self
)->value
);
464 GDB_PY_HANDLE_EXCEPTION (except
);
466 return value_to_value_object (val
);
470 valpy_positive (PyObject
*self
)
472 struct value
*copy
= value_copy (((value_object
*) self
)->value
);
474 return value_to_value_object (copy
);
478 valpy_absolute (PyObject
*self
)
480 if (value_less (((value_object
*) self
)->value
,
481 value_from_longest (builtin_type_int8
, 0)))
482 return valpy_negative (self
);
484 return valpy_positive (self
);
487 /* Implements boolean evaluation of gdb.Value. */
489 valpy_nonzero (PyObject
*self
)
491 value_object
*self_value
= (value_object
*) self
;
494 type
= check_typedef (value_type (self_value
->value
));
496 if (is_integral_type (type
) || TYPE_CODE (type
) == TYPE_CODE_PTR
)
497 return !!value_as_long (self_value
->value
);
498 else if (TYPE_CODE (type
) == TYPE_CODE_FLT
)
499 return value_as_double (self_value
->value
) != 0;
500 else if (TYPE_CODE (type
) == TYPE_CODE_DECFLOAT
)
501 return !decimal_is_zero (value_contents (self_value
->value
),
505 PyErr_SetString (PyExc_TypeError
, _("Attempted truth testing on invalid "
511 /* Implements ~ for value objects. */
513 valpy_invert (PyObject
*self
)
515 struct value
*val
= NULL
;
516 volatile struct gdb_exception except
;
518 TRY_CATCH (except
, RETURN_MASK_ALL
)
520 val
= value_complement (((value_object
*) self
)->value
);
522 GDB_PY_HANDLE_EXCEPTION (except
);
524 return value_to_value_object (val
);
527 /* Implements left shift for value objects. */
529 valpy_lsh (PyObject
*self
, PyObject
*other
)
531 return valpy_binop (VALPY_LSH
, self
, other
);
534 /* Implements right shift for value objects. */
536 valpy_rsh (PyObject
*self
, PyObject
*other
)
538 return valpy_binop (VALPY_RSH
, self
, other
);
541 /* Implements bitwise and for value objects. */
543 valpy_and (PyObject
*self
, PyObject
*other
)
545 return valpy_binop (VALPY_BITAND
, self
, other
);
548 /* Implements bitwise or for value objects. */
550 valpy_or (PyObject
*self
, PyObject
*other
)
552 return valpy_binop (VALPY_BITOR
, self
, other
);
555 /* Implements bitwise xor for value objects. */
557 valpy_xor (PyObject
*self
, PyObject
*other
)
559 return valpy_binop (VALPY_BITXOR
, self
, other
);
562 /* Implements comparison operations for value objects. */
564 valpy_richcompare (PyObject
*self
, PyObject
*other
, int op
)
567 struct value
*value_other
;
568 volatile struct gdb_exception except
;
570 if (other
== Py_None
)
571 /* Comparing with None is special. From what I can tell, in Python
572 None is smaller than anything else. */
584 PyErr_SetString (PyExc_NotImplementedError
,
585 "Invalid operation on gdb.Value.");
589 TRY_CATCH (except
, RETURN_MASK_ALL
)
591 value_other
= convert_value_from_python (other
);
592 if (value_other
== NULL
)
597 result
= value_less (((value_object
*) self
)->value
, value_other
);
600 result
= value_less (((value_object
*) self
)->value
, value_other
)
601 || value_equal (((value_object
*) self
)->value
, value_other
);
604 result
= value_equal (((value_object
*) self
)->value
, value_other
);
607 result
= !value_equal (((value_object
*) self
)->value
, value_other
);
610 result
= value_less (value_other
, ((value_object
*) self
)->value
);
613 result
= value_less (value_other
, ((value_object
*) self
)->value
)
614 || value_equal (((value_object
*) self
)->value
, value_other
);
618 PyErr_SetString (PyExc_NotImplementedError
,
619 "Invalid operation on gdb.Value.");
623 GDB_PY_HANDLE_EXCEPTION (except
);
631 /* Helper function to determine if a type is "int-like". */
633 is_intlike (struct type
*type
, int ptr_ok
)
635 CHECK_TYPEDEF (type
);
636 return (TYPE_CODE (type
) == TYPE_CODE_INT
637 || TYPE_CODE (type
) == TYPE_CODE_ENUM
638 || TYPE_CODE (type
) == TYPE_CODE_BOOL
639 || TYPE_CODE (type
) == TYPE_CODE_CHAR
640 || (ptr_ok
&& TYPE_CODE (type
) == TYPE_CODE_PTR
));
643 /* Implements conversion to int. */
645 valpy_int (PyObject
*self
)
647 struct value
*value
= ((value_object
*) self
)->value
;
648 struct type
*type
= value_type (value
);
650 volatile struct gdb_exception except
;
652 CHECK_TYPEDEF (type
);
653 if (!is_intlike (type
, 0))
655 PyErr_SetString (PyExc_RuntimeError
, "cannot convert value to int");
659 TRY_CATCH (except
, RETURN_MASK_ALL
)
661 l
= value_as_long (value
);
663 GDB_PY_HANDLE_EXCEPTION (except
);
665 return PyInt_FromLong (l
);
668 /* Implements conversion to long. */
670 valpy_long (PyObject
*self
)
672 struct value
*value
= ((value_object
*) self
)->value
;
673 struct type
*type
= value_type (value
);
675 volatile struct gdb_exception except
;
677 if (!is_intlike (type
, 1))
679 PyErr_SetString (PyExc_RuntimeError
, "cannot convert value to long");
683 TRY_CATCH (except
, RETURN_MASK_ALL
)
685 l
= value_as_long (value
);
687 GDB_PY_HANDLE_EXCEPTION (except
);
689 return PyLong_FromLong (l
);
692 /* Implements conversion to float. */
694 valpy_float (PyObject
*self
)
696 struct value
*value
= ((value_object
*) self
)->value
;
697 struct type
*type
= value_type (value
);
699 volatile struct gdb_exception except
;
701 CHECK_TYPEDEF (type
);
702 if (TYPE_CODE (type
) != TYPE_CODE_FLT
)
704 PyErr_SetString (PyExc_RuntimeError
, "cannot convert value to float");
708 TRY_CATCH (except
, RETURN_MASK_ALL
)
710 d
= value_as_double (value
);
712 GDB_PY_HANDLE_EXCEPTION (except
);
714 return PyFloat_FromDouble (d
);
717 /* Returns an object for a value which is released from the all_values chain,
718 so its lifetime is not bound to the execution of a command. */
720 value_to_value_object (struct value
*val
)
722 value_object
*val_obj
;
724 val_obj
= PyObject_New (value_object
, &value_object_type
);
727 val_obj
->value
= val
;
728 val_obj
->owned_by_gdb
= 0;
730 value_prepend_to_list (&values_in_python
, val
);
733 return (PyObject
*) val_obj
;
736 /* Try to convert a Python value to a gdb value. If the value cannot
737 be converted, set a Python exception and return NULL. */
740 convert_value_from_python (PyObject
*obj
)
742 struct value
*value
= NULL
; /* -Wall */
743 PyObject
*target_str
, *unicode_str
;
745 volatile struct gdb_exception except
;
748 gdb_assert (obj
!= NULL
);
750 TRY_CATCH (except
, RETURN_MASK_ALL
)
752 if (PyBool_Check (obj
))
754 cmp
= PyObject_IsTrue (obj
);
756 value
= value_from_longest (builtin_type_pybool
, cmp
);
758 else if (PyInt_Check (obj
))
760 long l
= PyInt_AsLong (obj
);
762 if (! PyErr_Occurred ())
763 value
= value_from_longest (builtin_type_pyint
, l
);
765 else if (PyLong_Check (obj
))
767 LONGEST l
= PyLong_AsLongLong (obj
);
769 if (! PyErr_Occurred ())
770 value
= value_from_longest (builtin_type_pylong
, l
);
772 else if (PyFloat_Check (obj
))
774 double d
= PyFloat_AsDouble (obj
);
776 if (! PyErr_Occurred ())
777 value
= value_from_double (builtin_type_pyfloat
, d
);
779 else if (gdbpy_is_string (obj
))
783 s
= python_string_to_target_string (obj
);
786 old
= make_cleanup (xfree
, s
);
787 value
= value_from_string (s
);
791 else if (PyObject_TypeCheck (obj
, &value_object_type
))
792 value
= value_copy (((value_object
*) obj
)->value
);
794 PyErr_Format (PyExc_TypeError
, _("Could not convert Python object: %s"),
795 PyString_AsString (PyObject_Str (obj
)));
797 if (except
.reason
< 0)
799 PyErr_Format (except
.reason
== RETURN_QUIT
800 ? PyExc_KeyboardInterrupt
: PyExc_RuntimeError
,
801 "%s", except
.message
);
808 /* Returns value object in the ARGth position in GDB's history. */
810 gdbpy_history (PyObject
*self
, PyObject
*args
)
813 struct value
*res_val
= NULL
; /* Initialize to appease gcc warning. */
814 volatile struct gdb_exception except
;
816 if (!PyArg_ParseTuple (args
, "i", &i
))
819 TRY_CATCH (except
, RETURN_MASK_ALL
)
821 res_val
= access_value_history (i
);
823 GDB_PY_HANDLE_EXCEPTION (except
);
825 return value_to_value_object (res_val
);
829 gdbpy_initialize_values (void)
831 if (PyType_Ready (&value_object_type
) < 0)
834 Py_INCREF (&value_object_type
);
835 PyModule_AddObject (gdb_module
, "Value", (PyObject
*) &value_object_type
);
837 values_in_python
= NULL
;
840 static PyGetSetDef value_object_getset
[] = {
841 { "is_optimized_out", valpy_get_is_optimized_out
, NULL
,
842 "Boolean telling whether the value is optimized out (i.e., not available).",
844 {NULL
} /* Sentinel */
847 static PyMethodDef value_object_methods
[] = {
848 { "address", valpy_address
, METH_NOARGS
, "Return the address of the value." },
849 { "dereference", valpy_dereference
, METH_NOARGS
, "Dereferences the value." },
850 { "string", (PyCFunction
) valpy_string
, METH_VARARGS
| METH_KEYWORDS
,
851 "string ([encoding] [, errors]) -> string\n\
852 Return Unicode string representation of the value." },
853 {NULL
} /* Sentinel */
856 static PyNumberMethods value_object_as_number
= {
862 NULL
, /* nb_divmod */
863 valpy_power
, /* nb_power */
864 valpy_negative
, /* nb_negative */
865 valpy_positive
, /* nb_positive */
866 valpy_absolute
, /* nb_absolute */
867 valpy_nonzero
, /* nb_nonzero */
868 valpy_invert
, /* nb_invert */
869 valpy_lsh
, /* nb_lshift */
870 valpy_rsh
, /* nb_rshift */
871 valpy_and
, /* nb_and */
872 valpy_xor
, /* nb_xor */
873 valpy_or
, /* nb_or */
874 NULL
, /* nb_coerce */
875 valpy_int
, /* nb_int */
876 valpy_long
, /* nb_long */
877 valpy_float
, /* nb_float */
882 static PyMappingMethods value_object_as_mapping
= {
888 PyTypeObject value_object_type
= {
889 PyObject_HEAD_INIT (NULL
)
891 "gdb.Value", /*tp_name*/
892 sizeof (value_object
), /*tp_basicsize*/
894 valpy_dealloc
, /*tp_dealloc*/
900 &value_object_as_number
, /*tp_as_number*/
901 0, /*tp_as_sequence*/
902 &value_object_as_mapping
, /*tp_as_mapping*/
905 valpy_str
, /*tp_str*/
909 Py_TPFLAGS_DEFAULT
| Py_TPFLAGS_CHECKTYPES
, /*tp_flags*/
910 "GDB value object", /* tp_doc */
913 valpy_richcompare
, /* tp_richcompare */
914 0, /* tp_weaklistoffset */
917 value_object_methods
, /* tp_methods */
919 value_object_getset
, /* tp_getset */
922 0, /* tp_descr_get */
923 0, /* tp_descr_set */
924 0, /* tp_dictoffset */
927 valpy_new
/* tp_new */
930 #endif /* HAVE_PYTHON */