aboutsummaryrefslogtreecommitdiffhomepage
path: root/player/lua
diff options
context:
space:
mode:
authorGravatar ChrisK2 <spam@kalania.de>2014-11-26 17:36:23 +0100
committerGravatar ChrisK2 <spam@kalania.de>2014-11-26 17:36:23 +0100
commit13845cf6fe81b20ef21903ff4a0eae3fd5a4516a (patch)
treea383c29e41a67713518753a7a6ab8ad4fcb83c44 /player/lua
parent07ddfd4f8afd6047c9d22249a9b1923ea6221643 (diff)
ytdl: Try to handle multi-arc videos
this currently uses a sketchy but apparently working workaround, which will be removed once the neccessary changes in youtube-dl are implemented Fixes #1277
Diffstat (limited to 'player/lua')
-rw-r--r--player/lua/ytdl_hook.lua51
1 files changed, 37 insertions, 14 deletions
diff --git a/player/lua/ytdl_hook.lua b/player/lua/ytdl_hook.lua
index 5fece5bbea..4029c46248 100644
--- a/player/lua/ytdl_hook.lua
+++ b/player/lua/ytdl_hook.lua
@@ -97,23 +97,46 @@ mp.add_hook("on_load", 10, function ()
elseif not (json["_type"] == nil) and (json["_type"] == "playlist") then
-- a playlist
- local playlist = "#EXTM3U\n"
- for i, entry in pairs(json.entries) do
- local site = entry.url
-
- -- some extractors will still return the full info for
- -- all clips in the playlist and the URL will point
- -- directly to the file in that case, which we don't
- -- want so get the webpage URL instead, which is what
- -- we want
- if not (entry["webpage_url"] == nil) then
- site = entry["webpage_url"]
+ -- some funky guessing to detect multi-arc videos
+ if not (json.entries[1]["webpage_url"] == nil)
+ and (json.entries[1]["webpage_url"] == json["webpage_url"]) then
+ msg.verbose("multi-arc video detected, building EDL")
+
+
+ local playlist = "edl://"
+ for i, entry in pairs(json.entries) do
+
+ playlist = playlist .. entry.url .. ";"
end
- playlist = playlist .. "ytdl://" .. site .. "\n"
- end
+ msg.debug("EDL: " .. playlist)
+
+
+ mp.set_property("stream-open-filename", playlist)
+ if not (json.title == nil) then
+ mp.set_property("file-local-options/media-title", json.title)
+ end
- mp.set_property("stream-open-filename", "memory://" .. playlist)
+ else
+
+ local playlist = "#EXTM3U\n"
+ for i, entry in pairs(json.entries) do
+ local site = entry.url
+
+ -- some extractors will still return the full info for
+ -- all clips in the playlist and the URL will point
+ -- directly to the file in that case, which we don't
+ -- want so get the webpage URL instead, which is what
+ -- we want
+ if not (entry["webpage_url"] == nil) then
+ site = entry["webpage_url"]
+ end
+
+ playlist = playlist .. "ytdl://" .. site .. "\n"
+ end
+
+ mp.set_property("stream-open-filename", "memory://" .. playlist)
+ end
else -- probably a video
local streamurl = ""