Fixed file/format refactoring.
Originally committed to SVN as r2473.
This commit is contained in:
parent
248dbddfdf
commit
2a0f9b7447
10 changed files with 70 additions and 7 deletions
|
@ -108,5 +108,10 @@ std::string Exception::GetExceptionMessage(int code,String message,const char *f
|
||||||
Stack stack(str);
|
Stack stack(str);
|
||||||
stack.Walk(2);
|
stack.Walk(2);
|
||||||
|
|
||||||
|
// Append extra message
|
||||||
|
if (!message.IsEmpty()) {
|
||||||
|
str = str + "\nExtra message: " + message;
|
||||||
|
}
|
||||||
|
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#include "reader.h"
|
#include "reader.h"
|
||||||
#include "text_reader.h"
|
#include "text_reader.h"
|
||||||
#include <wx/string.h>
|
#include <wx/string.h>
|
||||||
|
#include <algorithm>
|
||||||
using namespace Athenasub;
|
using namespace Athenasub;
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,8 +49,15 @@ std::vector<Format> FormatManager::formats;
|
||||||
|
|
||||||
////////////////
|
////////////////
|
||||||
// Add a format
|
// Add a format
|
||||||
void FormatManager::AddFormat(const Format format)
|
void FormatManager::AddFormat(Format format)
|
||||||
{
|
{
|
||||||
|
// Abort if there is already a format with this name
|
||||||
|
String name = format->GetName();
|
||||||
|
for (size_t i=0;i<formats.size();i++) {
|
||||||
|
if (formats[i]->GetName() == name) return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add
|
||||||
formats.push_back(format);
|
formats.push_back(format);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,8 +139,22 @@ std::vector<Format> FormatManager::GetCompatibleFormatList(Reader &reader)
|
||||||
std::vector<std::pair<float,Format> > results;
|
std::vector<std::pair<float,Format> > results;
|
||||||
size_t len = formats.size();
|
size_t len = formats.size();
|
||||||
for (size_t i=0;i<len;i++) {
|
for (size_t i=0;i<len;i++) {
|
||||||
|
// Reset reader
|
||||||
reader.Rewind();
|
reader.Rewind();
|
||||||
|
|
||||||
|
// Check how certain it is that it can read the format
|
||||||
float certainty = formats[i]->CanReadFile(reader);
|
float certainty = formats[i]->CanReadFile(reader);
|
||||||
|
|
||||||
|
// Compare to extension
|
||||||
|
StringArray exts = formats[i]->GetReadExtensions();
|
||||||
|
for (size_t j=0;j<exts.size();j++) {
|
||||||
|
if (reader.GetFileName().EndsWith(exts[j],false)) {
|
||||||
|
certainty *= 2.0f;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If it thinks that it can read the format, add to list.
|
||||||
if (certainty > 0.0f) {
|
if (certainty > 0.0f) {
|
||||||
results.push_back(std::pair<float,Format>(certainty,formats[i]));
|
results.push_back(std::pair<float,Format>(certainty,formats[i]));
|
||||||
}
|
}
|
||||||
|
@ -152,5 +174,8 @@ std::vector<Format> FormatManager::GetCompatibleFormatList(Reader &reader)
|
||||||
for (size_t i=0;i<len;i++) {
|
for (size_t i=0;i<len;i++) {
|
||||||
finalResults.push_back(results[i].second);
|
finalResults.push_back(results[i].second);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reset reader again and return results
|
||||||
|
reader.Rewind();
|
||||||
return finalResults;
|
return finalResults;
|
||||||
}
|
}
|
||||||
|
|
|
@ -199,6 +199,8 @@ void FormatHandlerASS::Save(const IModel& model,Writer &file) const
|
||||||
WriteSection(writer,section);
|
WriteSection(writer,section);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writer->Flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,8 @@
|
||||||
using namespace Athenasub;
|
using namespace Athenasub;
|
||||||
|
|
||||||
|
|
||||||
Reader::Reader(String filename,String encoding)
|
Reader::Reader(String fn,String encoding)
|
||||||
|
: filename(fn)
|
||||||
{
|
{
|
||||||
stream = shared_ptr<wxFFileInputStream>(new wxFFileInputStream(filename.GetWxString()));
|
stream = shared_ptr<wxFFileInputStream>(new wxFFileInputStream(filename.GetWxString()));
|
||||||
text = TextReader::GetReader(*stream,encoding);
|
text = TextReader::GetReader(*stream,encoding);
|
||||||
|
@ -51,6 +52,17 @@ shared_ptr<TextReader> Athenasub::Reader::GetTextReader()
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Athenasub::String Athenasub::Reader::GetFileName()
|
||||||
|
{
|
||||||
|
return filename;
|
||||||
|
}
|
||||||
|
|
||||||
|
Athenasub::Reader::~Reader()
|
||||||
|
{
|
||||||
|
text = shared_ptr<TextReader>();
|
||||||
|
stream = shared_ptr<wxFFileInputStream>();
|
||||||
|
}
|
||||||
|
|
||||||
void Reader::Rewind()
|
void Reader::Rewind()
|
||||||
{
|
{
|
||||||
text->Rewind();
|
text->Rewind();
|
||||||
|
|
|
@ -52,6 +52,7 @@ namespace Athenasub {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Reader(String filename,String encoding="");
|
Reader(String filename,String encoding="");
|
||||||
|
~Reader();
|
||||||
|
|
||||||
shared_ptr<TextReader> GetTextReader();
|
shared_ptr<TextReader> GetTextReader();
|
||||||
String GetFileName();
|
String GetFileName();
|
||||||
|
|
|
@ -58,8 +58,8 @@ TextFileWriter::TextFileWriter(wxOutputStream &stream,String enc)
|
||||||
//////////////
|
//////////////
|
||||||
// Destructor
|
// Destructor
|
||||||
TextFileWriter::~TextFileWriter() {
|
TextFileWriter::~TextFileWriter() {
|
||||||
// Flush
|
Flush();
|
||||||
if (bufferPos) file.Write(&buffer[0],(std::streamsize)bufferPos);
|
file.Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -96,9 +96,7 @@ void TextFileWriter::WriteLineToFile(String line,bool addLineBreak) {
|
||||||
|
|
||||||
// Resize buffer if it won't fit
|
// Resize buffer if it won't fit
|
||||||
if (buffer.size() < bufferPos+len) {
|
if (buffer.size() < bufferPos+len) {
|
||||||
// Flush
|
Flush();
|
||||||
file.Write(&buffer[0],(std::streamsize)bufferPos);
|
|
||||||
bufferPos = 0;
|
|
||||||
|
|
||||||
// Resize if it still doesn't fit
|
// Resize if it still doesn't fit
|
||||||
if (buffer.size() < len) buffer.resize(len);
|
if (buffer.size() < len) buffer.resize(len);
|
||||||
|
@ -143,3 +141,13 @@ void TextFileWriter::SetEncoding(String enc) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/////////
|
||||||
|
// Flush
|
||||||
|
void TextFileWriter::Flush() {
|
||||||
|
if (bufferPos) {
|
||||||
|
file.Write(&buffer[0],(std::streamsize)bufferPos);
|
||||||
|
bufferPos = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -60,5 +60,6 @@ namespace Athenasub {
|
||||||
~TextFileWriter();
|
~TextFileWriter();
|
||||||
|
|
||||||
void WriteLineToFile(Athenasub::String line,bool addLineBreak=true);
|
void WriteLineToFile(Athenasub::String line,bool addLineBreak=true);
|
||||||
|
void Flush();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,6 +47,7 @@ namespace Athenasub {
|
||||||
virtual ~TextWriter() {}
|
virtual ~TextWriter() {}
|
||||||
|
|
||||||
virtual void WriteLineToFile(String line,bool addLineBreak=true) = 0;
|
virtual void WriteLineToFile(String line,bool addLineBreak=true) = 0;
|
||||||
|
virtual void Flush() = 0;
|
||||||
|
|
||||||
static shared_ptr<TextWriter> GetWriter(wxOutputStream &stream,String encoding);
|
static shared_ptr<TextWriter> GetWriter(wxOutputStream &stream,String encoding);
|
||||||
};
|
};
|
||||||
|
|
|
@ -47,6 +47,13 @@ Writer::Writer(String filename,String encoding)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Writer::~Writer()
|
||||||
|
{
|
||||||
|
text = shared_ptr<TextWriter>();
|
||||||
|
stream = shared_ptr<wxFFileOutputStream>();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
shared_ptr<TextWriter> Writer::GetTextWriter()
|
shared_ptr<TextWriter> Writer::GetTextWriter()
|
||||||
{
|
{
|
||||||
return text;
|
return text;
|
||||||
|
|
|
@ -52,6 +52,7 @@ namespace Athenasub {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Writer(String filename,String encoding="");
|
Writer(String filename,String encoding="");
|
||||||
|
~Writer();
|
||||||
|
|
||||||
shared_ptr<TextWriter> GetTextWriter();
|
shared_ptr<TextWriter> GetTextWriter();
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue