plugin.h & lua add playlist_insert_playlist
having issues running lua and loading a playlist Change-Id: I72d32d77e6567ceed7e8e5fd492eebf0ee44561a
This commit is contained in:
parent
f02cd18ad0
commit
221e8752cc
4 changed files with 70 additions and 17 deletions
|
@ -803,6 +803,7 @@ static const struct plugin_api rockbox_api = {
|
|||
/* new stuff at the end, sort into place next time
|
||||
the API gets incompatible */
|
||||
warn_on_pl_erase,
|
||||
playlist_insert_playlist,
|
||||
};
|
||||
|
||||
static int plugin_buffer_handle;
|
||||
|
|
|
@ -929,7 +929,8 @@ struct plugin_api {
|
|||
/* new stuff at the end, sort into place next time
|
||||
the API gets incompatible */
|
||||
bool (*warn_on_pl_erase)(void);
|
||||
|
||||
int (*playlist_insert_playlist)(struct playlist_info* playlist,
|
||||
const char *filename, int position, bool queue);
|
||||
};
|
||||
|
||||
/* plugin header */
|
||||
|
|
|
@ -320,11 +320,12 @@ RB_WRAP(playlist)
|
|||
enum e_playlist {PLAYL_AMOUNT = 0, PLAYL_ADD, PLAYL_CREATE,
|
||||
PLAYL_START, PLAYL_RESUMETRACK, PLAYL_RESUME,
|
||||
PLAYL_SHUFFLE, PLAYL_SYNC, PLAYL_REMOVEALLTRACKS,
|
||||
PLAYL_INSERTTRACK, PLAYL_INSERTDIRECTORY, PLAYL_ECOUNT};
|
||||
PLAYL_INSERTTRACK, PLAYL_INSERTDIRECTORY, PLAYL_INSERTPLAYL,
|
||||
PLAYL_ECOUNT};
|
||||
|
||||
const char *playlist_option[] = {"amount", "add", "create", "start", "resume_track",
|
||||
"resume", "shuffle", "sync", "remove_all_tracks",
|
||||
"insert_track", "insert_directory", NULL};
|
||||
"insert_track", "insert_directory", "insert_playlist", NULL};
|
||||
|
||||
const char *filename, *dir;
|
||||
int result = 0;
|
||||
|
@ -388,6 +389,12 @@ RB_WRAP(playlist)
|
|||
recurse = lua_toboolean(L, 5); /* default to false */
|
||||
result = rb->playlist_insert_directory(NULL, dir, pos, queue, recurse);
|
||||
break;
|
||||
case PLAYL_INSERTPLAYL:
|
||||
filename = luaL_checkstring(L, 2); /* only required parameter */
|
||||
pos = luaL_optint(L, 3, 0);
|
||||
queue = lua_toboolean(L, 4); /* default to false */
|
||||
result = rb->playlist_insert_playlist(NULL, filename, pos, queue);
|
||||
break;
|
||||
}
|
||||
|
||||
yield();
|
||||
|
|
|
@ -29,6 +29,9 @@ local playlistpath = "/Playlists"
|
|||
local max_tracks = 500; -- size of playlist to create
|
||||
local min_repeat = 500; -- this many songs before a repeat
|
||||
local play_on_success = true;
|
||||
--program vars
|
||||
local playlist_handle
|
||||
local t_playlistbuf -- table for playlist write buffer
|
||||
|
||||
-- Random integer function
|
||||
local random = math.random; -- ref random(min, max)
|
||||
|
@ -48,7 +51,6 @@ rb.contexts = nil
|
|||
local sINITDATABASE = "Initialize Database"
|
||||
local sHEADERTEXT = "Random Playlist"
|
||||
local sPLAYLISTERROR = "Playlist Error!"
|
||||
local sREMOVEPLAYLIST = "Removing Dynamic Playlist"
|
||||
local sSEARCHINGFILES = "Searching for Files.."
|
||||
local sERROROPENFMT = "Error Opening %s"
|
||||
local sINVALIDDBFMT = "Invalid Database %s"
|
||||
|
@ -174,13 +176,55 @@ local function _setup_random_playlist(tag_entries, play, min_repeat, trackcount)
|
|||
return play, min_repeat, trackcount;
|
||||
end
|
||||
|
||||
--deletes existing file and creates a new playlist
|
||||
local function playlist_create(filename)
|
||||
local filehandle = io.open(filename, "w+") --overwrite
|
||||
if not filehandle then
|
||||
rb.splash(rb.HZ, "Error opening " .. filename)
|
||||
return false
|
||||
end
|
||||
t_playlistbuf = {}
|
||||
filehandle:write("\239\187\191") -- Write BOM --"\xEF\xBB\xBF"
|
||||
playlist_handle = filehandle
|
||||
return true
|
||||
--os.remove( playlistpath .. "/" .. playlist)
|
||||
--rb.playlist("remove_all_tracks")
|
||||
--rb.playlist("create", playlistpath .. "/", playlist)
|
||||
end
|
||||
|
||||
-- writes track path to a buffer must be flushed
|
||||
local function playlist_write(trackpath)
|
||||
t_playlistbuf[#t_playlistbuf + 1] = trackpath
|
||||
t_playlistbuf[#t_playlistbuf + 1] = "\n"
|
||||
--[[if rb.playlist("insert_track", str) < 0 then
|
||||
rb.splash(rb.HZ, sPLAYLISTERROR)
|
||||
break; -- ERROR, PLAYLIST FULL?
|
||||
end]]
|
||||
end
|
||||
|
||||
-- flushes playlist buffer to file
|
||||
local function playlist_flush()
|
||||
playlist_handle:write(table.concat(t_playlistbuf))
|
||||
t_playlistbuf = {}
|
||||
--[[if rb.playlist("insert_track", str) < 0 then
|
||||
rb.splash(rb.HZ, sPLAYLISTERROR)
|
||||
break; -- ERROR, PLAYLIST FULL?
|
||||
end]]
|
||||
end
|
||||
|
||||
-- closes playlist file descriptor
|
||||
local function playlist_finalize()
|
||||
playlist_handle:close()
|
||||
end
|
||||
|
||||
--[[ Given the filenameDB file [database]
|
||||
creates a random dynamic playlist with a default savename of [playlist]
|
||||
containing [trackcount] tracks, played on completion if [play] is true]]
|
||||
function create_random_playlist(database, playlist, trackcount, play)
|
||||
local function create_random_playlist(database, playlist, trackcount, play)
|
||||
if not database or not playlist or not trackcount then return end
|
||||
if not play then play = false end
|
||||
|
||||
local playlist_handle
|
||||
local file = io.open('/' .. database or "", "r") --read
|
||||
if not file then rb.splash(100, string.format(sERROROPENFMT, database)) return end
|
||||
|
||||
|
@ -214,6 +258,7 @@ function create_random_playlist(database, playlist, trackcount, play)
|
|||
end
|
||||
|
||||
local tag_entries = bytesLE_n(tagcache_entries)
|
||||
if tag_entries > 50000 then play = false end
|
||||
|
||||
play, min_repeat, trackcount = _setup_random_playlist(
|
||||
tag_entries, play, min_repeat, trackcount);
|
||||
|
@ -250,6 +295,7 @@ function create_random_playlist(database, playlist, trackcount, play)
|
|||
if y >= max_h then
|
||||
do_progress_header()
|
||||
rb.lcd_clear_display()
|
||||
playlist_flush(playlist_handle)
|
||||
rb.yield()
|
||||
y = h
|
||||
end
|
||||
|
@ -319,14 +365,11 @@ function create_random_playlist(database, playlist, trackcount, play)
|
|||
tracks = tracks + 1
|
||||
show_progress()
|
||||
push_lru(idxp) -- add to repeat list
|
||||
if rb.playlist("insert_track", str) < 0 then
|
||||
rb.splash(rb.HZ, sPLAYLISTERROR)
|
||||
break; -- ERROR, PLAYLIST FULL?
|
||||
end
|
||||
|
||||
playlist_write(str)
|
||||
end
|
||||
|
||||
if tracks >= trackcount then
|
||||
playlist_flush()
|
||||
do_progress_header()
|
||||
break
|
||||
end
|
||||
|
@ -400,11 +443,7 @@ function create_random_playlist(database, playlist, trackcount, play)
|
|||
anchor_index = nil
|
||||
end
|
||||
|
||||
rb.splash(10, sREMOVEPLAYLIST)
|
||||
rb.audio("stop")
|
||||
os.remove( playlistpath .. "/" .. playlist)
|
||||
--rb.playlist("remove_all_tracks")
|
||||
rb.playlist("create", playlistpath .. "/", playlist)
|
||||
if not playlist_create(playlistpath .. "/" .. playlist) then return end
|
||||
--[[ --profiling
|
||||
local starttime = rb.current_tick();
|
||||
get_tracks_random()
|
||||
|
@ -414,15 +453,20 @@ function create_random_playlist(database, playlist, trackcount, play)
|
|||
if (false) then
|
||||
--]]
|
||||
get_tracks_random()
|
||||
playlist_finalize(playlist_handle)
|
||||
end
|
||||
|
||||
file:close()
|
||||
collectgarbage("collect")
|
||||
if trackcount and rb.playlist("amount") >= trackcount and play == true then
|
||||
if trackcount and play == true then
|
||||
rb.audio("stop")
|
||||
rb.yield()
|
||||
rb.playlist("create", playlistpath .. "/", "dynamic_playlist.m3u8")
|
||||
rb.playlist("insert_playlist", playlistpath .. "/" .. playlist)
|
||||
rb.playlist("start", 0, 0, 0)
|
||||
end
|
||||
|
||||
end -- create_playlist
|
||||
end -- playlist_create
|
||||
|
||||
local function main()
|
||||
if not rb.file_exists(rb.ROCKBOX_DIR .. "/database_4.tcd") then
|
||||
|
|
Loading…
Reference in a new issue