//Copyright (c) 2018 Emil Dotchevski //Copyright (c) 2018 Second Spectrum, Inc. //Distributed under the Boost Software License, Version 1.0. (See accompanying //file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #include #include #include namespace leaf = boost::leaf; template struct info { int value; }; leaf::error f1() { return leaf::error( info<1>{1} ); } leaf::error f2() { return f1().propagate( info<2>{2} ); } leaf::error f3() { return f2().propagate( info<3>{3} ); } leaf::error f4() { return f3().propagate(); } leaf::error_capture make_capture() { leaf::expect,info<2>,info<4>> exp; return capture(exp,f4()); } int main() { leaf::error_capture e1 = make_capture(); BOOST_TEST(e1); { int const * p = leaf::peek>(e1); BOOST_TEST(p && *p==1); } { int const * p = leaf::peek>(e1); BOOST_TEST(p && *p==2); } BOOST_TEST(!leaf::peek>(e1)); leaf::expect,info<2>,info<4>> exp; leaf::error e2 = f4(); { int const * p = leaf::peek>(e1); BOOST_TEST(p && *p==1); } { int const * p = leaf::peek>(e1); BOOST_TEST(p && *p==2); } BOOST_TEST(!leaf::peek>(e1)); { int const * p = leaf::peek>(exp,e2); BOOST_TEST(p && *p==1); } { int const * p = leaf::peek>(exp,e2); BOOST_TEST(p && *p==2); } BOOST_TEST(!leaf::peek>(exp,e2)); { int c1=0, c2=0; BOOST_TEST( handle_error( exp, e2, leaf::match,info<2>,info<4>>( [&c1]( int, int, int ) { ++c1; } ), leaf::match,info<1>>( [&c2]( int i2,int i1 ) { BOOST_TEST(i1==1); BOOST_TEST(i2==2); ++c2; } ) ) ); BOOST_TEST(c1==0); BOOST_TEST(c2==1); } { int c1=0, c2=0, c3=0; BOOST_TEST( handle_error( e1, leaf::match,info<2>,info<3>>( [&c1]( int, int, int ) { ++c1; } ), leaf::match,info<2>,info<4>>( [&c2]( int, int, int ) { ++c2; } ), leaf::match,info<1>>( [&c3]( int i2,int i1 ) { BOOST_TEST(i1==1); BOOST_TEST(i2==2); ++c3; } ) ) ); BOOST_TEST(c1==0); BOOST_TEST(c2==0); BOOST_TEST(c3==1); } BOOST_TEST( handle_error( e1, leaf::match,info<2>,info<3>>(), leaf::match,info<2>,info<4>>(), leaf::match,info<1>>() ) ); return boost::report_errors(); }