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 + -
显示快捷键?