This is the mail archive of the gdb@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Patch for allowing calling pascal-methods (fpc)


Hi all,

More digging convinced me that the actual problem is in
lookup_struct_elt_type. 

Attached is a patch which makes it possible for gdb to call methods and
print the result. A testsuite-run did not show any regressions. The
patch also contains a test with an example.

Regards,

Joost van der Sluis
diff --git a/gdb/gdbtypes.c b/gdb/gdbtypes.c
index da9bade..f98dbe1 100644
--- a/gdb/gdbtypes.c
+++ b/gdb/gdbtypes.c
@@ -1355,6 +1355,23 @@ lookup_struct_elt_type (struct type *type, char *name, int noerr)
 	}
     }
 
+  /* Check for cplus-stuf (Or Pascal-methods) */
+
+  for (i = 0; i < TYPE_NFN_FIELDS (type); i++)
+    {
+      char *t_method_name = TYPE_FN_FIELDLIST_NAME (type, i);
+
+      if (t_method_name && (strcmp_iw (t_method_name, name) == 0))
+	{
+          if (TYPE_FN_FIELDLIST_LENGTH(type, i) == 1)
+            {
+              return TYPE_FN_FIELD_TYPE (TYPE_FN_FIELDLIST1 (type, i), 0);
+            }
+          else if (!(noerr))
+            error (_("Could not determine which %s has to be used."), name);
+	}
+    }
+
   /* OK, it's not in this class.  Recursively check the baseclasses.  */
   for (i = TYPE_N_BASECLASSES (type) - 1; i >= 0; i--)
     {
diff --git a/gdb/testsuite/gdb.pascal/methods.exp b/gdb/testsuite/gdb.pascal/methods.exp
new file mode 100644
index 0000000..1a36ce0
--- /dev/null
+++ b/gdb/testsuite/gdb.pascal/methods.exp
@@ -0,0 +1,60 @@
+# Copyright 2011 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/>.
+
+if $tracelevel then {
+    strace $tracelevel
+}
+
+load_lib "pascal.exp"
+
+set testfile "methods"
+set srcfile ${testfile}.pas
+set binfile ${objdir}/${subdir}/${testfile}$EXEEXT
+
+if {[gdb_compile_pascal "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug ]] != "" } {
+  return -1
+}
+
+gdb_exit
+gdb_start
+gdb_reinitialize_dir $srcdir/$subdir
+gdb_load ${binfile}
+set bp_location1 [gdb_get_line_number "set breakpoint 1 here"]
+
+if { [gdb_breakpoint ${srcfile}:${bp_location1}] } {
+    pass "setting breakpoint 1"
+}
+
+# Verify that "start" lands inside the right procedure.
+if { [gdb_start_cmd] < 0 } {
+    untested start
+    return -1
+}
+
+gdb_test "" ".* at .*${srcfile}.*" "start"
+gdb_test "continue" ""
+
+#gdb_test "print integer_array" { = \{50, 51, 52, 53, 54, 55, 56, 57\}}
+#gdb_test "print /s integer_array" " = '23456789'" 
+
+gdb_test "print AClass.GetInt()" " = 42535" 
+#gdb_test "print /d char_array" { = \{50, 51, 52, 53, 54, 55, 56, 57\}}
+#gdb_test "print /x char_array" { = \{0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39\}}
+# Use next two times to avoid GPC line numbering problem
+#gdb_test "next" ""
+#gdb_test "next" ""
+#gdb_test "print char_array" " = '2345X789'"
+gdb_exit
+
diff --git a/gdb/testsuite/gdb.pascal/methods.pas b/gdb/testsuite/gdb.pascal/methods.pas
new file mode 100644
index 0000000..1b32d5c
--- /dev/null
+++ b/gdb/testsuite/gdb.pascal/methods.pas
@@ -0,0 +1,37 @@
+{
+ Copyright 2011 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/>.
+}
+program methods;
+
+{$mode objfpc}
+
+type
+  TMyClass = class
+    function getInt: integer;
+  end;
+
+function TMyClass.getInt: integer;
+begin
+  result := 42535;
+end;
+
+var 
+  AClass: TMyClass;
+
+begin
+  AClass := TMyClass.Create;
+  writeln(AClass.GetInt); { set breakpoint 1 here }
+end.

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]