forked from Imagelibrary/binutils-gdb
Currently it's not possible to call C++ methods from python.
Using this example:
```
class B
{
static int static_func ();
int arg0_func ();
int arg1_func (int arg1);
int arg2_func (int arg1, int arg2);
};
B *b_obj = new B;
```
Trying to call B::static_func gives this error:
```
(gdb) py b_obj = gdb.parse_and_eval('b_obj')
(gdb) py print(b_obj['static_func']())
Traceback (most recent call last):
File "<string>", line 1, in <module>
RuntimeError: Value is not callable (not TYPE_CODE_FUNC).
Error while executing Python code.
```
TYPE_CODE_METHOD was simply missing as a possible type in
valpy_call, now the same is possible:
```
(gdb) py b_obj = gdb.parse_and_eval('b_obj')
(gdb) py print(b_obj['static_func']())
1111
```
Note that it's necessary to explicitely add the this pointer
as the first argument in a call of non-static methods:
```
(gdb) py print(b_obj['arg0_func']())
Traceback (most recent call last):
File "<string>", line 1, in <module>
gdb.error: Too few arguments in function call.
Error while executing Python code.
(gdb) py print(b_obj['arg0_func'](b_obj))
198
```
Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=13326
Approved-By: Tom Tromey <tom@tromey.com>
129 lines
1.9 KiB
C++
129 lines
1.9 KiB
C++
/* This testcase is part of GDB, the GNU debugger.
|
|
|
|
Copyright 2012-2024 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/>. */
|
|
|
|
class A {
|
|
public:
|
|
int operator+ (const int a1);
|
|
|
|
public:
|
|
int a;
|
|
};
|
|
|
|
int
|
|
A::operator+ (const int a1)
|
|
{
|
|
return a + a1;
|
|
}
|
|
|
|
union U {
|
|
int a;
|
|
char c;
|
|
};
|
|
|
|
class B : public A {
|
|
public:
|
|
char a;
|
|
|
|
static int static_func ();
|
|
int arg0_func ();
|
|
int arg1_func (int arg1);
|
|
int arg2_func (int arg1, int arg2);
|
|
};
|
|
|
|
int B::static_func ()
|
|
{
|
|
return 1111;
|
|
}
|
|
|
|
int B::arg0_func ()
|
|
{
|
|
return A::a + a;
|
|
}
|
|
|
|
int B::arg1_func (int arg1)
|
|
{
|
|
return a * arg1;
|
|
}
|
|
|
|
int B::arg2_func (int arg1, int arg2)
|
|
{
|
|
return a * arg1 + arg2;
|
|
}
|
|
|
|
struct X
|
|
{
|
|
union { int x; char y; };
|
|
union { int a; char b; };
|
|
};
|
|
|
|
union UU
|
|
{
|
|
union { int x; char y; };
|
|
union { int a; char b; };
|
|
};
|
|
|
|
typedef B Btd;
|
|
typedef int *int_ptr;
|
|
typedef X Xtd;
|
|
|
|
int
|
|
func (const A &a)
|
|
{
|
|
int val = 10;
|
|
int &int_ref = val;
|
|
int_ptr ptr = &val;
|
|
int_ptr &int_ptr_ref = ptr;
|
|
|
|
B b;
|
|
B b1;
|
|
|
|
b.a = 'a';
|
|
b.A::a = 10;
|
|
|
|
B *b_obj = &b1;
|
|
b_obj->a = 'b';
|
|
b_obj->A::a = 100;
|
|
|
|
B &b_ref = b1;
|
|
Btd &b_td = b1;
|
|
|
|
U u;
|
|
u.a = 0x63636363;
|
|
|
|
X x;
|
|
x.x = 101;
|
|
x.a = 102;
|
|
|
|
UU uu;
|
|
uu.x = 1000;
|
|
|
|
X *x_ptr = &x;
|
|
Xtd *xtd = &x;
|
|
|
|
return 0; /* Break here. */
|
|
}
|
|
|
|
int
|
|
main ()
|
|
{
|
|
A obj;
|
|
|
|
obj.a = 5;
|
|
|
|
return func (obj);
|
|
}
|