forked from mia/Aegisub
Remove the platform-specific agi::io implementations since they were nearly identical
This commit is contained in:
parent
9193023948
commit
063e1bc0dc
5 changed files with 11 additions and 120 deletions
|
@ -287,6 +287,10 @@
|
||||||
RelativePath="..\..\libaegisub\common\hotkey.cpp"
|
RelativePath="..\..\libaegisub\common\hotkey.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath="..\..\libaegisub\common\io.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\libaegisub\common\json.cpp"
|
RelativePath="..\..\libaegisub\common\json.cpp"
|
||||||
>
|
>
|
||||||
|
@ -349,10 +353,6 @@
|
||||||
RelativePath="..\..\libaegisub\windows\charset_conv_win.cpp"
|
RelativePath="..\..\libaegisub\windows\charset_conv_win.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
|
||||||
RelativePath="..\..\libaegisub\windows\io.cpp"
|
|
||||||
>
|
|
||||||
</File>
|
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\libaegisub\windows\lagi_pre.cpp"
|
RelativePath="..\..\libaegisub\windows\lagi_pre.cpp"
|
||||||
>
|
>
|
||||||
|
|
|
@ -25,6 +25,7 @@ SRC += \
|
||||||
common/charset_conv.cpp \
|
common/charset_conv.cpp \
|
||||||
common/charset_ucd.cpp \
|
common/charset_ucd.cpp \
|
||||||
common/hotkey.cpp \
|
common/hotkey.cpp \
|
||||||
|
common/io.cpp \
|
||||||
common/json.cpp \
|
common/json.cpp \
|
||||||
common/mru.cpp \
|
common/mru.cpp \
|
||||||
common/option.cpp \
|
common/option.cpp \
|
||||||
|
@ -37,7 +38,6 @@ SRC += \
|
||||||
common/validator.cpp \
|
common/validator.cpp \
|
||||||
common/vfr.cpp \
|
common/vfr.cpp \
|
||||||
unix/util.cpp \
|
unix/util.cpp \
|
||||||
unix/io.cpp \
|
|
||||||
unix/access.cpp \
|
unix/access.cpp \
|
||||||
unix/log.cpp \
|
unix/log.cpp \
|
||||||
unix/path.cpp
|
unix/path.cpp
|
||||||
|
|
|
@ -11,12 +11,10 @@
|
||||||
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
|
|
||||||
/// @file io.cpp
|
/// @file io.cpp
|
||||||
/// @brief Windows IO methods.
|
/// @brief Windows IO methods.
|
||||||
/// @ingroup libaegisub windows
|
/// @ingroup libaegisub
|
||||||
|
|
||||||
#ifndef LAGI_PRE
|
#ifndef LAGI_PRE
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
@ -32,17 +30,20 @@
|
||||||
#include "libaegisub/log.h"
|
#include "libaegisub/log.h"
|
||||||
#include "libaegisub/util.h"
|
#include "libaegisub/util.h"
|
||||||
|
|
||||||
|
|
||||||
namespace agi {
|
namespace agi {
|
||||||
namespace io {
|
namespace io {
|
||||||
|
|
||||||
using agi::charset::ConvertW;
|
using agi::charset::ConvertW;
|
||||||
|
|
||||||
|
#ifndef _WIN32
|
||||||
|
#define ConvertW
|
||||||
|
#endif
|
||||||
|
|
||||||
std::ifstream* Open(const std::string &file, bool binary) {
|
std::ifstream* Open(const std::string &file, bool binary) {
|
||||||
LOG_D("agi/io/open/file") << file;
|
LOG_D("agi/io/open/file") << file;
|
||||||
acs::CheckFileRead(file);
|
acs::CheckFileRead(file);
|
||||||
|
|
||||||
std::ifstream *stream = new std::ifstream(ConvertW(file).c_str(), std::ios::in | (binary ? std::ios::binary : 0));
|
std::ifstream *stream = new std::ifstream(ConvertW(file).c_str(), (binary ? std::ios::binary : std::ios::in));
|
||||||
|
|
||||||
if (stream->fail()) {
|
if (stream->fail()) {
|
||||||
delete stream;
|
delete stream;
|
||||||
|
@ -52,7 +53,6 @@ std::ifstream* Open(const std::string &file, bool binary) {
|
||||||
return stream;
|
return stream;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Save::Save(const std::string& file, bool binary): file_name(file) {
|
Save::Save(const std::string& file, bool binary): file_name(file) {
|
||||||
LOG_D("agi/io/save/file") << file;
|
LOG_D("agi/io/save/file") << file;
|
||||||
const std::string pwd = util::DirName(file);
|
const std::string pwd = util::DirName(file);
|
||||||
|
@ -68,10 +68,6 @@ Save::Save(const std::string& file, bool binary): file_name(file) {
|
||||||
std::ofstream fp_touch(ConvertW(file).c_str());
|
std::ofstream fp_touch(ConvertW(file).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @todo This is a temp hack, proper implementation needs to come after
|
|
||||||
/// Windows support is added. The code in the destructor needs fixing
|
|
||||||
/// as well.
|
|
||||||
// This will open to file.XXXX. (tempfile)
|
|
||||||
fp = new std::ofstream(ConvertW(file + "_tmp").c_str(), binary ? std::ios::binary : std::ios::out);
|
fp = new std::ofstream(ConvertW(file + "_tmp").c_str(), binary ? std::ios::binary : std::ios::out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,6 +80,5 @@ std::ofstream& Save::Get() {
|
||||||
return *fp;
|
return *fp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace io
|
} // namespace io
|
||||||
} // namespace agi
|
} // namespace agi
|
|
@ -31,15 +31,6 @@ namespace agi {
|
||||||
DEFINE_BASE_EXCEPTION_NOINNER(IOError, Exception)
|
DEFINE_BASE_EXCEPTION_NOINNER(IOError, Exception)
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IOFatal, IOError, "io/fatal")
|
DEFINE_SIMPLE_EXCEPTION_NOINNER(IOFatal, IOError, "io/fatal")
|
||||||
|
|
||||||
/*
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IOAccess, IOError, "io/access")
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IONotFound, IOError, "io/notfound")
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IONotAFile, IOError, "io/file")
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IONotADirectory, IOError, "io/directory")
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IOAccessRead, IOError, "io/read")
|
|
||||||
DEFINE_SIMPLE_EXCEPTION_NOINNER(IOAccessWrite, IOError, "io/write")
|
|
||||||
*/
|
|
||||||
|
|
||||||
std::ifstream* Open(const std::string &file, bool binary = false);
|
std::ifstream* Open(const std::string &file, bool binary = false);
|
||||||
|
|
||||||
class Save {
|
class Save {
|
||||||
|
@ -52,8 +43,5 @@ public:
|
||||||
std::ofstream& Get();
|
std::ofstream& Get();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
} // namespace io
|
} // namespace io
|
||||||
} // namespace agi
|
} // namespace agi
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,92 +0,0 @@
|
||||||
// Copyright (c) 2010, Amar Takhar <verm@aegisub.org>
|
|
||||||
//
|
|
||||||
// Permission to use, copy, modify, and distribute this software for any
|
|
||||||
// purpose with or without fee is hereby granted, provided that the above
|
|
||||||
// copyright notice and this permission notice appear in all copies.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
||||||
// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
||||||
// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
||||||
// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
||||||
// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
||||||
// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
|
|
||||||
/// @file io.cpp
|
|
||||||
/// @brief Unix IO methods.
|
|
||||||
/// @ingroup libaegisub unix
|
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
|
|
||||||
#include "libaegisub/io.h"
|
|
||||||
|
|
||||||
#ifndef LAGI_PRE
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <errno.h>
|
|
||||||
|
|
||||||
#include <iostream>
|
|
||||||
#include <fstream>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "libaegisub/access.h"
|
|
||||||
#include "libaegisub/log.h"
|
|
||||||
#include "libaegisub/util.h"
|
|
||||||
|
|
||||||
|
|
||||||
namespace agi {
|
|
||||||
namespace io {
|
|
||||||
|
|
||||||
std::ifstream* Open(const std::string &file, bool) {
|
|
||||||
LOG_D("agi/io/open/file") << file;
|
|
||||||
acs::CheckFileRead(file);
|
|
||||||
|
|
||||||
std::ifstream *stream = new std::ifstream(file.c_str());
|
|
||||||
|
|
||||||
if (stream->fail())
|
|
||||||
throw IOFatal("Unknown fatal error as occurred");
|
|
||||||
|
|
||||||
return stream;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Save::Save(const std::string& file, bool binary): file_name(file) {
|
|
||||||
LOG_D("agi/io/save/file") << file;
|
|
||||||
const std::string pwd = util::DirName(file);
|
|
||||||
|
|
||||||
acs::CheckDirWrite(pwd.c_str());
|
|
||||||
|
|
||||||
try {
|
|
||||||
acs::CheckFileWrite(file);
|
|
||||||
} catch (FileNotFoundError const&) {
|
|
||||||
// If the file doesn't exist we create a 0 byte file, this so so
|
|
||||||
// util::Rename will find it, and to let users know something went
|
|
||||||
// wrong by leaving a 0 byte file.
|
|
||||||
(void)std::ofstream(file.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo This is a temp hack, proper implementation needs to come after
|
|
||||||
/// Windows support is added. The code in the destructor needs fixing
|
|
||||||
/// as well.
|
|
||||||
const std::string tmp = file + "_tmp";
|
|
||||||
|
|
||||||
// This will open to file.XXXX. (tempfile)
|
|
||||||
fp = new std::ofstream(tmp.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
Save::~Save() {
|
|
||||||
|
|
||||||
const std::string tmp(file_name + "_tmp");
|
|
||||||
util::Rename(tmp, file_name);
|
|
||||||
delete fp;
|
|
||||||
fp = 0; // to avoid any silly errors.
|
|
||||||
}
|
|
||||||
|
|
||||||
std::ofstream& Save::Get() {
|
|
||||||
return *fp;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // namespace io
|
|
||||||
} // namespace agi
|
|
Loading…
Reference in a new issue