Some refactoring of Athenasub, mostly related to const correctness.

Originally committed to SVN as r2460.
This commit is contained in:
Rodrigo Braz Monteiro 2008-11-16 00:58:08 +00:00
parent 07a7576547
commit 9280b56e34
16 changed files with 166 additions and 79 deletions

View file

@ -57,6 +57,11 @@ namespace Athenasub {
String(const basic_string<Character>& str); String(const basic_string<Character>& str);
explicit String(const wchar_t* utf16); explicit String(const wchar_t* utf16);
explicit String(const wxString& wxstring); explicit String(const wxString& wxstring);
explicit String(char character);
explicit String(wchar_t character);
explicit String(int integer);
explicit String(float number);
explicit String(double number);
wxString GetWxString() const; wxString GetWxString() const;

View file

@ -107,10 +107,6 @@ namespace Athenasub {
protected: protected:
virtual void ProcessActionList(CActionList &actionList,int type=0) = 0; virtual void ProcessActionList(CActionList &actionList,int type=0) = 0;
virtual String GetUndoMessage(const String owner="") const = 0;
virtual String GetRedoMessage(const String owner="") const = 0;
virtual bool CanUndo(const String owner="") const = 0;
virtual bool CanRedo(const String owner="") const = 0;
virtual void Undo(const String owner="") = 0; virtual void Undo(const String owner="") = 0;
virtual void Redo(const String owner="") = 0; virtual void Redo(const String owner="") = 0;
virtual void ActivateStack(ActionStack stack,bool isUndo,const String &owner) = 0; virtual void ActivateStack(ActionStack stack,bool isUndo,const String &owner) = 0;
@ -119,22 +115,29 @@ namespace Athenasub {
virtual void Clear() = 0; virtual void Clear() = 0;
virtual void Load(wxInputStream &input,Format format=Format(),const String encoding="") = 0; virtual void Load(wxInputStream &input,Format format=Format(),const String encoding="") = 0;
virtual void Save(wxOutputStream &output,Format format=Format(),const String encoding="UTF-8") = 0;
virtual void AddSection(String name) = 0; virtual void AddSection(String name) = 0;
virtual Section GetSection(String name) = 0; virtual Section GetMutableSection(String name) = 0;
virtual Section GetSectionByIndex(size_t index) = 0; virtual Section GetMutableSectionByIndex(size_t index) = 0;
public: public:
virtual ~IModel() {} virtual ~IModel() {}
virtual Controller CreateController() = 0;
virtual void AddListener(View listener) = 0;
virtual void Save(wxOutputStream &output,Format format=Format(),const String encoding="UTF-8") const = 0;
virtual String GetUndoMessage(const String owner="") const = 0;
virtual String GetRedoMessage(const String owner="") const = 0;
virtual bool CanUndo(const String owner="") const = 0;
virtual bool CanRedo(const String owner="") const = 0;
virtual ConstSection GetSection(String name) const = 0; virtual ConstSection GetSection(String name) const = 0;
virtual ConstSection GetSectionByIndex(size_t index) const = 0; virtual ConstSection GetSectionByIndex(size_t index) const = 0;
virtual size_t GetSectionCount() const = 0; virtual size_t GetSectionCount() const = 0;
virtual Controller CreateController()=0; virtual Format GetFormat() const = 0;
virtual Format GetFormat() const=0;
virtual void AddListener(View listener)=0;
}; };
@ -314,7 +317,7 @@ namespace Athenasub {
virtual String GetName() const = 0; virtual String GetName() const = 0;
virtual StringArray GetReadExtensions() const = 0; virtual StringArray GetReadExtensions() const = 0;
virtual StringArray GetWriteExtensions() const = 0; virtual StringArray GetWriteExtensions() const = 0;
virtual FormatHandler GetHandler(IModel &model) const = 0; virtual FormatHandler GetHandler() const = 0;
virtual bool CanStoreText() const = 0; virtual bool CanStoreText() const = 0;
virtual bool CanStoreImages() const = 0; virtual bool CanStoreImages() const = 0;
@ -340,8 +343,8 @@ namespace Athenasub {
public: public:
virtual ~IFormatHandler() {} virtual ~IFormatHandler() {}
virtual void Load(wxInputStream &file,const String encoding) = 0; virtual void Load(IModel &model,wxInputStream &file,const String encoding) = 0;
virtual void Save(wxOutputStream &file,const String encoding) = 0; virtual void Save(const IModel &model,wxOutputStream &file,const String encoding) const = 0;
}; };

View file

@ -49,7 +49,7 @@ namespace Athenasub {
CAction(Model model); CAction(Model model);
Model GetModel() const { return model; } Model GetModel() const { return model; }
Section GetSection(String name) const { return model->GetSection(name); } Section GetSection(String name) const { return model->GetMutableSection(name); }
}; };
// Insert line // Insert line

View file

@ -125,7 +125,7 @@ void CActionList::RemoveLine(int position,const String section)
// Insert a "modify line" action // Insert a "modify line" action
Entry CActionList::ModifyLine(int position,const String section) Entry CActionList::ModifyLine(int position,const String section)
{ {
Section sect = Model(model)->GetSection(section); Section sect = Model(model)->GetMutableSection(section);
Entry entry = sect->GetEntry(position)->Clone(); Entry entry = sect->GetEntry(position)->Clone();
Action action = Action (new ActionModify(model.lock(),entry,position,section,false)); Action action = Action (new ActionModify(model.lock(),entry,position,section,false));
AddAction(action); AddAction(action);
@ -138,7 +138,7 @@ Entry CActionList::ModifyLine(int position,const String section)
std::vector<Entry> CActionList::ModifyLines(Selection selection,const String section) std::vector<Entry> CActionList::ModifyLines(Selection selection,const String section)
{ {
// Get section // Get section
Section sect = Model(model)->GetSection(section); Section sect = Model(model)->GetMutableSection(section);
// Generate entries // Generate entries
std::vector<Entry> entries(selection->GetCount()); std::vector<Entry> entries(selection->GetCount());

View file

@ -82,6 +82,39 @@ String::String(const wxString& wxstring)
} }
String::String(char character)
{
*this = std::string(character,1);
}
String::String(wchar_t character)
{
wchar_t tmp[2];
tmp[0] = character;
tmp[1] = 0;
*this = String(tmp);
}
String::String(int integer)
{
*this = IntegerToString(integer);
}
String::String(float number)
{
*this = FloatToString(number);
}
String::String(double number)
{
*this = FloatToString(number);
}
Character* String::GetCharPointer(size_t pos) Character* String::GetCharPointer(size_t pos)
{ {
return &operator[](pos); return &operator[](pos);

View file

@ -148,7 +148,7 @@ ConstStyle CController::GetStyle(String name) const
// Get section // Get section
Style dummy = CreateStyle(); Style dummy = CreateStyle();
String section = dummy->GetDefaultGroup(); String section = dummy->GetDefaultGroup();
Section sect = model->GetSection(section); ConstSection sect = model->GetSection(section);
if (!sect) THROW_ATHENA_EXCEPTION(Exception::Invalid_Section); if (!sect) THROW_ATHENA_EXCEPTION(Exception::Invalid_Section);
// Return from index // Return from index
@ -160,7 +160,7 @@ ConstStyle CController::GetStyle(String name) const
// Get an entry // Get an entry
ConstEntry CController::GetEntry(size_t n,String section) const ConstEntry CController::GetEntry(size_t n,String section) const
{ {
Section sect = model->GetSection(section); ConstSection sect = model->GetSection(section);
if (!sect) THROW_ATHENA_EXCEPTION(Exception::Invalid_Section); if (!sect) THROW_ATHENA_EXCEPTION(Exception::Invalid_Section);
return sect->GetEntry(n); return sect->GetEntry(n);
} }

View file

@ -42,24 +42,21 @@ namespace Athenasub {
// Format handler interface // Format handler interface
class CFormatHandler : public IFormatHandler { class CFormatHandler : public IFormatHandler {
private:
IModel& model;
protected: protected:
virtual ~CFormatHandler() {} virtual ~CFormatHandler() {}
IModel& GetModel() const { return model; } void AddSection(IModel &model,String name) const { model.AddSection(name); }
ConstSection GetSection(const IModel &model,String name) const { return model.GetSection(name); }
void AddSection(String name) { model.AddSection(name); } ConstSection GetSectionByIndex(const IModel &model,size_t index) const { return model.GetSectionByIndex(index); }
Section GetSection(String name) const { return model.GetSection(name); } Section GetSection(IModel &model,String name) const { return model.GetMutableSection(name); }
Section GetSectionByIndex(size_t index) const { return model.GetSectionByIndex(index); } Section GetSectionByIndex(IModel &model,size_t index) const { return model.GetMutableSectionByIndex(index); }
size_t GetSectionCount() const { return model.GetSectionCount(); } size_t GetSectionCount(const IModel &model) const { return model.GetSectionCount(); }
public: public:
CFormatHandler(IModel& _model) : model(_model) {} //CFormatHandler(IModel& _model) : model(_model) {}
virtual void Load(wxInputStream &file,const String encoding) = 0; virtual void Load(IModel &model,wxInputStream &file,const String encoding) = 0;
virtual void Save(wxOutputStream &file,const String encoding) = 0; virtual void Save(const IModel &model,wxOutputStream &file,const String encoding) const = 0;
}; };
} }

View file

@ -90,8 +90,8 @@ StringArray FormatASS2::GetWriteExtensions() const
/////////////// ///////////////
// Constructor // Constructor
FormatHandlerASS::FormatHandlerASS(CModel &_model,int version) FormatHandlerASS::FormatHandlerASS(int version)
: CFormatHandler(_model), formatVersion(version) : CFormatHandler(), formatVersion(version)
{ {
} }
@ -105,7 +105,7 @@ FormatHandlerASS::~FormatHandlerASS()
/////////////// ///////////////
// Load a file // Load a file
void FormatHandlerASS::Load(wxInputStream &file,const String encoding) void FormatHandlerASS::Load(IModel &model,wxInputStream &file,const String encoding)
{ {
// Make text file reader // Make text file reader
TextFileReader reader(file,encoding); TextFileReader reader(file,encoding);
@ -127,10 +127,10 @@ void FormatHandlerASS::Load(wxInputStream &file,const String encoding)
ProcessGroup(cur,curGroup,version); ProcessGroup(cur,curGroup,version);
// Insert group if it doesn't already exist // Insert group if it doesn't already exist
if (prevGroup != curGroup) section = GetSection(curGroup); if (prevGroup != curGroup) section = GetSection(model,curGroup);
if (!section) { if (!section) {
AddSection(curGroup); AddSection(model,curGroup);
section = GetSection(curGroup); section = GetSection(model,curGroup);
} }
// Skip [] lines // Skip [] lines
@ -142,13 +142,13 @@ void FormatHandlerASS::Load(wxInputStream &file,const String encoding)
} }
// Ensure validity // Ensure validity
MakeValid(); MakeValid(model);
} }
///////////////////// /////////////////////
// Save file to disc // Save file to disc
void FormatHandlerASS::Save(wxOutputStream &file,const String encoding) void FormatHandlerASS::Save(const IModel& model,wxOutputStream &file,const String encoding) const
{ {
// Make text file writer // Make text file writer
TextFileWriter writer(file,encoding); TextFileWriter writer(file,encoding);
@ -162,9 +162,9 @@ void FormatHandlerASS::Save(wxOutputStream &file,const String encoding)
sections.push_back("Graphics"); sections.push_back("Graphics");
// Look for remaining sections // Look for remaining sections
size_t totalSections = GetSectionCount(); size_t totalSections = GetSectionCount(model);
for (size_t i=0;i<totalSections;i++) { for (size_t i=0;i<totalSections;i++) {
String name = GetSectionByIndex(i)->GetName(); String name = GetSectionByIndex(model,i)->GetName();
// If not found on the list, add to it // If not found on the list, add to it
if (find(sections.begin(),sections.end(),name) == sections.end()) { if (find(sections.begin(),sections.end(),name) == sections.end()) {
sections.push_back(name); sections.push_back(name);
@ -175,7 +175,7 @@ void FormatHandlerASS::Save(wxOutputStream &file,const String encoding)
size_t len = sections.size(); size_t len = sections.size();
for (size_t i=0;i<len;i++) { for (size_t i=0;i<len;i++) {
// See if it exists // See if it exists
Section section = GetSection(sections[i]); ConstSection section = GetSection(model,sections[i]);
if (section) { if (section) {
// Add a spacer // Add a spacer
if (i != 0) writer.WriteLineToFile(""); if (i != 0) writer.WriteLineToFile("");
@ -334,7 +334,7 @@ void FormatHandlerASS::ProcessGroup(String cur,String &curGroup,int &version) {
/////////////////////////////// ///////////////////////////////
// Write a section to the file // Write a section to the file
void FormatHandlerASS::WriteSection(TextFileWriter &writer,Section section) void FormatHandlerASS::WriteSection(TextFileWriter &writer,ConstSection section) const
{ {
// Write name // Write name
String name = section->GetName(); String name = section->GetName();
@ -371,15 +371,15 @@ void FormatHandlerASS::WriteSection(TextFileWriter &writer,Section section)
/////////////////////// ///////////////////////
// Validate the format // Validate the format
void FormatHandlerASS::MakeValid() void FormatHandlerASS::MakeValid(IModel &model)
{ {
// Only ASS supported right now // Only ASS supported right now
if (formatVersion != 1) THROW_ATHENA_EXCEPTION(Exception::TODO); if (formatVersion != 1) THROW_ATHENA_EXCEPTION(Exception::TODO);
// Check for [Script Info] // Check for [Script Info]
Section section = GetSection("Script Info"); Section section = GetSection(model,"Script Info");
if (!section) AddSection("Script Info"); if (!section) AddSection(model,"Script Info");
section = GetSection("Script Info"); section = GetSection(model,"Script Info");
if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error); if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error);
// Check if necessary variables are available // Check if necessary variables are available
@ -388,16 +388,16 @@ void FormatHandlerASS::MakeValid()
section->SetProperty("ScriptType","v4.00+"); section->SetProperty("ScriptType","v4.00+");
// Get [V4+ Styles] // Get [V4+ Styles]
section = GetSection("V4+ Styles"); section = GetSection(model,"V4+ Styles");
if (!section) AddSection("V4+ Styles"); if (!section) AddSection(model,"V4+ Styles");
section = GetSection("V4+ Styles"); section = GetSection(model,"V4+ Styles");
if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error); if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error);
section->SetProperty("Format","Name, Fontname, Fontsize, PrimaryColour, SecondaryColour, OutlineColour, BackColour, Bold, Italic, Underline, StrikeOut, ScaleX, ScaleY, Spacing, Angle, BorderStyle, Outline, Shadow, Alignment, MarginL, MarginR, MarginV, Encoding"); section->SetProperty("Format","Name, Fontname, Fontsize, PrimaryColour, SecondaryColour, OutlineColour, BackColour, Bold, Italic, Underline, StrikeOut, ScaleX, ScaleY, Spacing, Angle, BorderStyle, Outline, Shadow, Alignment, MarginL, MarginR, MarginV, Encoding");
// Get [Events] // Get [Events]
section = GetSection("Events"); section = GetSection(model,"Events");
if (!section) AddSection("Events"); if (!section) AddSection(model,"Events");
section = GetSection("Events"); section = GetSection(model,"Events");
if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error); if (!section) THROW_ATHENA_EXCEPTION(Exception::Internal_Error);
section->SetProperty("Format","Layer, Start, End, Style, Actor, MarginL, MarginR, MarginV, Effect, Text"); section->SetProperty("Format","Layer, Start, End, Style, Actor, MarginL, MarginR, MarginV, Effect, Text");
} }

View file

@ -55,15 +55,15 @@ namespace Athenasub {
Entry MakeEntry(const String &data,Section section,int version); Entry MakeEntry(const String &data,Section section,int version);
void ProcessGroup(String cur,String &curGroup,int &version); void ProcessGroup(String cur,String &curGroup,int &version);
void WriteSection(TextFileWriter &writer,Section section); void WriteSection(TextFileWriter &writer,ConstSection section) const;
void MakeValid(); void MakeValid(IModel &model);
public: public:
FormatHandlerASS(CModel &model,int version); FormatHandlerASS(int version);
~FormatHandlerASS(); ~FormatHandlerASS();
void Load(wxInputStream &file,const String encoding); void Load(IModel &model,wxInputStream &file,const String encoding);
void Save(wxOutputStream &file,const String encoding); void Save(const IModel &model,wxOutputStream &file,const String encoding) const;
}; };
// Advanced Substation Alpha format base class // Advanced Substation Alpha format base class
@ -92,7 +92,7 @@ namespace Athenasub {
// Substation Alpha // Substation Alpha
class FormatSSA : public FormatASSFamily { class FormatSSA : public FormatASSFamily {
public: public:
FormatHandler GetHandler(IModel &model) const { return FormatHandler(new FormatHandlerASS((CModel&)model,0)); } FormatHandler GetHandler() const { return FormatHandler(new FormatHandlerASS(0)); }
String GetName() const { return "Substation Alpha"; } String GetName() const { return "Substation Alpha"; }
StringArray GetReadExtensions() const; StringArray GetReadExtensions() const;
StringArray GetWriteExtensions() const; StringArray GetWriteExtensions() const;
@ -101,7 +101,7 @@ namespace Athenasub {
// Advanced Substation Alpha // Advanced Substation Alpha
class FormatASS : public FormatASSFamily { class FormatASS : public FormatASSFamily {
public: public:
FormatHandler GetHandler(IModel &model) const { return FormatHandler(new FormatHandlerASS((CModel&)model,1)); } FormatHandler GetHandler() const { return FormatHandler(new FormatHandlerASS(1)); }
String GetName() const { return "Advanced Substation Alpha"; } String GetName() const { return "Advanced Substation Alpha"; }
StringArray GetReadExtensions() const; StringArray GetReadExtensions() const;
StringArray GetWriteExtensions() const; StringArray GetWriteExtensions() const;
@ -110,7 +110,7 @@ namespace Athenasub {
// Advanced Substation Alpha 2 // Advanced Substation Alpha 2
class FormatASS2 : public FormatASSFamily { class FormatASS2 : public FormatASSFamily {
public: public:
FormatHandler GetHandler(IModel &model) const { return FormatHandler(new FormatHandlerASS((CModel&)model,2)); } FormatHandler GetHandler() const { return FormatHandler(new FormatHandlerASS(2)); }
String GetName() const { return "Advanced Substation Alpha 2"; } String GetName() const { return "Advanced Substation Alpha 2"; }
StringArray GetReadExtensions() const; StringArray GetReadExtensions() const;
StringArray GetWriteExtensions() const; StringArray GetWriteExtensions() const;

View file

@ -202,3 +202,22 @@ String DialogueASS::ToText(int version) const
buffer.SetSize(pos-1); buffer.SetSize(pos-1);
return buffer; return buffer;
} }
////////////////////////
// Overloaded operators
bool DialogueASS::operator==(const DialogueASS& param) const
{
if (time != param.time) return false;
if (text != param.text) return false;
if (margin != param.margin) return false;
if (layer != param.layer) return false;
if (isComment != param.isComment) return false;
return true;
}
bool DialogueASS::operator!=(const DialogueASS& param) const
{
return !(*this == param);
}

View file

@ -93,6 +93,10 @@ namespace Athenasub {
void SetStyle(const String &style) { text[1] = style; } void SetStyle(const String &style) { text[1] = style; }
void SetActor(const String &actor) { text[2] = actor; } void SetActor(const String &actor) { text[2] = actor; }
void SetUserField(const String &userField) { text[3] = userField; } void SetUserField(const String &userField) { text[3] = userField; }
// Operator overloading
bool operator==(const DialogueASS& param) const;
bool operator!=(const DialogueASS& param) const;
}; };
} }

View file

@ -118,14 +118,14 @@ void CModel::Load(wxInputStream &input,const Format _format,const String encodin
} }
// Get handler // Get handler
FormatHandler handler = _format->GetHandler(*this); FormatHandler handler = _format->GetHandler();
if (!handler) THROW_ATHENA_EXCEPTION(Exception::No_Format_Handler); if (!handler) THROW_ATHENA_EXCEPTION(Exception::No_Format_Handler);
// Clear the model first // Clear the model first
Clear(); Clear();
// Load // Load
handler->Load(input,encoding); handler->Load(*this,input,encoding);
// Set the format // Set the format
format = _format; format = _format;
@ -134,7 +134,7 @@ void CModel::Load(wxInputStream &input,const Format _format,const String encodin
////////////////// //////////////////
// Save subtitles // Save subtitles
void CModel::Save(wxOutputStream &output,const Format _format,const String encoding) void CModel::Save(wxOutputStream &output,const Format _format,const String encoding) const
{ {
// Use another format // Use another format
if (_format && _format != format) { if (_format && _format != format) {
@ -143,11 +143,11 @@ void CModel::Save(wxOutputStream &output,const Format _format,const String encod
} }
// Get handler // Get handler
FormatHandler handler = format->GetHandler(*this); FormatHandler handler = format->GetHandler();
if (!handler) THROW_ATHENA_EXCEPTION(Exception::No_Format_Handler); if (!handler) THROW_ATHENA_EXCEPTION(Exception::No_Format_Handler);
// Load // Load
handler->Save(output,encoding); handler->Save(*this,output,encoding);
} }
@ -155,7 +155,7 @@ void CModel::Save(wxOutputStream &output,const Format _format,const String encod
// Inserts a new section // Inserts a new section
void CModel::AddSection(String name) void CModel::AddSection(String name)
{ {
Section prev = GetSection(name); ConstSection prev = GetSection(name);
if (prev) THROW_ATHENA_EXCEPTION(Exception::Section_Already_Exists); if (prev) THROW_ATHENA_EXCEPTION(Exception::Section_Already_Exists);
sections.push_back(Section(new CSection(name))); sections.push_back(Section(new CSection(name)));
} }
@ -172,7 +172,7 @@ ConstSection CModel::GetSection(String name) const
return SectionPtr(); return SectionPtr();
} }
Section CModel::GetSection(String name) Section CModel::GetMutableSection(String name)
{ {
size_t len = sections.size(); size_t len = sections.size();
for (size_t i=0;i<len;i++) { for (size_t i=0;i<len;i++) {
@ -189,7 +189,7 @@ ConstSection CModel::GetSectionByIndex(size_t index) const
return sections.at(index); return sections.at(index);
} }
Section CModel::GetSectionByIndex(size_t index) Section CModel::GetMutableSectionByIndex(size_t index)
{ {
return sections.at(index); return sections.at(index);
} }

View file

@ -51,6 +51,7 @@ namespace Athenasub {
friend class CActionList; friend class CActionList;
friend class CController; friend class CController;
friend class CAction; friend class CAction;
friend class CLibAthenaSub;
private: private:
weak_ptr<IModel> weakThis; weak_ptr<IModel> weakThis;
@ -80,22 +81,24 @@ namespace Athenasub {
void Clear(); void Clear();
void Load(wxInputStream &input,Format format=Format(),const String encoding=""); void Load(wxInputStream &input,Format format=Format(),const String encoding="");
void Save(wxOutputStream &output,Format format=Format(),const String encoding="UTF-8");
void AddSection(String name); void AddSection(String name);
ConstSection GetSection(String name) const; Section GetMutableSection(String name);
Section GetSection(String name); Section GetMutableSectionByIndex(size_t index);
ConstSection GetSectionByIndex(size_t index) const;
Section GetSectionByIndex(size_t index); void SetWeakPtr(weak_ptr<IModel> ptr) { weakThis = ptr; }
size_t GetSectionCount() const;
public: public:
CModel(); CModel();
Controller CreateController(); Controller CreateController();
Format GetFormat() const { return format; } Format GetFormat() const { return format; }
void AddListener(View listener);
void SetWeakPtr(weak_ptr<IModel> ptr) { weakThis = ptr; } void AddListener(View listener);
void Save(wxOutputStream &output,Format format=Format(),const String encoding="UTF-8") const;
ConstSection GetSection(String name) const;
ConstSection GetSectionByIndex(size_t index) const;
size_t GetSectionCount() const;
}; };
typedef shared_ptr<CModel> ModelPtr; typedef shared_ptr<CModel> ModelPtr;

View file

@ -92,9 +92,9 @@ int main()
// Issue an action // Issue an action
#ifdef WXDEBUG #ifdef WXDEBUG
int n = 1000;
#else
int n = 1; int n = 1;
#else
int n = 1000;
#endif #endif
cout << "Executing action " << n << " times... "; cout << "Executing action " << n << " times... ";
timer.Start(); timer.Start();
@ -126,7 +126,7 @@ int main()
cout << "Done in " << timer.Time() << " ms.\n"; cout << "Done in " << timer.Time() << " ms.\n";
// Undo // Undo
n = 1000; n = 10;
cout << "Undoing and redoing " << n << " times... "; cout << "Undoing and redoing " << n << " times... ";
timer.Start(); timer.Start();
for (int i=0;i<n;i++) { for (int i=0;i<n;i++) {

View file

@ -78,6 +78,16 @@ public:
CPPUNIT_ASSERT(refDiag.GetText() == "Text, why halo thar?"); CPPUNIT_ASSERT(refDiag.GetText() == "Text, why halo thar?");
DialogueASS diag; DialogueASS diag;
CPPUNIT_ASSERT(diag != refDiag);
diag = refDiag;
CPPUNIT_ASSERT(diag == refDiag);
String text = "Dialogue: 3 , 1:23:45.67 , 2:34:56.78 , style name , actor name , 0001 , 0020 , 3300 , effect field ,Text, why halo thar?";
diag = DialogueASS(text,1);
CPPUNIT_ASSERT(diag == refDiag);
text = "Dialogue: 3,1:23:45.67,2:34:56.78,style name,actor name,1,20,3300,effect field,Text, why halo thar?";
diag = DialogueASS(text,1);
CPPUNIT_ASSERT(diag == refDiag);
} }
}; };

View file

@ -82,6 +82,10 @@ public:
CPPUNIT_ASSERT((e < d) == false); CPPUNIT_ASSERT((e < d) == false);
CPPUNIT_ASSERT(d < c); CPPUNIT_ASSERT(d < c);
CPPUNIT_ASSERT((c < d) == false); CPPUNIT_ASSERT((c < d) == false);
CPPUNIT_ASSERT(c.AsciiCompareNoCase("hello world!"));
CPPUNIT_ASSERT(c.AsciiCompareNoCase("Hello world!"));
CPPUNIT_ASSERT(c.AsciiCompareNoCase("hello world") == false);
} }
void testStartEnd() void testStartEnd()
@ -128,6 +132,15 @@ public:
CPPUNIT_ASSERT_THROW(String("312a").ToInteger(),Athenasub::Exception); CPPUNIT_ASSERT_THROW(String("312a").ToInteger(),Athenasub::Exception);
CPPUNIT_ASSERT_THROW(String("3-12").ToInteger(),Athenasub::Exception); CPPUNIT_ASSERT_THROW(String("3-12").ToInteger(),Athenasub::Exception);
CPPUNIT_ASSERT_THROW(String("3+12").ToInteger(),Athenasub::Exception); CPPUNIT_ASSERT_THROW(String("3+12").ToInteger(),Athenasub::Exception);
CPPUNIT_ASSERT(String(312) == "312");
CPPUNIT_ASSERT(String(-312) == "-312");
CPPUNIT_ASSERT(String(312.0) == "312");
CPPUNIT_ASSERT(String(312.25) == "312.25");
CPPUNIT_ASSERT(String(-312.25) == "-312.25");
CPPUNIT_ASSERT(String(312.0f) == "312");
CPPUNIT_ASSERT(String(312.25f) == "312.25");
CPPUNIT_ASSERT(String(-312.25f) == "-312.25");
} }
}; };