diff options
author | ChrisK2 <spam@kalania.de> | 2014-11-26 17:36:23 +0100 |
---|---|---|
committer | ChrisK2 <spam@kalania.de> | 2014-11-26 17:36:23 +0100 |
commit | 13845cf6fe81b20ef21903ff4a0eae3fd5a4516a (patch) | |
tree | a383c29e41a67713518753a7a6ab8ad4fcb83c44 /player/lua | |
parent | 07ddfd4f8afd6047c9d22249a9b1923ea6221643 (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.lua | 51 |
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 = "" |