Set more finely-grained commit types from LuaAssFile rather than always using COMMIT_NEW

Originally committed to SVN as r5631.
This commit is contained in:
Thomas Goyne 2011-09-28 19:47:12 +00:00
parent 08a61c7fd4
commit 2ca9392942
2 changed files with 33 additions and 29 deletions

View File

@ -66,12 +66,12 @@ namespace Automation4 {
bool can_modify;
/// Is the feature allowed to set undo points?
bool can_set_undo;
/// Has the ass file been modified by the script?
bool is_modified;
/// throws an error if modification is disallowed
void CheckAllowModify();
/// How ass file been modified by the script since the last commit
int modification_type;
/// Reference count used to avoid deleting this until both lua and the
/// calling C++ code are done with it
int references;

View File

@ -167,7 +167,17 @@ namespace {
return 0;
}
int modification_mask(AssEntry *e)
{
switch (e->GetType())
{
case ENTRY_DIALOGUE: return AssFile::COMMIT_DIAG_ADDREM;
case ENTRY_STYLE: return AssFile::COMMIT_STYLES;
case ENTRY_ATTACHMENT: return AssFile::COMMIT_ATTACHMENT;
default: return AssFile::COMMIT_SCRIPTINFO;
}
}
}
namespace Automation4 {
void LuaAssFile::CheckAllowModify()
@ -370,6 +380,9 @@ namespace Automation4 {
void LuaAssFile::SeekCursorTo(int n)
{
if (n <= 0 || n > (int)ass->Line.size())
luaL_error(L, "Requested out-of-range line from subtitle file: %d", n);
if (n < last_entry_id - n) {
// fastest to search from start
last_entry_ptr = ass->Line.begin();
@ -390,18 +403,10 @@ namespace Automation4 {
{
switch (lua_type(L, 2)) {
case LUA_TNUMBER:
{
// read an indexed AssEntry
// get requested index
int reqid = lua_tointeger(L, 2);
if (reqid <= 0 || reqid > (int)ass->Line.size())
return luaL_error(L, "Requested out-of-range line from subtitle file: %d", reqid);
SeekCursorTo(reqid);
SeekCursorTo(lua_tointeger(L, 2));
AssEntryToLua(L, *last_entry_ptr);
return 1;
}
case LUA_TSTRING:
{
@ -447,7 +452,6 @@ namespace Automation4 {
// after modifying the stack to match their expectations
CheckAllowModify();
is_modified = true;
int n = luaL_checkint(L, 2);
if (n < 0) {
@ -468,6 +472,7 @@ namespace Automation4 {
if (!lua_isnil(L, 3)) {
// insert
AssEntry *e = LuaToAssEntry(L);
modification_type |= modification_mask(e);
SeekCursorTo(n);
delete *last_entry_ptr;
*last_entry_ptr = e;
@ -502,7 +507,6 @@ namespace Automation4 {
ids.push_back(n);
--itemcount;
}
is_modified = true;
// sort the item id's so we can delete from last to first to preserve original numbering
sort(ids.begin(), ids.end());
@ -514,6 +518,7 @@ namespace Automation4 {
--last_entry_ptr;
--last_entry_id;
}
modification_type |= modification_mask(*last_entry_ptr);
delete *last_entry_ptr;
ass->Line.erase(last_entry_ptr++);
}
@ -523,14 +528,13 @@ namespace Automation4 {
{
CheckAllowModify();
is_modified = true;
int a = std::max<int>(luaL_checkinteger(L, 1), 1);
int b = std::min<int>(luaL_checkinteger(L, 2), ass->Line.size());
SeekCursorTo(a);
while (a++ <= b) {
modification_type |= modification_mask(*last_entry_ptr);
delete *last_entry_ptr;
ass->Line.erase(last_entry_ptr++);
}
@ -539,7 +543,6 @@ namespace Automation4 {
void LuaAssFile::ObjectAppend(lua_State *L)
{
CheckAllowModify();
is_modified = true;
int n = lua_gettop(L);
@ -551,6 +554,7 @@ namespace Automation4 {
for (int i = 1; i <= n; i++) {
lua_pushvalue(L, i);
AssEntry *e = LuaToAssEntry(L);
modification_type |= modification_mask(*last_entry_ptr);
if (e->GetType() == ENTRY_DIALOGUE) {
// find insertion point, looking backwards
std::list<AssEntry*>::iterator it = ass->Line.end();
@ -577,11 +581,12 @@ namespace Automation4 {
SeekCursorTo(before);
is_modified = true;
int n = lua_gettop(L);
for (int i = 2; i <= n; i++) {
lua_pushvalue(L, i);
ass->Line.insert(last_entry_ptr, LuaToAssEntry(L));
AssEntry *e = LuaToAssEntry(L);
modification_type |= modification_mask(e);
ass->Line.insert(last_entry_ptr, e);
lua_pop(L, 1);
}
@ -635,9 +640,9 @@ namespace Automation4 {
if (!can_set_undo)
luaL_error(L, "Attempt to set an undo point in a context where it makes no sense to do so.");
if (is_modified) {
ass->Commit(wxString(luaL_checkstring(L, 1), wxConvUTF8), AssFile::COMMIT_NEW);
is_modified = false;
if (modification_type) {
ass->Commit(wxString(luaL_checkstring(L, 1), wxConvUTF8), modification_type);
modification_type = 0;
}
}
@ -650,9 +655,9 @@ namespace Automation4 {
void LuaAssFile::ProcessingComplete(wxString const& undo_description)
{
if (is_modified && can_set_undo && !undo_description.empty()) {
ass->Commit(undo_description, AssFile::COMMIT_NEW);
is_modified = false;
if (modification_type && can_set_undo && !undo_description.empty()) {
ass->Commit(undo_description, modification_type);
modification_type = 0;
}
references--;
if (!references) delete this;
@ -663,12 +668,11 @@ namespace Automation4 {
, L(L)
, can_modify(can_modify)
, can_set_undo(can_set_undo)
, modification_type(0)
, references(2)
, last_entry_ptr(ass->Line.begin())
, last_entry_id(1)
{
// prepare cursor
last_entry_ptr = ass->Line.begin();
last_entry_id = 1;
// prepare userdata object
*static_cast<LuaAssFile**>(lua_newuserdata(L, sizeof(LuaAssFile**))) = this;