summaryrefslogtreecommitdiff
path: root/gdb/p-lang.c
diff options
context:
space:
mode:
authorPierre Muller <muller@ics.u-strasbg.fr>2001-11-09 09:48:09 +0000
committerPierre Muller <muller@ics.u-strasbg.fr>2001-11-09 09:48:09 +0000
commit6a129d4f23cd565a7d606542ed9253f522388de5 (patch)
tree856a9fb029d9e929c4d874ea41040f8edc8105cc /gdb/p-lang.c
parent458d424149528912ee72f6b9b9a2afd578a17715 (diff)
downloadgdb-6a129d4f23cd565a7d606542ed9253f522388de5.tar.gz
2001-11-06 Pierre Muller <muller@ics.u-strasbg.fr>
* p-lang.c (is_pascal_string_type): New function to determine if a type is a string type. * p-lang.h: Add prototype for is_pascal_string_type. * p-valprint.c (pascal_val_print) : Use is_pascal_string_type function to display strings nicely.
Diffstat (limited to 'gdb/p-lang.c')
-rw-r--r--gdb/p-lang.c52
1 files changed, 50 insertions, 2 deletions
diff --git a/gdb/p-lang.c b/gdb/p-lang.c
index 93dd2548f67..b5ad5801aab 100644
--- a/gdb/p-lang.c
+++ b/gdb/p-lang.c
@@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
-/* This file is derived from p-lang.c */
+/* This file is derived from c-lang.c */
#include "defs.h"
#include "symtab.h"
@@ -27,8 +27,56 @@
#include "language.h"
#include "p-lang.h"
#include "valprint.h"
-
+#include <ctype.h>
+
extern void _initialize_pascal_language (void);
+
+
+/* Determines if type TYPE is a pascal string type.
+ Returns 1 if the type is a known pascal type
+ This function is used by p-valprint.c code to allow better string display.
+ If it is a pascal string type, then it also sets info needed
+ to get the length and the data of the string
+ length_pos, length_size and string_pos are given in bytes.
+ char_size gives the element size in bytes.
+ FIXME: if the position or the size of these fields
+ are not multiple of TARGET_CHAR_BIT then the results are wrong
+ but this does not happen for Free Pascal nor for GPC. */
+int
+is_pascal_string_type (struct type *type,int *length_pos,
+ int * length_size, int *string_pos, int *char_size)
+{
+ if (TYPE_CODE (type) == TYPE_CODE_STRUCT)
+ {
+ /* Old Borland type pascal strings from Free Pascal Compiler. */
+ /* Two fields: length and st. */
+ if (TYPE_NFIELDS (type) == 2
+ && strcmp (TYPE_FIELDS (type)[0].name, "length") == 0
+ && strcmp (TYPE_FIELDS (type)[1].name, "st") == 0)
+ {
+ *length_pos = TYPE_FIELD_BITPOS (type, 0) / TARGET_CHAR_BIT;
+ *length_size = TYPE_FIELD_TYPE (type, 0)->length;
+ *string_pos = TYPE_FIELD_BITPOS (type, 1) / TARGET_CHAR_BIT;
+ *char_size = 1;
+ return 1;
+ };
+ /* GNU pascal strings. */
+ /* Three fields: Capacity, length and schema$ or _p_schema. */
+ if (TYPE_NFIELDS (type) == 3
+ && strcmp (TYPE_FIELDS (type)[0].name, "Capacity") == 0
+ && strcmp (TYPE_FIELDS (type)[1].name, "length") == 0)
+ {
+ *length_pos = TYPE_FIELD_BITPOS (type, 1) / TARGET_CHAR_BIT;
+ *length_size = TYPE_FIELD_TYPE (type, 1)->length;
+ *string_pos = TYPE_FIELD_BITPOS (type, 2) / TARGET_CHAR_BIT;
+ /* FIXME: how can I detect wide chars in GPC ?? */
+ *char_size = 1;
+ return 1;
+ };
+ }
+ return 0;
+}
+
static void pascal_one_char (int, struct ui_file *, int *);
/* Print the character C on STREAM as part of the contents of a literal