2014-09-17 03:35:18 +02:00
|
|
|
/*
|
2014-09-27 17:21:03 +02:00
|
|
|
Copyright 2012 Wolfgang Thaller.
|
2014-09-17 03:35:18 +02:00
|
|
|
|
|
|
|
This file is part of Retro68.
|
|
|
|
|
|
|
|
Retro68 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.
|
|
|
|
|
|
|
|
Retro68 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 Retro68. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2017-09-26 11:27:53 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <exception>
|
2014-09-17 03:35:18 +02:00
|
|
|
|
2014-09-27 17:21:03 +02:00
|
|
|
#include <Events.h>
|
|
|
|
|
|
|
|
class Foo
|
|
|
|
{
|
|
|
|
};
|
|
|
|
|
|
|
|
void foobar()
|
|
|
|
{
|
|
|
|
throw Foo();
|
|
|
|
}
|
|
|
|
|
2017-09-26 11:27:53 +02:00
|
|
|
void UnexpectedExceptionOccurred()
|
|
|
|
{
|
|
|
|
printf("std::unexpected called.\n");
|
|
|
|
printf("Press Enter...\n");
|
|
|
|
getchar();
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
void UncaughtExceptionOccurred()
|
|
|
|
{
|
|
|
|
printf("std::terminate called.\n");
|
|
|
|
printf("Press Enter...\n");
|
|
|
|
getchar();
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
2014-09-17 03:35:18 +02:00
|
|
|
int main(int argc, char** argv)
|
|
|
|
{
|
2017-09-26 11:27:53 +02:00
|
|
|
std::set_unexpected(&UnexpectedExceptionOccurred);
|
|
|
|
std::set_terminate(&UncaughtExceptionOccurred);
|
2017-09-24 20:04:11 +02:00
|
|
|
bool throwFail = false;
|
|
|
|
bool catchFail = true;
|
2014-09-27 17:21:03 +02:00
|
|
|
for(int i = 0; i < 5; i++)
|
|
|
|
{
|
|
|
|
int n = i == 0 ? 1 : 100;
|
|
|
|
printf("Exception speed test (%3d iterations): ", n); fflush(stdout);
|
|
|
|
long start = TickCount();
|
|
|
|
for(int j = 0; j < n; j++)
|
|
|
|
{
|
2017-09-24 20:04:11 +02:00
|
|
|
try { foobar(); throwFail = true; } catch(...) { catchFail = false; }
|
2014-09-27 17:21:03 +02:00
|
|
|
}
|
|
|
|
long end = TickCount();
|
|
|
|
|
|
|
|
printf("%g ms per throw/catch\n",(end-start)*1000 / 60.0 / n);
|
|
|
|
}
|
|
|
|
|
2017-09-24 20:04:11 +02:00
|
|
|
if(throwFail)
|
|
|
|
printf("******** FAILURE: throw didn't really throw\n");
|
|
|
|
if(catchFail)
|
|
|
|
printf("******** FAILURE: catch block never entered\n");
|
|
|
|
|
2017-09-26 11:27:53 +02:00
|
|
|
printf("Press Enter...\n");
|
|
|
|
getchar();
|
2014-09-17 03:35:18 +02:00
|
|
|
return 0;
|
|
|
|
}
|