forked from mia/Aegisub
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:
parent
08a61c7fd4
commit
2ca9392942
2 changed files with 33 additions and 29 deletions
|
@ -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;
|
||||||
|
|
|
@ -167,7 +167,17 @@ 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 {
|
||||||
void LuaAssFile::CheckAllowModify()
|
void LuaAssFile::CheckAllowModify()
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue