C ++ "Привет, мир!" - PullRequest
       66

C ++ "Привет, мир!"

12 голосов
/ 16 июня 2009

Библиотека Boost C ++ имеет Тройник шаблона функции

Шаблоны классов tee_filter и tee_device предоставляют два способа разделения выходной последовательности так что все данные направляются одновременно в два разных места.

Я ищу полный пример C ++, использующий тройник Boost для вывода в стандартный формат и в файл типа «sample.txt».

Ответы [ 2 ]

26 голосов
/ 16 июня 2009

Основано на помощи из вопроса Джона, связанного:

#include <boost/iostreams/tee.hpp>
#include <boost/iostreams/stream.hpp>
#include <fstream>
#include <iostream>

using std::ostream;
using std::ofstream;
using std::cout;

namespace bio = boost::iostreams;
using bio::tee_device;
using bio::stream;

int main()
{
    typedef tee_device<ostream, ofstream> TeeDevice;
    typedef stream<TeeDevice> TeeStream;
    ofstream ofs("sample.txt");
    TeeDevice my_tee(cout, ofs); 
    TeeStream my_split(my_tee);
    my_split << "Hello, World!\n";
    my_split.flush();
    my_split.close();
}
0 голосов
/ 02 ноября 2014

Вот пример использования tee_filter, который я сейчас использую для вывода моего Boost.Test:

{ // init code, use static streams to keep them alive until test run process end

    using namespace boost::iostreams;
    static ofstream ofs("boost_test_output.log.xml"); // log file
    static tee_filter<ostream>  fileFilt(ofs); // tee all passed data to logfile

    // note derives from `boost::iostreams::output_filter`
    static text_xml_readability_filter xmlFilt; // filter all passed data, making the XML output readable

    static filtering_ostream filter; // master filter

    filter.push(fileFilt); // 1st, tee off any data to the file (raw boost XML)
    filter.push(xmlFilt);  // 2nd make the xml data stream readable (linebreaks, etc.)
    filter.push(cout);     // 3rd output the readable XML to cout

    boost::unit_test::unit_test_log.set_stream( filter );
}
...