mirror of
https://github.com/ksyasuda/mpv-youtube-queue.git
synced 2024-10-28 04:44:11 -07:00
change helper functions to use mpv utils
- use utils.file_info.is_file to check if the file exits and is a file - use utils.split_path to split path into directory and filename components
This commit is contained in:
parent
6ca5de8aa4
commit
ff60b12e61
@ -15,6 +15,7 @@
|
|||||||
-- along with this program. If not, see <https://www.gnu.org/licenses/>.
|
-- along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
local mp = require 'mp'
|
local mp = require 'mp'
|
||||||
mp.options = require 'mp.options'
|
mp.options = require 'mp.options'
|
||||||
|
local utils = require 'mp.utils'
|
||||||
local styleOn = mp.get_property("osd-ass-cc/0")
|
local styleOn = mp.get_property("osd-ass-cc/0")
|
||||||
local styleOff = mp.get_property("osd-ass-cc/1")
|
local styleOff = mp.get_property("osd-ass-cc/1")
|
||||||
|
|
||||||
@ -105,20 +106,6 @@ local function remove_quotes(s) return string.gsub(s, "'", "") end
|
|||||||
-- run sleep shell command for n seconds
|
-- run sleep shell command for n seconds
|
||||||
local function sleep(n) os.execute("sleep " .. tonumber(n)) end
|
local function sleep(n) os.execute("sleep " .. tonumber(n)) end
|
||||||
|
|
||||||
-- returns true if the provided path exists and is a file
|
|
||||||
local function is_file(filepath)
|
|
||||||
local result = os.execute("test -f " .. surround_with_quotes(filepath))
|
|
||||||
return result
|
|
||||||
end
|
|
||||||
|
|
||||||
-- returns the filename given a path (e.g. /home/user/file.txt -> file.txt)
|
|
||||||
local function get_filename(filepath) return string.match(filepath, ".+/(.+)$") end
|
|
||||||
|
|
||||||
-- return the directory given a path (e.g. /home/user/file.txt -> /home/user)
|
|
||||||
local function get_directory(filepath)
|
|
||||||
return surround_with_quotes(string.match(filepath, "(.+)/.+"))
|
|
||||||
end
|
|
||||||
|
|
||||||
local function print_osd_message(message, duration, s)
|
local function print_osd_message(message, duration, s)
|
||||||
if s == style.error and not options.show_errors then return end
|
if s == style.error and not options.show_errors then return end
|
||||||
if s == nil then s = style.font .. "{" .. notransparent .. "}" end
|
if s == nil then s = style.font .. "{" .. notransparent .. "}" end
|
||||||
@ -127,6 +114,22 @@ local function print_osd_message(message, duration, s)
|
|||||||
duration)
|
duration)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- returns true if the provided path exists and is a file
|
||||||
|
local function is_file(filepath)
|
||||||
|
mp.msg.info("FILEPATH: " .. filepath)
|
||||||
|
local result = utils.file_info(filepath)
|
||||||
|
if result == nil then
|
||||||
|
print_osd_message("File not found: " .. filepath, 3, style.error)
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
return result.is_file
|
||||||
|
end
|
||||||
|
|
||||||
|
-- returns the filename given a path (e.g. /home/user/file.txt -> file.txt)
|
||||||
|
local function split_path(filepath)
|
||||||
|
if is_file(filepath) then return utils.split_path(filepath) end
|
||||||
|
end
|
||||||
|
|
||||||
local function print_current_video()
|
local function print_current_video()
|
||||||
local current = YouTubeQueue.get_current_video()
|
local current = YouTubeQueue.get_current_video()
|
||||||
if is_file(current.video_url) then
|
if is_file(current.video_url) then
|
||||||
@ -453,9 +456,10 @@ function YouTubeQueue.add_to_queue(url, update_internal_playlist)
|
|||||||
local video, channel_url, channel_name, video_name, video_url
|
local video, channel_url, channel_name, video_name, video_url
|
||||||
if is_file(url) then
|
if is_file(url) then
|
||||||
video_url = url
|
video_url = url
|
||||||
video_name = get_filename(url)
|
channel_url, video_name = split_path(video_url)
|
||||||
channel_url = get_directory(url)
|
mp.msg.info("channel_url: " .. channel_url)
|
||||||
channel_name = get_directory(url)
|
mp.msg.info("video_name: " .. video_name)
|
||||||
|
channel_name = "Local file"
|
||||||
|
|
||||||
video = {
|
video = {
|
||||||
video_url = video_url,
|
video_url = video_url,
|
||||||
|
Loading…
Reference in New Issue
Block a user