lexertl5.cpp

来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 115 行

CPP
115
字号
//  Copyright (c) 2001-2008 Hartmut Kaiser// //  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 <boost/detail/lightweight_test.hpp>#include <boost/spirit/include/lex_lexer_lexertl.hpp>#include "test.hpp"/////////////////////////////////////////////////////////////////////////////////  test pattern definition capabilitiesint main(){    using namespace boost::spirit;    using namespace boost::spirit::lex;    using namespace spirit_test;    // initialize tokens    typedef lex::token_def<std::string> token_def;        std::size_t const CCOMMENT = 1;    std::size_t const CPPCOMMENT = 2;    std::size_t const TOKEN_ID_ABC = 1000;    std::size_t const TOKEN_ID_STR = 1001;    std::size_t const TOKEN_ID_WS = 1002;        typedef std::string::iterator base_iterator_type;        typedef lex::lexertl_token<base_iterator_type> token_type;    typedef lex::lexertl_lexer<token_type> lexer_type;        typedef lexer_type::token_set token_set;    typedef lex::lexer_def<lexer_type> lexer_def;    std::string str("def");    {        // initialize lexer        lexer_def def;                def.self.add_pattern            ("CCOMMENT", "\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\/")            ("CPPCOMMENT", "\\/\\/[^\\n\\r]*(\\n|\\r|\\r\\n)")            ("WS", "[\\v\\f\\n\\r]*")        ;                token_def c_comment ("{CCOMMENT}", CCOMMENT);        token_def cpp_comment ("{CPPCOMMENT}", CPPCOMMENT);        token_def ws_tok ("{WS}");        def.self.add            (c_comment)(cpp_comment)             ('1')('2')('3')            ("abc", TOKEN_ID_ABC)            (str, TOKEN_ID_STR)        ;        def.self += token_def(' ') | '\t' | ws_tok;        // test lexer for different input strings        lex::lexer<lexer_def> lex(def);        BOOST_TEST(test (lex, "/* this is a comment */", CCOMMENT));        BOOST_TEST(test (lex, "// this is a comment as well\n", CPPCOMMENT));        BOOST_TEST(test (lex, "\n\n\v\f\r", ws_tok.id()));        BOOST_TEST(test (lex, " ", ' '));        BOOST_TEST(test (lex, "2", '2'));        BOOST_TEST(test (lex, "abc", TOKEN_ID_ABC));        BOOST_TEST(test (lex, "def", TOKEN_ID_STR));    }        {        // initialize lexer        lexer_def def;        def.self.add_pattern            ("CCOMMENT", "\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\/")            ("CPPCOMMENT", "\\/\\/[^\\n\\r]*(\\n|\\r|\\r\\n)")            ("WS", "[\\v\\f\\n\\r]*")        ;                token_def c_comment ("{CCOMMENT}", CCOMMENT);        token_def cpp_comment ("{CPPCOMMENT}", CPPCOMMENT);        token_def ws_tok ("{WS}");        // init a token set        token_set ws;        ws.add            (' ')('\t')            (ws_tok, TOKEN_ID_WS)        ;        def.self.add            (c_comment)(cpp_comment)             ('1')('2')('3')            ("abc", TOKEN_ID_ABC)            (str, TOKEN_ID_STR)        ;        def.self("WHITESPACE").add(ws);        // test lexer for different input strings        lex::lexer<lexer_def> lex(def);        BOOST_TEST(test (lex, "/* this is a comment */", CCOMMENT));        BOOST_TEST(test (lex, "// this is a comment as well\n", CPPCOMMENT));        BOOST_TEST(test (lex, "2", '2'));        BOOST_TEST(test (lex, "abc", TOKEN_ID_ABC));        BOOST_TEST(test (lex, "def", TOKEN_ID_STR));        BOOST_TEST(!test (lex, "\n\n\v\f\r", TOKEN_ID_WS));        BOOST_TEST(test (lex, " ", ' ', "WHITESPACE"));        BOOST_TEST(test (lex, "\n\n\v\f\r", TOKEN_ID_WS, "WHITESPACE"));    }    return boost::report_errors();}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?