/*============================================================================= Copyright (c) 2003 Martin Wille http://spirit.sourceforge.net/ Use, modification and distribution is subject to 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) =============================================================================*/ #ifndef BOOST_SPIRIT_UTILITY_SCOPED_LOCK_HPP #define BOOST_SPIRIT_UTILITY_SCOPED_LOCK_HPP /////////////////////////////////////////////////////////////////////////////// #if !defined(BOOST_SPIRIT_COMPOSITE_HPP) #include #endif /////////////////////////////////////////////////////////////////////////////// namespace boost { namespace spirit { /////////////////////////////////////////////////////////////////////////// // // scoped_lock_parser class // // implements locking of a mutex during execution of // the parse method of an embedded parser // /////////////////////////////////////////////////////////////////////////// template struct scoped_lock_parser : public unary< ParserT, parser< scoped_lock_parser > > { typedef scoped_lock_parser self_t; typedef MutexT mutex_t; typedef ParserT parser_t; template struct result { typedef typename parser_result::type type; }; scoped_lock_parser(mutex_t &m, parser_t const &p) : unary< ParserT, parser< scoped_lock_parser > >(p) , mutex(m) {} template typename parser_result::type parse(ScannerT const &scan) const { typedef typename mutex_t::scoped_lock scoped_lock_t; scoped_lock_t lock(mutex); return this->subject().parse(scan); } mutex_t &mutex; }; /////////////////////////////////////////////////////////////////////////// // // scoped_lock_parser_gen // // generator for scoped_lock_parser objects // operator[] returns scoped_lock_parser according to its argument // /////////////////////////////////////////////////////////////////////////// template struct scoped_lock_parser_gen { typedef MutexT mutex_t; explicit scoped_lock_parser_gen(mutex_t &m) : mutex(m) {} template scoped_lock_parser < MutexT, typename as_parser::type > operator[](ParserT const &p) const { typedef ::boost::spirit::as_parser as_parser_t; typedef typename as_parser_t::type parser_t; return scoped_lock_parser (mutex, as_parser_t::convert(p)); } mutex_t &mutex; }; /////////////////////////////////////////////////////////////////////////// // // scoped_lock_d parser directive // // constructs a scoped_lock_parser generator from its argument // /////////////////////////////////////////////////////////////////////////// template scoped_lock_parser_gen scoped_lock_d(MutexT &mutex) { return scoped_lock_parser_gen(mutex); } }} // namespace boost::spirit #endif // BOOST_SPIRIT_UTILITY_SCOPED_LOCK_HPP