{
#ifdef WIN32
#ifdef UNICODE
- size_t length = strlen(fileName.c_str()) + sizeof(char);
- wchar_t* path = new wchar_t[length];
- memset(path, '\0', length);
- mbstowcs(path, fileName.c_str(), length);
+ int size_needed = MultiByteToWideChar(CP_UTF8, 0, fileName.c_str(), strlen(fileName.c_str()), NULL, 0);
+ wchar_t* path = new wchar_t[size_needed + 1];
+ MultiByteToWideChar(CP_UTF8, 0, fileName.c_str(), strlen(fileName.c_str()), path, size_needed);
+ path[size_needed] = '\0';
#else
cosnt char* path = xmlPath.c_str();
#endif
{
#ifdef WIN32
#ifdef UNICODE
- const wchar_t* name = Kernel_Utils::decode(_name.data());
+ std::wstring aName = Kernel_Utils::utf8_decode_s(_name);
+ const wchar_t* name = aName.c_str();
#else
char* name = name.data();
#endif
_file = CreateFile(name, GENERIC_READ, FILE_SHARE_READ,
NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
bool ok = ( _file != INVALID_HANDLE_VALUE );
-#ifdef UNICODE
- delete name;
-#endif
#else
_file = ::open(_name.data(), O_RDONLY );
bool ok = ( _file >= 0 );
close();
boost::system::error_code err;
+#if defined(WIN32) && defined(UNICODE)
+ std::wstring name = Kernel_Utils::utf8_decode_s(_name);
+ boofs::remove(name.c_str(), err);
+#else
boofs::remove( _name, err );
+#endif
_error = err.message();
return !err;
if ( _size >= 0 ) return _size; // size of an open file
boost::system::error_code err;
+#if defined(WIN32) && defined(UNICODE)
+ std::wstring name = Kernel_Utils::utf8_decode_s(_name);
+ boost::uintmax_t size = boofs::file_size(name.c_str(), err);
+#else
boost::uintmax_t size = boofs::file_size( _name, err );
+#endif
_error = err.message();
return !err ? (long) size : -1;
bool SMESH_File::exists()
{
boost::system::error_code err;
- bool res = boofs::exists( _name, err );
+#if defined(WIN32) && defined(UNICODE)
+ std::wstring name = Kernel_Utils::utf8_decode_s(_name);
+ bool res = boofs::exists(name.c_str(), err);
+#else
+ bool res = boofs::exists(_name, err);
+#endif
+
_error = err.message();
return err ? false : res;
bool SMESH_File::isDirectory()
{
boost::system::error_code err;
+#if defined(WIN32) && defined(UNICODE)
+ std::wstring name = Kernel_Utils::utf8_decode_s(_name);
+ bool res = boofs::is_directory(name.c_str(), err);
+#else
bool res = boofs::is_directory( _name, err );
+#endif
_error = err.message();
return err ? false : res;
{
#ifdef WIN32
#ifdef UNICODE
- const wchar_t* name = Kernel_Utils::decode(_name.data());
+ std::wstring aName = Kernel_Utils::utf8_decode_s(_name);
+ const wchar_t* name = aName.c_str();
#else
char* name = name.data();
#endif
OPEN_ALWAYS, // CREATE NEW or OPEN EXISTING
FILE_ATTRIBUTE_NORMAL, // normal file
NULL); // no attr. template
-#ifdef UNICODE
- delete name;
-#endif
return ( _file != INVALID_HANDLE_VALUE );
-
#else
_file = ::open( _name.c_str(),