Boost Log ライブラリで作成したログファイルを を利用して瞬時に圧縮しようとしていますboost::iostreams::gzip_compressor
。したがって、 を呼び出すとBOOST_LOG()
、出力はオンザフライで圧縮されます。これが私がこれまでに試したことです:
#include <fstream>
#include <iostream>
#include <boost/iostreams/filtering_stream.hpp>
#include <boost/iostreams/filtering_streambuf.hpp>
#include <boost/iostreams/stream.hpp>
#include <boost/iostreams/filter/gzip.hpp>
#include <boost/smart_ptr/shared_ptr.hpp>
#include <boost/smart_ptr/make_shared_object.hpp>
#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>
#include <boost/log/sinks/sync_frontend.hpp>
#include <boost/log/sinks/text_ostream_backend.hpp>
#include <boost/log/sources/logger.hpp>
void init()
{
// Construct the sink
typedef boost::log::sinks::synchronous_sink< boost::log::sinks::text_ostream_backend > text_sink;
boost::shared_ptr< text_sink > sink = boost::make_shared< text_sink >();
boost::shared_ptr< std::ofstream > file = boost::make_shared< std::ofstream >(
"sample.gz", std::ios_base::out | std::ios_base::binary );
boost::iostreams::filtering_ostream out;
out.push( boost::iostreams::gzip_compressor() );
out.push( *(file.get()) );
for( int i = 0; i < 10; i++ ) {
out << "Hello world! " << i << std::endl; // compresses OK
}
sink->locked_backend()->add_stream( file );
// Register the sink in the logging core
boost::log::core::get()->add_sink( sink );
}
int main( )
{
init();
boost::log::sources::logger lg;
for( int i = 0; i < 10; i++ )
BOOST_LOG(lg) << "Bye world!" << std::endl; // Does not compress
return 0;
}
どういうわけか、1)filtering_ostream全体をシンクとして配置するだけでなくfile
、
2) の代わりに logger シンクを何らかの方法でプッシュしfile
ますfiltering_ostream
。
誰かが私を正しい方向に向けることができますか? ありがとう!