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; bool can_modify;
/// Is the feature allowed to set undo points? /// Is the feature allowed to set undo points?
bool can_set_undo; bool can_set_undo;
/// Has the ass file been modified by the script?
bool is_modified;
/// throws an error if modification is disallowed /// throws an error if modification is disallowed
void CheckAllowModify(); 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 /// Reference count used to avoid deleting this until both lua and the
/// calling C++ code are done with it /// calling C++ code are done with it
int references; int references;

View file

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