data:image/s3,"s3://crabby-images/c40f8/c40f844dd71506326976f1871996275b0ff47c9a" alt=""
On 26/07/2013 14:49, Larry Evans wrote:
On 07/26/13 06:39, Frédéric Bron wrote:
This is how I do it with file_sink:
boost::iostreams::filtering_ostream output_file; output_file.push(boost::iostreams::bzip2_compressor(boost::iostreams::bzip2_params(9))); output_file.push(boost::iostreams::file_sink("file.bz2", std::ios_base::binary)); output_file<<"blalba";
I think if you do just this, nothing happen until output_file is destroyed. So enclose in { }.
Frédéric
Thanks Frederic.
However, I think this is not obvious. I would have thought Ken's solution would have worked. I would have also thought mine would have worked until I saw Ken's which indicated std::ios_base::binary was needed when the std::ofstream was created.
Is there anywhere in the docs explaining why your method works and Ken's doesn't?
-regards, Larry
Larry,
Passing the filtering_streambuf to a stream constructor should indeed
work, as you expect.
The test program below works fine for me - boost 1_49 on mingw 4.4.
Ken Appleby
Soft Optics Ltd
-------------------
#include <iostream>
#include <fstream>
#include