Projet_SETI_RISC-V/riscv-gnu-toolchain/binutils/gdb/testsuite/gdb.python/py-xmethods.cc
2023-03-06 14:48:14 +01:00

180 lines
2.7 KiB
C++

/* This testcase is part of GDB, the GNU debugger.
Copyright 2014-2022 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/>. */
namespace dop
{
class A
{
public:
int a;
int array [10];
virtual ~A ();
int operator+ (const A &obj);
int operator- (const A &obj);
virtual int geta (void);
};
A::~A () { }
int a_plus_a = 0;
int
A::operator+ (const A &obj)
{
a_plus_a++;
return a + obj.a;
}
int a_minus_a = 0;
int
A::operator- (const A &obj)
{
a_minus_a++;
return a - obj.a;
}
int a_geta = 0;
int
A::geta (void)
{
a_geta++;
return a;
}
class B : public A
{
public:
virtual int geta (void);
};
int b_geta = 0;
int
B::geta (void)
{
b_geta++;
return 2 * a;
}
typedef B Bt;
typedef Bt Btt;
class E : public A
{
public:
/* This class has a member named 'a', while the base class also has a
member named 'a'. When one invokes A::geta(), A::a should be
returned and not E::a as the 'geta' method is defined on class 'A'.
This class tests this aspect of debug methods. */
int a;
};
template <typename T>
class G
{
public:
template <typename T1>
int size_diff ();
template <int M>
int size_mul ();
template <typename T1>
T mul(const T1 t1);
public:
T t;
};
int g_size_diff = 0;
template <typename T>
template <typename T1>
int
G<T>::size_diff ()
{
g_size_diff++;
return sizeof (T1) - sizeof (T);
}
int g_size_mul = 0;
template <typename T>
template <int M>
int
G<T>::size_mul ()
{
g_size_mul++;
return M * sizeof (T);
}
int g_mul = 0;
template <typename T>
template <typename T1>
T
G<T>::mul (const T1 t1)
{
g_mul++;
return t1 * t;
}
} // namespaxe dop
using namespace dop;
int main(void)
{
A a1, a2;
a1.a = 5;
a2.a = 10;
B b1;
b1.a = 30;
A *a_ptr = &b1;
Bt bt;
bt.a = 40;
Btt btt;
btt.a = -5;
G<int> g, *g_ptr;
g.t = 5;
g_ptr = &g;
E e;
E &e_ref = e;
E *e_ptr = &e;
e.a = 1000;
e.A::a = 100;
int diff = g.size_diff<float> ();
int smul = g.size_mul<2> ();
int mul = g.mul (1.0);
for (int i = 0; i < 10; i++)
{
a1.array[i] = a2.array[i] = b1.array[i] = i;
}
return 0; /* Break here. */
}