diff options
author | Joel Brobecker <brobecker@gnat.com> | 2009-09-09 17:45:42 +0000 |
---|---|---|
committer | Joel Brobecker <brobecker@gnat.com> | 2009-09-09 17:45:42 +0000 |
commit | 5172aecbd2b65e71aedbd21c46253ca6a20227aa (patch) | |
tree | 879124432741656573e3a6f6a4c7b3a9dfb2ca8a /gdb/python/python-utils.c | |
parent | b83e9eb71cb4a21b31f8f47782da821a5a0ddb32 (diff) | |
download | gdb-5172aecbd2b65e71aedbd21c46253ca6a20227aa.zip gdb-5172aecbd2b65e71aedbd21c46253ca6a20227aa.tar.gz gdb-5172aecbd2b65e71aedbd21c46253ca6a20227aa.tar.bz2 |
Checking in this patch for Thiago: Rename python-* files into py-*,
more 8+3 friendly.
gdb/
* Makefile.in (py-cmd.o): Renamed from python-cmd.o. Updated
references.
(py-frame.o): Renamed from python-frame.o. Updated references.
(py-function.o): Renamed from python-function.o. Updated references.
(py-objfile.o): Renamed from python-objfile.o. Updated references.
(py-prettyprint.o): Renamed from python-prettyprint.o. Updated
+references.
(py-type.o): Renamed from python-type.o. Updated references.
(py-utils.o): Renamed from python-utils.o. Updated references.
(py-value.o): Renamed from python-value.o. Updated references.
* py-cmd.o: Renamed from python-cmd.o.
* py-frame.o: Renamed from python-frame.o.
* py-function.o: Renamed from python-function.o.
* py-objfile.o: Renamed from python-objfile.o.
* py-prettyprint.o: Renamed from python-prettyprint.o.
* py-type.o: Renamed from python-type.o.
* py-utils.o: Renamed from python-utils.o.
* py-value.o: Renamed from python-value.o.
gdb/testsuite/
* gdb.python/Makefile.in (EXECUTABLES): Adjust to new executable
names, add missing ones.
* gdb.python/py-cmd.exp: Rename from python-cmd.exp.
* gdb.python/py-frame.c: Rename from python-frame.c.
* gdb.python/py-frame.exp: Rename from python-frame.exp. Adjust
testfile name.
* gdb.python/py-function.exp: Rename from python-function.exp.
* gdb.python/py-mi.exp: Rename from python-mi.exp. Adjust
testfile name.
* gdb.python/py-prettyprint.c: Rename from python-prettyprint.c.
* gdb.python/py-prettyprint.exp: Rename from python-prettyprint.exp.
Adjust testfile name.
* gdb.python/py-prettyprint.py: Rename from python-prettyprint.py.
* gdb.python/py-template.cc: Rename from python-template.cc.
* gdb.python/py-template.exp: Rename from python-template.exp.
Adjust testfile name.
* gdb.python/py-value.c: Rename from python-value.c.
* gdb.python/py-value.exp: Rename from python-value.exp. Adjust
testfile name.
Diffstat (limited to 'gdb/python/python-utils.c')
-rw-r--r-- | gdb/python/python-utils.c | 221 |
1 files changed, 0 insertions, 221 deletions
diff --git a/gdb/python/python-utils.c b/gdb/python/python-utils.c deleted file mode 100644 index 49c0437..0000000 --- a/gdb/python/python-utils.c +++ /dev/null @@ -1,221 +0,0 @@ -/* General utility routines for GDB/Python. - - Copyright (C) 2008, 2009 Free Software Foundation, Inc. - - This file is part of GDB. - - 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/>. */ - -#include "defs.h" -#include "charset.h" -#include "python-internal.h" - - -/* This is a cleanup function which decrements the refcount on a - Python object. */ - -static void -py_decref (void *p) -{ - PyObject *py = p; - /* Note that we need the extra braces in this 'if' to avoid a - warning from gcc. */ - if (py) - { - Py_DECREF (py); - } -} - -/* Return a new cleanup which will decrement the Python object's - refcount when run. */ - -struct cleanup * -make_cleanup_py_decref (PyObject *py) -{ - return make_cleanup (py_decref, (void *) py); -} - -/* Converts a Python 8-bit string to a unicode string object. Assumes the - 8-bit string is in the host charset. If an error occurs during conversion, - returns NULL with a python exception set. - - As an added bonus, the functions accepts a unicode string and returns it - right away, so callers don't need to check which kind of string they've - got. - - If the given object is not one of the mentioned string types, NULL is - returned, with the TypeError python exception set. */ -PyObject * -python_string_to_unicode (PyObject *obj) -{ - PyObject *unicode_str; - - /* If obj is already a unicode string, just return it. - I wish life was always that simple... */ - if (PyUnicode_Check (obj)) - { - unicode_str = obj; - Py_INCREF (obj); - } - - else if (PyString_Check (obj)) - unicode_str = PyUnicode_FromEncodedObject (obj, host_charset (), NULL); - else - { - PyErr_SetString (PyExc_TypeError, - _("Expected a string or unicode object.")); - unicode_str = NULL; - } - - return unicode_str; -} - -/* Returns a newly allocated string with the contents of the given unicode - string object converted to CHARSET. If an error occurs during the - conversion, NULL will be returned and a python exception will be set. - - The caller is responsible for xfree'ing the string. */ -static char * -unicode_to_encoded_string (PyObject *unicode_str, const char *charset) -{ - char *result; - PyObject *string; - - /* Translate string to named charset. */ - string = PyUnicode_AsEncodedString (unicode_str, charset, NULL); - if (string == NULL) - return NULL; - - result = xstrdup (PyString_AsString (string)); - - Py_DECREF (string); - - return result; -} - -/* Returns a PyObject with the contents of the given unicode string - object converted to a named charset. If an error occurs during - the conversion, NULL will be returned and a python exception will - be set. */ -static PyObject * -unicode_to_encoded_python_string (PyObject *unicode_str, const char *charset) -{ - PyObject *string; - - /* Translate string to named charset. */ - string = PyUnicode_AsEncodedString (unicode_str, charset, NULL); - if (string == NULL) - return NULL; - - return string; -} - -/* Returns a newly allocated string with the contents of the given unicode - string object converted to the target's charset. If an error occurs during - the conversion, NULL will be returned and a python exception will be set. - - The caller is responsible for xfree'ing the string. */ -char * -unicode_to_target_string (PyObject *unicode_str) -{ - return unicode_to_encoded_string (unicode_str, target_charset ()); -} - -/* Returns a PyObject with the contents of the given unicode string - object converted to the target's charset. If an error occurs - during the conversion, NULL will be returned and a python exception - will be set. */ -PyObject * -unicode_to_target_python_string (PyObject *unicode_str) -{ - return unicode_to_encoded_python_string (unicode_str, target_charset ()); -} - -/* Converts a python string (8-bit or unicode) to a target string in - the target's charset. Returns NULL on error, with a python exception set. - - The caller is responsible for xfree'ing the string. */ -char * -python_string_to_target_string (PyObject *obj) -{ - PyObject *str; - char *result; - - str = python_string_to_unicode (obj); - if (str == NULL) - return NULL; - - result = unicode_to_target_string (str); - Py_DECREF (str); - return result; -} - -/* Converts a python string (8-bit or unicode) to a target string in the - target's charset. Returns NULL on error, with a python exception - set. */ -PyObject * -python_string_to_target_python_string (PyObject *obj) -{ - PyObject *str; - PyObject *result; - - str = python_string_to_unicode (obj); - if (str == NULL) - return NULL; - - result = unicode_to_target_python_string (str); - Py_DECREF (str); - return result; -} - -/* Converts a python string (8-bit or unicode) to a target string in - the host's charset. Returns NULL on error, with a python exception set. - - The caller is responsible for xfree'ing the string. */ -char * -python_string_to_host_string (PyObject *obj) -{ - PyObject *str; - char *result; - - str = python_string_to_unicode (obj); - if (str == NULL) - return NULL; - - result = unicode_to_encoded_string (str, host_charset ()); - Py_DECREF (str); - return result; -} - -/* Converts a target string of LENGTH bytes in the target's charset to a - Python Unicode string. If LENGTH is -1, convert until a null byte is found. - - Returns NULL on error, with a python exception set. */ -PyObject * -target_string_to_unicode (const gdb_byte *str, int length) -{ - if (length == -1) - length = strlen (str); - - return PyUnicode_Decode (str, length, target_charset (), NULL); -} - -/* Return true if OBJ is a Python string or unicode object, false - otherwise. */ - -int -gdbpy_is_string (PyObject *obj) -{ - return PyString_Check (obj) || PyUnicode_Check (obj); -} |