2008-03-08 04:08:50 +01:00
|
|
|
// Copyright (c) 2008, Rodrigo Braz Monteiro
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// Redistribution and use in source and binary forms, with or without
|
|
|
|
// modification, are permitted provided that the following conditions are met:
|
|
|
|
//
|
|
|
|
// * Redistributions of source code must retain the above copyright notice,
|
|
|
|
// this list of conditions and the following disclaimer.
|
|
|
|
// * Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
// this list of conditions and the following disclaimer in the documentation
|
|
|
|
// and/or other materials provided with the distribution.
|
|
|
|
// * Neither the name of the Aegisub Group nor the names of its contributors
|
|
|
|
// may be used to endorse or promote products derived from this software
|
|
|
|
// without specific prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
// POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
//
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// AEGISUB/AEGILIB
|
|
|
|
//
|
|
|
|
// Website: http://www.aegisub.net
|
|
|
|
// Contact: mailto:amz@aegisub.net
|
|
|
|
//
|
|
|
|
|
2008-03-13 22:28:22 +01:00
|
|
|
#include <aegilib/gorgonsub.h>
|
2008-03-08 08:14:14 +01:00
|
|
|
#include <wx/wfstream.h>
|
2008-03-08 04:08:50 +01:00
|
|
|
#include <iostream>
|
2008-03-14 07:10:54 +01:00
|
|
|
#include <wx/stopwatch.h>
|
2008-03-08 04:08:50 +01:00
|
|
|
#include "text_file_reader.h"
|
|
|
|
#include "text_file_writer.h"
|
|
|
|
|
2008-03-16 01:32:42 +01:00
|
|
|
int main()
|
|
|
|
{
|
2008-03-08 04:08:50 +01:00
|
|
|
using namespace std;
|
2008-03-13 22:28:22 +01:00
|
|
|
using namespace Gorgonsub;
|
2008-03-08 04:08:50 +01:00
|
|
|
|
2008-03-13 22:28:22 +01:00
|
|
|
cout << "Gorgonsub test program by amz.\n\n";
|
2008-03-08 04:08:50 +01:00
|
|
|
|
2008-03-08 08:14:14 +01:00
|
|
|
try {
|
|
|
|
// Set up the lib
|
|
|
|
FormatManager::InitializeFormats();
|
2008-03-13 22:28:22 +01:00
|
|
|
Gorgonsub::SetHostApplicationName(L"Aegilib test program");
|
2008-03-08 04:08:50 +01:00
|
|
|
|
2008-03-08 08:14:14 +01:00
|
|
|
// Subtitles model
|
|
|
|
Model subs;
|
2008-03-14 03:02:48 +01:00
|
|
|
Controller control(subs);
|
2008-03-14 07:10:54 +01:00
|
|
|
wxStopWatch timer;
|
2008-03-08 04:08:50 +01:00
|
|
|
|
2008-03-08 08:14:14 +01:00
|
|
|
// Load subtitles
|
|
|
|
cout << "Loading file... ";
|
2008-03-14 07:10:54 +01:00
|
|
|
timer.Start();
|
2008-03-16 01:32:42 +01:00
|
|
|
control.LoadFile(L"subs_in.ass",L"UTF-8");
|
2008-03-14 07:10:54 +01:00
|
|
|
timer.Pause();
|
2008-03-15 09:36:52 +01:00
|
|
|
cout << "Done in " << timer.Time() << " ms.\n";
|
|
|
|
//system("pause");
|
|
|
|
|
|
|
|
// Save subtitles
|
|
|
|
cout << "Saving file... ";
|
|
|
|
timer.Start();
|
|
|
|
control.SaveFile(L"subs_out.ass",L"UTF-8");
|
|
|
|
timer.Pause();
|
|
|
|
cout << "Done in " << timer.Time() << " ms.\n";
|
2008-03-14 03:02:48 +01:00
|
|
|
|
2008-03-17 02:32:26 +01:00
|
|
|
// Issue an action
|
2008-03-18 03:09:33 +01:00
|
|
|
#ifdef WXDEBUG
|
|
|
|
const int n = 1;
|
|
|
|
#else
|
|
|
|
const int n = 100;
|
|
|
|
#endif
|
|
|
|
cout << "Executing action " << n << " times... ";
|
2008-03-17 08:19:33 +01:00
|
|
|
timer.Start();
|
2008-03-18 03:09:33 +01:00
|
|
|
for (size_t i=0;i<n;i++) {
|
2008-03-17 08:19:33 +01:00
|
|
|
ActionListPtr actions = control.CreateActionList(L"Test");
|
|
|
|
Selection selection;
|
|
|
|
selection.AddRange(Range(0,5000));
|
|
|
|
selection.AddRange(Range(4500,5500));
|
|
|
|
selection.AddRange(Range(9000,9100));
|
2008-03-18 03:09:33 +01:00
|
|
|
std::vector<EntryPtr> entries = actions->ModifyLines(selection,L"Events");
|
2008-03-17 08:19:33 +01:00
|
|
|
size_t len = entries.size();
|
|
|
|
for (size_t i=0;i<len;i++) {
|
2008-03-18 03:09:33 +01:00
|
|
|
DialoguePtr diag = dynamic_pointer_cast<Dialogue> (entries[i]);
|
2008-03-17 08:19:33 +01:00
|
|
|
diag->SetStartTime(diag->GetStartTime() - 55555);
|
|
|
|
diag->SetEndTime(diag->GetEndTime() + 5555);
|
|
|
|
}
|
|
|
|
actions->Finish();
|
|
|
|
}
|
|
|
|
timer.Pause();
|
|
|
|
cout << "Done in " << timer.Time() << " ms.\n";
|
|
|
|
|
|
|
|
// Rollback
|
2008-03-18 03:09:33 +01:00
|
|
|
cout << "Undoing " << n << " times... ";
|
|
|
|
for (size_t i=0;i<n-1;i++) {
|
2008-03-17 08:19:33 +01:00
|
|
|
control.Undo();
|
|
|
|
}
|
|
|
|
cout << "Done.\n";
|
2008-03-14 04:33:27 +01:00
|
|
|
|
|
|
|
// Undo
|
2008-03-18 03:09:33 +01:00
|
|
|
cout << "Undoing and redoing " << n*10 << " times... ";
|
2008-03-14 07:10:54 +01:00
|
|
|
timer.Start();
|
2008-03-18 03:09:33 +01:00
|
|
|
for (size_t i=0;i<n*10;i++) {
|
2008-03-15 09:36:52 +01:00
|
|
|
control.Undo();
|
|
|
|
control.Redo();
|
|
|
|
}
|
2008-03-14 07:10:54 +01:00
|
|
|
timer.Pause();
|
2008-03-15 09:36:52 +01:00
|
|
|
cout << "Done in " << timer.Time() << " ms.\n";
|
2008-03-18 03:09:33 +01:00
|
|
|
|
|
|
|
// Get style test
|
|
|
|
StyleConstPtr style = control.GetStyle(L"japro1_star");
|
|
|
|
cout << "Style " << style->GetName().mb_str() << " font is " << style->GetFontName().mb_str() << " " << style->GetFontSize() << ".\n";
|
|
|
|
|
|
|
|
// Save a few more
|
2008-03-15 23:02:16 +01:00
|
|
|
control.SaveFile(L"subs_out2.ass",L"UTF-8");
|
2008-03-16 03:20:34 +01:00
|
|
|
control.Undo();
|
|
|
|
control.SaveFile(L"subs_out3.ass",L"UTF-8");
|
2008-03-08 08:14:14 +01:00
|
|
|
}
|
|
|
|
|
2008-03-13 08:28:30 +01:00
|
|
|
catch (std::exception &e) {
|
|
|
|
cout << "\n\nException: " << e.what() << endl << endl;
|
2008-03-08 08:14:14 +01:00
|
|
|
}
|
2008-03-15 01:29:17 +01:00
|
|
|
|
2008-03-17 02:32:26 +01:00
|
|
|
if (false) {
|
|
|
|
wchar_t myArray[] = { 0xD834, 0xDD1E, 0 };
|
|
|
|
String str = wxString(myArray);
|
|
|
|
cout << "Length: " << str.Length() << ". Contents: " << str[0] << "," << str[1] << endl;
|
|
|
|
wxCharBuffer buf = str.mb_str(wxConvUTF8);
|
|
|
|
unsigned char *chr = (unsigned char *) buf.data();
|
|
|
|
cout << "UTF-8 Length: " << strlen(buf) << ". Contents: " << (size_t)chr[0] << "," << (size_t)chr[1] << "," << (size_t)chr[2] << "," << (size_t)chr[3] << endl;
|
|
|
|
str = wxString(buf,wxConvUTF8);
|
|
|
|
cout << "Length: " << str.Length() << ". Contents: " << str[0] << "," << str[1] << endl;
|
|
|
|
}
|
2008-03-15 01:29:17 +01:00
|
|
|
return true;
|
2008-03-08 04:08:50 +01:00
|
|
|
}
|