Remove the platform-specific agi::io implementations since they were nearly identical

This commit is contained in:
Thomas Goyne 2012-10-21 07:57:48 -07:00
parent 9193023948
commit 063e1bc0dc
5 changed files with 11 additions and 120 deletions

View File

@ -287,6 +287,10 @@
RelativePath="..\..\libaegisub\common\hotkey.cpp"
>
</File>
<File
RelativePath="..\..\libaegisub\common\io.cpp"
>
</File>
<File
RelativePath="..\..\libaegisub\common\json.cpp"
>
@ -349,10 +353,6 @@
RelativePath="..\..\libaegisub\windows\charset_conv_win.cpp"
>
</File>
<File
RelativePath="..\..\libaegisub\windows\io.cpp"
>
</File>
<File
RelativePath="..\..\libaegisub\windows\lagi_pre.cpp"
>

View File

@ -25,6 +25,7 @@ SRC += \
common/charset_conv.cpp \
common/charset_ucd.cpp \
common/hotkey.cpp \
common/io.cpp \
common/json.cpp \
common/mru.cpp \
common/option.cpp \
@ -37,7 +38,6 @@ SRC += \
common/validator.cpp \
common/vfr.cpp \
unix/util.cpp \
unix/io.cpp \
unix/access.cpp \
unix/log.cpp \
unix/path.cpp

View File

@ -11,12 +11,10 @@
// 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 Windows IO methods.
/// @ingroup libaegisub windows
/// @ingroup libaegisub
#ifndef LAGI_PRE
#include <sys/stat.h>
@ -32,17 +30,20 @@
#include "libaegisub/log.h"
#include "libaegisub/util.h"
namespace agi {
namespace io {
using agi::charset::ConvertW;
#ifndef _WIN32
#define ConvertW
#endif
std::ifstream* Open(const std::string &file, bool binary) {
LOG_D("agi/io/open/file") << 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()) {
delete stream;
@ -52,7 +53,6 @@ std::ifstream* Open(const std::string &file, bool binary) {
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);
@ -68,10 +68,6 @@ Save::Save(const std::string& file, bool binary): file_name(file) {
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);
}
@ -84,6 +80,5 @@ std::ofstream& Save::Get() {
return *fp;
}
} // namespace io
} // namespace agi

View File

@ -31,15 +31,6 @@ namespace agi {
DEFINE_BASE_EXCEPTION_NOINNER(IOError, Exception)
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);
class Save {
@ -52,8 +43,5 @@ public:
std::ofstream& Get();
};
} // namespace io
} // namespace agi

View File

@ -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