#include <vlc_common.h>
#include <vlc_input.h>
-#include <vlc_playlist.h>
#include <vlc_meta.h>
#include <vlc_demux.h>
#include <vlc_art_finder.h>
*****************************************************************************/
static const luaL_Reg p_reg[] = { { NULL, NULL } };
-static lua_State * init( vlc_object_t *p_this, input_item_t * p_item )
+static lua_State * init( vlc_object_t *p_this, input_item_t * p_item, const char *psz_filename )
{
lua_State * L = luaL_newstate();
if( !L )
return NULL;
}
+ vlclua_set_this( L, p_this );
+
/* Load Lua libraries */
luaL_openlibs( L ); /* XXX: Don't open all the libs? */
luaopen_variables( L );
luaopen_object( L );
luaopen_misc( L );
+ luaopen_xml( L );
+ luaopen_md5( L );
luaopen_input_item( L, p_item );
- lua_pushlightuserdata( L, p_this );
- lua_setfield( L, -2, "private" );
+ if( vlclua_add_modules_path( p_this, L, psz_filename ) )
+ {
+ msg_Warn( p_this, "Error while setting the module search path for %s",
+ psz_filename );
+ lua_close( L );
+ return NULL;
+ }
return L;
}
if( !lua_isfunction( L, lua_gettop( L ) ) )
{
- msg_Warn( p_this, "Error while runing script %s, "
+ msg_Warn( p_this, "Error while running script %s, "
"function %s() not found", psz_filename, luafunction );
goto error;
}
if( lua_pcall( L, 0, 1, 0 ) )
{
- msg_Warn( p_this, "Error while runing script %s, "
+ msg_Warn( p_this, "Error while running script %s, "
"function %s(): %s", psz_filename, luafunction,
lua_tostring( L, lua_gettop( L ) ) );
goto error;
* pointed by psz_filename.
*****************************************************************************/
static int fetch_art( vlc_object_t *p_this, const char * psz_filename,
- lua_State * L, void * user_data )
+ void * user_data )
{
- input_item_t * p_input = user_data;
- int s;
+ input_item_t * p_item = user_data;
+
+ lua_State *L = init( p_this, p_item, psz_filename );
+ if( !L )
+ return VLC_EGENERIC;
int i_ret = run(p_this, psz_filename, L, "fetch_art");
if(i_ret != VLC_SUCCESS)
+ {
+ lua_close( L );
return i_ret;
+ }
- if((s = lua_gettop( L )))
+ if(lua_gettop( L ))
{
const char * psz_value;
- if( lua_isstring( L, s ) )
+ if( lua_isstring( L, -1 ) )
{
- psz_value = lua_tostring( L, s );
+ psz_value = lua_tostring( L, -1 );
if( psz_value && *psz_value != 0 )
{
lua_Dbg( p_this, "setting arturl: %s", psz_value );
- input_item_SetArtURL ( p_input, psz_value );
+ input_item_SetArtURL ( p_item, psz_value );
+ lua_close( L );
return VLC_SUCCESS;
}
}
- else if( !lua_isnil( L, s ) )
+ else if( !lua_isnoneornil( L, -1 ) )
{
msg_Err( p_this, "Lua art fetcher script %s: "
"didn't return a string", psz_filename );
msg_Err( p_this, "Script went completely foobar" );
}
+ lua_close( L );
return VLC_EGENERIC;
}
/*****************************************************************************
- * Called through lua_scripts_batch_execute to call 'fetch_art' on the script
+ * Called through lua_scripts_batch_execute to call 'read_meta' on the script
* pointed by psz_filename.
*****************************************************************************/
static int read_meta( vlc_object_t *p_this, const char * psz_filename,
- lua_State * L, void * user_data )
+ void * user_data )
{
- VLC_UNUSED(user_data);
+ input_item_t * p_item = user_data;
+ lua_State *L = init( p_this, p_item, psz_filename );
+ if( !L )
+ return VLC_EGENERIC;
int i_ret = run(p_this, psz_filename, L, "read_meta");
- if(i_ret != VLC_SUCCESS)
- return i_ret;
+ lua_close( L );
- // Continue, all "meta reader" are always run.
- return 1;
+ // Continue even if an error occured: all "meta reader" are always run.
+ return i_ret == VLC_SUCCESS ? VLC_EGENERIC : i_ret;
}
* pointed by psz_filename.
*****************************************************************************/
static int fetch_meta( vlc_object_t *p_this, const char * psz_filename,
- lua_State * L, void * user_data )
+ void * user_data )
{
- VLC_UNUSED(user_data);
+ input_item_t * p_item = user_data;
+ lua_State *L = init( p_this, p_item, psz_filename );
+ if( !L )
+ return VLC_EGENERIC;
- return run(p_this, psz_filename, L, "fetch_meta");
+ int ret = run(p_this, psz_filename, L, "fetch_meta");
+ lua_close( L );
+
+ return ret;
}
/*****************************************************************************
demux_meta_t *p_demux_meta = (demux_meta_t *)p_this;
input_item_t *p_item = p_demux_meta->p_item;
- lua_State *L = init( p_this, p_item );
- int i_ret = vlclua_scripts_batch_execute( p_this, "meta/reader", &read_meta, L, NULL );
- lua_close( L );
-
- return i_ret;
+ return vlclua_scripts_batch_execute( p_this, "meta"DIR_SEP"reader",
+ &read_meta, p_item );
}
demux_meta_t *p_demux_meta = (demux_meta_t *)p_this;
input_item_t *p_item = p_demux_meta->p_item;
- lua_State *L = init( p_this, p_item );
- int i_ret = vlclua_scripts_batch_execute( p_this, "meta/fetcher", &fetch_meta, L, NULL );
- lua_close( L );
-
- return i_ret;
+ return vlclua_scripts_batch_execute( p_this, "meta"DIR_SEP"fetcher",
+ &fetch_meta, p_item );
}
art_finder_t *p_finder = (art_finder_t *)p_this;
input_item_t *p_item = p_finder->p_item;
- lua_State *L = init( p_this, p_item );
- int i_ret = vlclua_scripts_batch_execute( p_this, "meta/art", &fetch_art, L, p_item );
- lua_close( L );
-
- return i_ret;
+ return vlclua_scripts_batch_execute( p_this, "meta"DIR_SEP"art",
+ &fetch_art, p_item );
}