[Filesystem] v3 using wide url with boost::iostreams::mapped_file
data:image/s3,"s3://crabby-images/4e91d/4e91d716cb84b64da9b1bd4565efd1d490da71b7" alt=""
We recently flipped the switch from v2 to v3 of the boost file system. Now that boost:filesystem::wpath is no longer a valid type, how do you work with the wide url and boost:iostreams::mapped_file? With v2 we would void doSomethingWithMapfile(std::wstring& url) { boost::iostreams::basic_mapped_file_paramsboost::filesystem::wpath attribs; // initialize attribs, including attribs.path = url; // create our mapped file boost::iostreams::mapped_file mapFile(attribs); // An then do something with the map file. } Regards, Joe
data:image/s3,"s3://crabby-images/e8c14/e8c14da28edb5107b805888398e2d0a5c4b24379" alt=""
On 2/23/2011 4:01 PM, Bibbo, Joe wrote:
We recently flipped the switch from v2 to v3 of the boost file system. Now that boost:filesystem::wpath is no longer a valid type, how do you work with the wide url and boost:iostreams::mapped_file?
With v2 we would void doSomethingWithMapfile(std::wstring& url) { boost::iostreams::basic_mapped_file_paramsboost::filesystem::wpath attribs;
// initialize attribs, including
attribs.path = url;
// create our mapped file
boost::iostreams::mapped_file mapFile(attribs);
// An then do something with the map file. }
There is a ticket #4485 which seems to cover this issue https://svn.boost.org/trac/boost/ticket/4485 It looks like someone has proposed a patch to address this, so hopefully it will get applied soon... You could always apply the patch and see if it works for you.
data:image/s3,"s3://crabby-images/1b90b/1b90bfc05206175c6d3630707d7ef800325812e2" alt=""
eg wrote:
On 2/23/2011 4:01 PM, Bibbo, Joe wrote:
We recently flipped the switch from v2 to v3 of the boost file system. Now that boost:filesystem::wpath is no longer a valid type, how do you work with the wide url and boost:iostreams::mapped_file?
With v2 we would void doSomethingWithMapfile(std::wstring& url) { boost::iostreams::basic_mapped_file_paramsboost::filesystem::wpath attribs;
// initialize attribs, including
attribs.path = url;
// create our mapped file
boost::iostreams::mapped_file mapFile(attribs);
// An then do something with the map file. }
There is a ticket #4485 which seems to cover this issue https://svn.boost.org/trac/boost/ticket/4485
It looks like someone has proposed a patch to address this, so hopefully it will get applied soon...
You could always apply the patch and see if it works for you.
It's not really a patch in the true sense. You need to wrap the path that you pass to mapped_file at the client call site. I've not gotten feedback on how to fix the issue internally to iostreams. Jeff
participants (3)
-
Bibbo, Joe
-
eg
-
Jeff Flinn