diff options
-rw-r--r-- | tests/c++.at | 2 | ||||
-rw-r--r-- | tests/local.at | 43 |
2 files changed, 45 insertions, 0 deletions
diff --git a/tests/c++.at b/tests/c++.at index 39c13f82..ac68dc0c 100644 --- a/tests/c++.at +++ b/tests/c++.at @@ -655,6 +655,8 @@ AT_CLEANUP m4_pushdef([AT_TEST], [AT_SETUP([[Exception safety $1]]) +AT_SKIP_IF_EXCEPTION_SUPPORT_IS_POOR + AT_BISON_OPTION_PUSHDEFS([%skeleton "lalr1.cc" $1]) AT_DATA_GRAMMAR([[input.yy]], diff --git a/tests/local.at b/tests/local.at index ee00e009..72c0d529 100644 --- a/tests/local.at +++ b/tests/local.at @@ -875,6 +875,49 @@ AT_PARSER_CHECK([./c-and-cxx]) ]) +# AT_SKIP_IF_EXCEPTION_SUPPORT_IS_POOR +# ------------------------------------ +# Check that we can expect exceptions to be handled properly. +# GCC 4.3 and 4.4 fail https://trac.macports.org/ticket/40853. +m4_define([AT_SKIP_IF_EXCEPTION_SUPPORT_IS_POOR], +[AT_DATA_SOURCE([exception.cc], +[[#include <iostream> +#include <stdexcept> + +void foo() +{ + try + { + throw std::runtime_error("foo"); + } + catch (...) + { + std::cerr << "Inner caught" << std::endl; + throw; + } +} + +int main() +{ + try + { + foo(); + } + catch (...) + { + std::cerr << "Outer caught" << std::endl; + return 0; + } + return 1; +} +]]) +AT_COMPILE_CXX([exception]) +# The "empty" quadrigraph is to protect from cfg.mk's +# sc_at_parser_check. +AT_CHECK([@&t@./exception || exit 77], [0], [], [ignore]) +]) + + ## ---------------------------- ## ## Running a generated parser. ## ## ---------------------------- ## |