aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgarret <garret@airmail.cc>2023-01-15 13:41:40 +0000
committergarret <garret@airmail.cc>2023-01-15 13:41:40 +0000
commit016ef8486d8320818879aebc3b8a6228ca28b4c5 (patch)
tree9c4af5db9766029097b77b2bc26cfbc8e1ffcc82
parent12fe89b0b930500e694f5b977f6b4a48f4af8137 (diff)
parente816a3888b3a5681e6e66a731ffed6144b864d7c (diff)
downloadaegisub-scripts-016ef8486d8320818879aebc3b8a6228ca28b4c5.tar.gz
aegisub-scripts-016ef8486d8320818879aebc3b8a6228ca28b4c5.tar.bz2
aegisub-scripts-016ef8486d8320818879aebc3b8a6228ca28b4c5.zip
Merge sel/act fixes from Akatsumekusa
Closes #5
-rw-r--r--macros/garret.dupe-and-comment.lua44
1 files changed, 30 insertions, 14 deletions
diff --git a/macros/garret.dupe-and-comment.lua b/macros/garret.dupe-and-comment.lua
index a434712..14a660c 100644
--- a/macros/garret.dupe-and-comment.lua
+++ b/macros/garret.dupe-and-comment.lua
@@ -1,45 +1,61 @@
script_name="Dupe and Comment"
script_description="Copies a line and comments out the original.\nbecause i like seeing the original while editing, and being able to go back to it easily"
script_author = "garret"
-script_version = "2.1.3"
+script_version = "3.0.0"
script_namespace = "garret.dupe-and-comment"
local haveDepCtrl, DependencyControl, depctrl = pcall(require, "l0.DependencyControl")
-local util
if haveDepCtrl then
depctrl = DependencyControl {
--feed="TODO",
- {"aegisub.util"}
}
- util = depctrl:requireModules()
-else
- util = require 'aegisub.util'
end
-local function comment(subs, sel)
+local function comment(subs, sel, act)
for i=#sel,1,-1 do
- local line=subs[sel[i]]
- local original = util.copy(line)
- line.comment = false -- going to edit it, so we probably want to see it on the video
- original.comment = true -- this is the actual original one
- subs.insert(sel[i]+1, original) -- putting it on the next line so i don't have to change line
+ local line=subs[sel[i]] -- grab copy of current line
+
+ -- now use that copy for a different line
+ line.comment = true -- comment out the new dupe line
+ subs.insert(sel[i]+1, line) -- and put it below
+
+ -- sort out selection
+ for j=i+1,#sel do
+ sel[j] = sel[j] + 1 -- bump all of sel by 1 to compensate for new line
+ end -- first item isnt included because it's not affected
+
+ if act > sel[i] then -- if we've not got to the active line yet
+ act = act + 1 -- bump by 1 to compensate for new lines above
+ end
end
aegisub.set_undo_point(script_name)
+ return sel, act
end
-local function undo(subs, sel)
+local function undo(subs, sel, act)
for i=#sel,1,-1 do
local edit=subs[sel[i]]
- if not (sel[i] + 1 > #subs) then
+ if not (sel[i] + 1 > #subs) then -- preventing out-of-range errors
local original=subs[sel[i]+1]
+
if edit.comment == false and original.comment == true then
original.comment = false
subs[sel[i]+1] = original
subs.delete(sel[i])
+
+ -- sort out selection. same as `do`, but the other way round.
+ for j=i+1,#sel do
+ sel[j] = sel[j] - 1
+ end
+ if act > sel[i] then
+ act = act - 1
+ end
+
end
end
end
aegisub.set_undo_point("Undo "..script_name)
+ return sel, act
end
local macros = {