⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 quick_start.cpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 CPP
字号:
/*=============================================================================    Boost.Wave: A Standard compliant C++ preprocessor library    http://www.boost.org/    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 <iostream>#include <fstream>#include <string>#include <vector>/////////////////////////////////////////////////////////////////////////////////  Include Wave itself#include <boost/wave.hpp>///////////////////////////////////////////////////////////////////////////////// Include the lexer stuff#include <boost/wave/cpplexer/cpp_lex_token.hpp>    // token class#include <boost/wave/cpplexer/cpp_lex_iterator.hpp> // lexer class///////////////////////////////////////////////////////////////////////////////// main entry pointint main(int argc, char *argv[]){    if (2 != argc) {        std::cerr << "Usage: quick_start infile" << std::endl;        return -1;    }    // current file position is saved for exception handlingboost::wave::util::file_position_type current_position;    try {//[quick_start_main    //  The following preprocesses the given input file (given by argv[1]).    //  Open and read in the specified input file.    std::ifstream instream(argv[1]);    std::string instring;        if (!instream.is_open()) {            std::cerr << "Could not open input file: " << argv[1] << std::endl;            return -2;        }        instream.unsetf(std::ios::skipws);        instring = std::string(std::istreambuf_iterator<char>(instream.rdbuf()),                                std::istreambuf_iterator<char>());                //  This token type is one of the central types used throughout the library,     //  because it is a template parameter to some of the public classes and      //  instances of this type are returned from the iterators.        typedef boost::wave::cpplexer::lex_token<> token_type;        //  The template boost::wave::cpplexer::lex_iterator<> is the lexer type to    //  to use as the token source for the preprocessing engine. It is     //  parametrized with the token type.        typedef boost::wave::cpplexer::lex_iterator<token_type> lex_iterator_type;            //  This is the resulting context type to use. The first template parameter    //  should match the iterator type to be used during construction of the    //  corresponding context object (see below).        typedef boost::wave::context<std::string::iterator, lex_iterator_type>            context_type;    //  The preprocessor iterator shouldn't be constructed directly. It is     //  to be generated through a wave::context<> object. This wave:context<>     //  object is to be used additionally to initialize and define different     //  parameters of the actual preprocessing (not done here).    //    //  The preprocessing of the input stream is done on the fly behind the     //  scenes during iteration over the context_type::iterator_type stream.    context_type ctx (instring.begin(), instring.end(), argv[1]);    //  Get the preprocessor iterators and use them to generate     //  the token sequence.    context_type::iterator_type first = ctx.begin();    context_type::iterator_type last = ctx.end();            //  The input stream is preprocessed for you while iterating over the range    //  [first, last)        while (first != last) {            current_position = (*first).get_position();            std::cout << (*first).get_value();            ++first;        }//]    }    catch (boost::wave::cpp_exception const& e) {    // some preprocessing error        std::cerr             << e.file_name() << "(" << e.line_no() << "): "            << e.description() << std::endl;        return 2;    }    catch (std::exception const& e) {    // use last recognized token to retrieve the error position        std::cerr             << current_position.get_file()             << "(" << current_position.get_line() << "): "            << "exception caught: " << e.what()            << std::endl;        return 3;    }    catch (...) {    // use last recognized token to retrieve the error position        std::cerr             << current_position.get_file()             << "(" << current_position.get_line() << "): "            << "unexpected exception caught." << std::endl;        return 4;    }    return 0;}

⌨️ 快捷键说明

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