mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2024-11-30 23:40:24 +00:00
2002-12-17 David Carlton <carlton@math.stanford.edu>
* gdb.c++/try_catch.cc: Add marker comments. * gdb.c++/try_catch.exp: Get line numbers from marker comments. * gdb.c++/m-data.cc: Delete namespace __gnu_test. * gdb.c++/m-static.cc: Ditto. * gdb.c++/m-static1.cc: Ditto. * gdb.c++/try_catch.cc: Ditto.
This commit is contained in:
parent
6819ae388f
commit
7656509736
@ -1,3 +1,12 @@
|
||||
2002-12-17 David Carlton <carlton@math.stanford.edu>
|
||||
|
||||
* gdb.c++/try_catch.cc: Add marker comments.
|
||||
* gdb.c++/try_catch.exp: Get line numbers from marker comments.
|
||||
* gdb.c++/m-data.cc: Delete namespace __gnu_test.
|
||||
* gdb.c++/m-static.cc: Ditto.
|
||||
* gdb.c++/m-static1.cc: Ditto.
|
||||
* gdb.c++/try_catch.cc: Ditto.
|
||||
|
||||
2002-12-16 Jeff Johnston <jjohnstn@redhat.com>
|
||||
|
||||
* lib/mi-support.exp (mi_reinitialize_dir): Check mi level
|
||||
|
@ -1,47 +1,44 @@
|
||||
// 2002-05-13
|
||||
|
||||
namespace __gnu_test
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
const bool test;
|
||||
const int key1;
|
||||
long key2;
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
const bool test;
|
||||
const int key1;
|
||||
long key2;
|
||||
antiquities value;
|
||||
|
||||
antiquities value;
|
||||
public:
|
||||
gnu_obj_1(antiquities a, long l): test(true), key1(5), key2(l), value(a) {}
|
||||
};
|
||||
|
||||
public:
|
||||
gnu_obj_1(antiquities a, long l): test(true), key1(5), key2(l), value(a) {}
|
||||
};
|
||||
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
protected:
|
||||
antiquities value_derived;
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
protected:
|
||||
antiquities value_derived;
|
||||
|
||||
public:
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7), value_derived(b) { }
|
||||
};
|
||||
public:
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7), value_derived(b) { }
|
||||
};
|
||||
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
gnu_obj_2<int> data;
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
gnu_obj_2<int> data;
|
||||
|
||||
public:
|
||||
gnu_obj_3(antiquities b): data(etruscan) { }
|
||||
};
|
||||
}
|
||||
public:
|
||||
gnu_obj_3(antiquities b): data(etruscan) { }
|
||||
};
|
||||
|
||||
int shadow = 0;
|
||||
|
||||
@ -56,7 +53,6 @@ private:
|
||||
|
||||
int main()
|
||||
{
|
||||
using namespace __gnu_test;
|
||||
gnu_obj_1 test1(egyptian, 4589);
|
||||
gnu_obj_2<long> test2(roman);
|
||||
gnu_obj_3<long> test3(greek);
|
||||
|
@ -1,73 +1,68 @@
|
||||
// 2002-05-13
|
||||
|
||||
namespace __gnu_test
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
static const bool test = true;
|
||||
static const int key1 = 5;
|
||||
static long key2;
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
protected:
|
||||
typedef region antiquities;
|
||||
static const bool test = true;
|
||||
static const int key1 = 5;
|
||||
static long key2;
|
||||
static antiquities value;
|
||||
|
||||
static antiquities value;
|
||||
public:
|
||||
gnu_obj_1(antiquities a, long l) {}
|
||||
};
|
||||
|
||||
public:
|
||||
gnu_obj_1(antiquities a, long l) {}
|
||||
};
|
||||
|
||||
const bool gnu_obj_1::test;
|
||||
const int gnu_obj_1::key1;
|
||||
long gnu_obj_1::key2 = 77;
|
||||
gnu_obj_1::antiquities gnu_obj_1::value = oriental;
|
||||
const bool gnu_obj_1::test;
|
||||
const int gnu_obj_1::key1;
|
||||
long gnu_obj_1::key2 = 77;
|
||||
gnu_obj_1::antiquities gnu_obj_1::value = oriental;
|
||||
|
||||
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
public:
|
||||
static antiquities value_derived;
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
public:
|
||||
static antiquities value_derived;
|
||||
|
||||
public:
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7) { }
|
||||
};
|
||||
public:
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7) { }
|
||||
};
|
||||
|
||||
template<typename T>
|
||||
typename gnu_obj_2<T>::antiquities gnu_obj_2<T>::value_derived = etruscan;
|
||||
template<typename T>
|
||||
typename gnu_obj_2<T>::antiquities gnu_obj_2<T>::value_derived = etruscan;
|
||||
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
public:
|
||||
typedef region antiquities;
|
||||
static gnu_obj_2<int> data;
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
public:
|
||||
typedef region antiquities;
|
||||
static gnu_obj_2<int> data;
|
||||
|
||||
public:
|
||||
gnu_obj_3(antiquities b) { }
|
||||
};
|
||||
public:
|
||||
gnu_obj_3(antiquities b) { }
|
||||
};
|
||||
|
||||
template<typename T>
|
||||
gnu_obj_2<int> gnu_obj_3<T>::data(etruscan);
|
||||
template<typename T>
|
||||
gnu_obj_2<int> gnu_obj_3<T>::data(etruscan);
|
||||
|
||||
// 2002-08-16
|
||||
// Test four.
|
||||
// 2002-08-16
|
||||
// Test four.
|
||||
#include "m-static.h"
|
||||
}
|
||||
|
||||
// instantiate templates explicitly so their static members will exist
|
||||
template class __gnu_test::gnu_obj_2<int>;
|
||||
template class __gnu_test::gnu_obj_2<long>;
|
||||
template class __gnu_test::gnu_obj_3<long>;
|
||||
template class gnu_obj_2<int>;
|
||||
template class gnu_obj_2<long>;
|
||||
template class gnu_obj_3<long>;
|
||||
|
||||
int main()
|
||||
{
|
||||
using namespace __gnu_test;
|
||||
|
||||
gnu_obj_1 test1(egyptian, 4589);
|
||||
gnu_obj_2<long> test2(roman);
|
||||
gnu_obj_3<long> test3(greek);
|
||||
|
@ -1,9 +1,5 @@
|
||||
// 2002-08-16
|
||||
|
||||
namespace __gnu_test {
|
||||
#include "m-static.h"
|
||||
}
|
||||
|
||||
using namespace __gnu_test;
|
||||
|
||||
const int gnu_obj_4::elsewhere = 221;
|
||||
|
@ -4,50 +4,45 @@
|
||||
#include <stdexcept>
|
||||
#include <string>
|
||||
|
||||
namespace __gnu_test
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
enum region { oriental, egyptian, greek, etruscan, roman };
|
||||
public:
|
||||
typedef region antiquities;
|
||||
const bool test;
|
||||
const int key1;
|
||||
long key2;
|
||||
|
||||
// Test one.
|
||||
class gnu_obj_1
|
||||
{
|
||||
public:
|
||||
typedef region antiquities;
|
||||
const bool test;
|
||||
const int key1;
|
||||
long key2;
|
||||
antiquities value;
|
||||
|
||||
antiquities value;
|
||||
gnu_obj_1(antiquities a, long l): test(true), key1(5), key2(l), value(a) {}
|
||||
};
|
||||
|
||||
gnu_obj_1(antiquities a, long l): test(true), key1(5), key2(l), value(a) {}
|
||||
};
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
public:
|
||||
antiquities value_derived;
|
||||
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7), value_derived(b) { }
|
||||
};
|
||||
|
||||
// Test two.
|
||||
template<typename T>
|
||||
class gnu_obj_2: public virtual gnu_obj_1
|
||||
{
|
||||
public:
|
||||
antiquities value_derived;
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
public:
|
||||
typedef region antiquities;
|
||||
gnu_obj_2<int> data;
|
||||
|
||||
gnu_obj_2(antiquities b): gnu_obj_1(oriental, 7), value_derived(b) { }
|
||||
};
|
||||
|
||||
// Test three.
|
||||
template<typename T>
|
||||
class gnu_obj_3
|
||||
{
|
||||
public:
|
||||
typedef region antiquities;
|
||||
gnu_obj_2<int> data;
|
||||
|
||||
gnu_obj_3(antiquities b): data(etruscan) { }
|
||||
};
|
||||
}
|
||||
gnu_obj_3(antiquities b): data(etruscan) { }
|
||||
};
|
||||
|
||||
int main()
|
||||
{
|
||||
using namespace __gnu_test;
|
||||
|
||||
bool test = true;
|
||||
const int i = 5;
|
||||
int j = i;
|
||||
@ -58,12 +53,12 @@ int main()
|
||||
try
|
||||
{
|
||||
++j;
|
||||
throw gnu_obj_1(egyptian, 4589);
|
||||
throw gnu_obj_1(egyptian, 4589); // marker 1-throw
|
||||
}
|
||||
catch (gnu_obj_1& obj)
|
||||
{
|
||||
++j;
|
||||
if (obj.value != egyptian)
|
||||
if (obj.value != egyptian) // marker 1-catch
|
||||
test &= false;
|
||||
if (obj.key2 != 4589)
|
||||
test &= false;
|
||||
@ -77,19 +72,19 @@ int main()
|
||||
// 2
|
||||
try
|
||||
{
|
||||
++j;
|
||||
++j; // marker 2-start
|
||||
try
|
||||
{
|
||||
++j;
|
||||
++j; // marker 2-next
|
||||
try
|
||||
{
|
||||
++j;
|
||||
throw gnu_obj_1(egyptian, 4589);
|
||||
throw gnu_obj_1(egyptian, 4589); // marker 2-throw
|
||||
}
|
||||
catch (gnu_obj_1& obj)
|
||||
{
|
||||
++j;
|
||||
if (obj.value != egyptian)
|
||||
if (obj.value != egyptian) // marker 2-catch
|
||||
test &= false;
|
||||
if (obj.key2 != 4589)
|
||||
test &= false;
|
||||
@ -115,11 +110,11 @@ int main()
|
||||
try
|
||||
{
|
||||
if (j < 100)
|
||||
throw invalid_argument("gdb.1");
|
||||
throw invalid_argument("gdb.1"); // marker 3-throw
|
||||
}
|
||||
catch (exception& obj)
|
||||
{
|
||||
if (obj.what() != "gdb.1")
|
||||
if (obj.what() != "gdb.1") // marker 3-catch
|
||||
test &= false;
|
||||
}
|
||||
return 0;
|
||||
|
@ -54,31 +54,29 @@ if ![runto_main] then {
|
||||
continue
|
||||
}
|
||||
|
||||
# One.
|
||||
gdb_breakpoint [gdb_get_line_number "marker 1-throw"]
|
||||
gdb_continue_to_breakpoint "marker 1-throw"
|
||||
|
||||
gdb_test "break 61" "Breakpoint \[0-9\]*.*line 61\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:61\r\n.*" "continue to 61"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 1-catch"]
|
||||
gdb_continue_to_breakpoint "marker 1-catch"
|
||||
|
||||
gdb_test "break 66" "Breakpoint \[0-9\]*.*line 66\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:66\r\n.*" "continue to 66"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 2-start"]
|
||||
gdb_continue_to_breakpoint "marker 2-start"
|
||||
|
||||
gdb_test "break 80" "Breakpoint \[0-9\]*.*line 80\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:80\r\n.*" "continue to 80"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 2-next"]
|
||||
gdb_continue_to_breakpoint "marker 2-next"
|
||||
|
||||
gdb_test "break 83" "Breakpoint \[0-9\]*.*line 83\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:83\r\n.*" "continue to 83"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 2-throw"]
|
||||
gdb_continue_to_breakpoint "marker 2-throw"
|
||||
|
||||
gdb_test "break 87" "Breakpoint \[0-9\]*.*line 87\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:87\r\n.*" "continue to 87"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 2-catch"]
|
||||
gdb_continue_to_breakpoint "marker 2-catch"
|
||||
|
||||
gdb_test "break 92" "Breakpoint \[0-9\]*.*line 92\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:92\r\n.*" "continue to 92"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 3-throw"]
|
||||
gdb_continue_to_breakpoint "marker 3-throw"
|
||||
|
||||
gdb_test "break 118" "Breakpoint \[0-9\]*.*line 118\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:118\r\n.*" "continue to 118"
|
||||
|
||||
gdb_test "break 122" "Breakpoint \[0-9\]*.*line 122\\."
|
||||
gdb_test "continue" "Continuing\\.\r\n\r\nBreakpoint.*at.*try_catch\\.cc:122\r\n.*" "continue to 122"
|
||||
gdb_breakpoint [gdb_get_line_number "marker 3-catch"]
|
||||
gdb_continue_to_breakpoint "marker 3-catch"
|
||||
|
||||
gdb_exit
|
||||
return 0
|
||||
|
Loading…
Reference in New Issue
Block a user