/* This testcase is part of GDB, the GNU debugger.
Copyright 2008-2023 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 . */
#include
using namespace std;
int dummy ()
{
return 0;
}
class NextOverThrowDerivates
{
public:
// Single throw an exception in this function.
void function1 (int val)
{
throw val;
}
// Throw an exception in another function.
void function2 (int val)
{
function1 (val);
}
// Throw an exception in another function, but handle it
// locally.
void function3 (int val)
{
{
try
{
function1 (val);
}
catch (...)
{
cout << "Caught and handled function1 exception" << endl;
}
}
}
void rethrow (int val)
{
try
{
function1 (val);
}
catch (...)
{
throw;
}
}
void finish (int val)
{
// We use this to test that a "finish" here does not end up in
// this frame, but in the one above.
try
{
function1 (val);
}
catch (int x)
{
}
function1 (val); // marker for until
}
void until (int val)
{
function1 (val);
function1 (val); // until here
}
void resumebpt (int val)
{
try
{
throw val;
}
catch (int x)
{
dummy ();
}
}
};
NextOverThrowDerivates next_cases;
int
resumebpt_test (int x)
{
try
{
next_cases.resumebpt (x); // Start: resumebpt
next_cases.resumebpt (x + 1); // Second: resumebpt
}
catch (int val)
{
dummy ();
x = val;
}
return x;
}
int main ()
{
int testval = -1;
try
{
next_cases.function1 (0); // Start: first test
}
catch (int val)
{
dummy ();
testval = val; // End: first test
}
try
{
next_cases.function2 (1); // Start: nested throw
}
catch (int val)
{
dummy ();
testval = val; // End: nested throw
}
try
{
// This is duplicated so we can next over one but step into
// another.
next_cases.function2 (2); // Start: step in test
}
catch (int val)
{
dummy ();
testval = val; // End: step in test
}
next_cases.function3 (3); // Start: next past catch
dummy ();
testval = 3; // End: next past catch
try
{
next_cases.rethrow (4); // Start: rethrow
}
catch (int val)
{
dummy ();
testval = val; // End: rethrow
}
try
{
// Another duplicate so we can test "finish".
next_cases.function2 (5); // Start: first finish
}
catch (int val)
{
dummy ();
testval = val; // End: first finish
}
// Another test for "finish".
try
{
next_cases.finish (6); // Start: second finish
}
catch (int val)
{
dummy ();
testval = val; // End: second finish
}
// Test of "until".
try
{
next_cases.finish (7); // Start: first until
}
catch (int val)
{
dummy ();
testval = val; // End: first until
}
// Test of "until" with an argument.
try
{
next_cases.until (8); // Start: second until
}
catch (int val)
{
dummy ();
testval = val; // End: second until
}
// Test of "advance".
try
{
next_cases.until (9); // Start: advance
}
catch (int val)
{
dummy ();
testval = val; // End: advance
}
// Test of "resumebpt".
testval = resumebpt_test (10);
testval = 32; // done
}