Select the right things in the select overlaps macro. Closes #1594.

This commit is contained in:
Thomas Goyne 2013-04-15 15:42:52 -07:00
parent 1096ef8c6e
commit 71b14ecc74
2 changed files with 67 additions and 41 deletions

View file

@ -1,46 +1,31 @@
-- Copyright (c) 2010, Thomas Goyne <plorkyeran@aegisub.org>
--
-- Permission to use, copy, modify, and distribute this software for any
-- purpose with or without fee is hereby granted, provided that the above
-- copyright notice and this permission notice appear in all copies.
--
-- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-- WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-- MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-- ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-- WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-- ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-- OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
local tr = aegisub.gettext local tr = aegisub.gettext
script_name = tr("Select overlaps")
script_name = tr"Select overlaps" script_description = tr("Select lines which begin while another non-comment line is active")
script_description = tr"Select lines which begin while another non-comment line is active"
script_author = "Thomas Goyne" script_author = "Thomas Goyne"
script_version = "1" script_version = "2"
local select_overlaps
function select_overlaps(subs) select_overlaps = function(subs)
-- filter subtitles lines to just dialogue lines and sort them by time
local dialogue = { } local dialogue = { }
for i = 1,#subs do for i, line in ipairs(subs) do
local line = subs[i]
if line.class == "dialogue" then if line.class == "dialogue" then
line.i = i - 1 line.i = i
table.insert(dialogue, line) table.insert(dialogue, line)
end end
end end
table.sort(dialogue, function(a,b) return a.start_time < b.start_time end) table.sort(dialogue, function(a, b)
return a.start_time < b.start_time or (a.start_time == b.start_time and a.i < b.i)
end)
local end_time = 0 local end_time = 0
local overlaps = { } local overlaps = { }
for i,line in ipairs(dialogue) do local _list_0 = dialogue
for _index_0 = 1, #_list_0 do
local line = _list_0[_index_0]
if line.start_time >= end_time then if line.start_time >= end_time then
end_time = line.end_time end_time = line.start_time
else else
table.insert(overlaps, line.i) table.insert(overlaps, line.i)
end end
end end
return overlaps return overlaps
end end
return aegisub.register_macro(script_name, script_description, select_overlaps)
aegisub.register_macro(script_name, script_description, select_overlaps)

View file

@ -0,0 +1,41 @@
-- Copyright (c) 2013, Thomas Goyne <plorkyeran@aegisub.org>
--
-- Permission to use, copy, modify, and distribute this software for any
-- purpose with or without fee is hereby granted, provided that the above
-- copyright notice and this permission notice appear in all copies.
--
-- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-- WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-- MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-- ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-- WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-- ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-- OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
tr = aegisub.gettext
export script_name = tr"Select overlaps"
export script_description = tr"Select lines which begin while another non-comment line is active"
export script_author = "Thomas Goyne"
export script_version = "2"
select_overlaps = (subs) ->
-- filter subtitles lines to just dialogue lines and sort them by time
dialogue = {}
for i, line in ipairs subs
if line.class == "dialogue"
line.i = i
table.insert dialogue, line
table.sort dialogue, (a,b) ->
a.start_time < b.start_time or (a.start_time == b.start_time and a.i < b.i)
end_time = 0
overlaps = {}
for line in *dialogue
if line.start_time >= end_time
end_time = line.start_time
else
table.insert overlaps, line.i
overlaps
aegisub.register_macro script_name, script_description, select_overlaps