-static int vlclua_get_playlist( lua_State *L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- if( p_playlist )
- {
- vlclua_push_vlc_object( L, p_playlist, vlclua_gc_release );
- }
- else lua_pushnil( L );
- return 1;
-}
-
-static int vlclua_playlist_prev( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_Prev( p_playlist );
- vlc_object_release( p_playlist );
- return 0;
-}
-
-static int vlclua_playlist_next( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_Next( p_playlist );
- vlc_object_release( p_playlist );
- return 0;
-}
-
-static int vlclua_playlist_play( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_Play( p_playlist );
- vlc_object_release( p_playlist );
- return 0;
-}
-
-static int vlclua_playlist_stop( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_Stop( p_playlist );
- vlc_object_release( p_playlist );
- return 0;
-}
-
-static int vlclua_playlist_clear( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_Stop( p_playlist ); /* Isn't this already implied by Clear? */
- playlist_Clear( p_playlist, VLC_FALSE );
- vlc_object_release( p_playlist );
- return 0;
-}
-
-static int vlclua_playlist_repeat( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- int i_ret = vlclua_var_toggle_or_set( L, p_playlist, "repeat" );
- vlc_object_release( p_playlist );
- return i_ret;
-}
-
-static int vlclua_playlist_loop( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- int i_ret = vlclua_var_toggle_or_set( L, p_playlist, "loop" );
- vlc_object_release( p_playlist );
- return i_ret;
-}
-
-static int vlclua_playlist_random( lua_State * L )
-{
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- int i_ret = vlclua_var_toggle_or_set( L, p_playlist, "random" );
- vlc_object_release( p_playlist );
- return i_ret;
-}
-
-static int vlclua_playlist_goto( lua_State * L )
-{
- /* XXX: logic copied from rc.c ... i'm not sure that it's ok as it
- * implies knowledge of the playlist internals. */
- playlist_t *p_playlist;
- int i_size;
- playlist_item_t *p_item, *p_parent;
-
- int i_pos;
- if( lua_gettop( L ) != 1 ) return vlclua_error( L );
- i_pos = luaL_checkint( L, -1 );
- lua_pop( L, 1 );
- if( i_pos <= 0 ) return 0;
-
- p_playlist = vlclua_get_playlist_internal( L );
- /* The playlist stores 2 times the same item: onelevel & category */
- i_size = p_playlist->items.i_size / 2;
-
- if( i_pos > i_size )
- {
- vlc_object_release( p_playlist );
- return 0;
- }
-
- p_item = p_parent = p_playlist->items.p_elems[i_pos*2-1];
- while( p_parent->p_parent )
- p_parent = p_parent->p_parent;
- playlist_Control( p_playlist, PLAYLIST_VIEWPLAY, VLC_TRUE,
- p_parent, p_item );
-
- vlc_object_release( p_playlist );
- lua_pushboolean( L, 1 );
- return 1;
-}
-
-static int vlclua_playlist_add( lua_State *L )
-{
- int i_count;
- vlc_object_t *p_this = vlclua_get_this( L );
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- i_count = vlclua_playlist_add_internal( p_this, L, p_playlist,
- NULL, VLC_TRUE );
- vlc_object_release( p_playlist );
- lua_pushinteger( L, i_count );
- return 1;
-}
-
-static int vlclua_playlist_enqueue( lua_State *L )
-{
- int i_count;
- vlc_object_t *p_this = vlclua_get_this( L );
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- i_count = vlclua_playlist_add_internal( p_this, L, p_playlist,
- NULL, VLC_FALSE );
- vlc_object_release( p_playlist );
- lua_pushinteger( L, i_count );
- return 1;
-}
-
-static int vlclua_playlist_get( lua_State *L )
-{
- /* TODO: make it possible to get the tree playlist */
- playlist_t *p_playlist = vlclua_get_playlist_internal( L );
- playlist_item_t *p_root;
- int i;
- if( lua_isboolean( L, 1 ) && lua_toboolean( L, 1 ) )
- p_root = p_playlist->p_ml_onelevel; /* media library */
- else
- p_root = p_playlist->p_local_onelevel; /* local/normal playlist */
- lua_createtable( L, p_root->i_children, 0 );
- for( i = 0; i < p_root->i_children; i++ )
- {
- playlist_item_t *p_item = p_root->pp_children[i];
- input_item_t *p_input = p_item->p_input;
- lua_pushinteger( L, i+1 );
- lua_newtable( L );
- lua_pushstring( L, p_input->psz_name );
- lua_setfield( L, -2, "name" );
- lua_pushstring( L, p_input->psz_uri );
- lua_setfield( L, -2, "path" );
- if( p_input->i_duration < 0 )
- lua_pushnumber( L, -1 );
- else
- lua_pushnumber( L, ((double)p_input->i_duration)*1e-6 );
- lua_setfield( L, -2, "duration" );
- lua_pushinteger( L, p_input->i_nb_played );
- lua_setfield( L, -2, "nb_played" );
- /* TODO: add (optional) info categories, meta, options, es */
- lua_settable( L, -3 );
- }
- vlc_object_release( p_playlist );
- return 1;
-}
-
-static int vlclua_playlist_sort( lua_State *L )
-{
- /* allow setting the different sort keys */
- return 0;
-}
-
-/* FIXME: split this in 3 different functions? */
-static int vlclua_playlist_status( lua_State *L )
-{
- intf_thread_t *p_intf = (intf_thread_t *)vlclua_get_this( L );
- playlist_t *p_playlist = pl_Yield( p_intf );
- /*
- int i_count = 0;
- lua_settop( L, 0 );*/
- if( p_playlist->p_input )
- {
- /*char *psz_uri =
- input_item_GetURI( input_GetItem( p_playlist->p_input ) );
- lua_pushstring( L, psz_uri );
- free( psz_uri );
- lua_pushnumber( L, config_GetInt( p_intf, "volume" ) );*/
- vlc_mutex_lock( &p_playlist->object_lock );
- switch( p_playlist->status.i_status )
- {
- case PLAYLIST_STOPPED:
- lua_pushstring( L, "stopped" );
- break;
- case PLAYLIST_RUNNING:
- lua_pushstring( L, "playing" );
- break;
- case PLAYLIST_PAUSED:
- lua_pushstring( L, "paused" );
- break;
- default:
- lua_pushstring( L, "unknown" );
- break;
- }
- vlc_mutex_unlock( &p_playlist->object_lock );
- /*i_count += 3;*/
- }
- else
- {
- lua_pushstring( L, "stopped" );
- }
- vlc_object_release( p_playlist );
- return 1;
-}
-
-
-static int vlclua_lock_and_wait( lua_State *L )
-{
- vlc_object_t *p_this = vlclua_get_this( L );
- int b_quit = vlc_object_lock_and_wait( p_this );
- lua_pushboolean( L, b_quit );
- return 1;
-}
-
-static int vlclua_signal( lua_State *L )
-{
- vlc_object_t *p_this = vlclua_get_this( L );
- vlc_object_signal( p_this );
- return 0;
-}
-
-static int vlclua_mdate( lua_State *L )
-{
- lua_pushnumber( L, mdate() );
- return 1;
-}
-
-static int vlclua_intf_should_die( lua_State *L )
-{
- intf_thread_t *p_intf = (intf_thread_t*)vlclua_get_this( L );
- lua_pushboolean( L, intf_ShouldDie( p_intf ) );
- return 1;
-}
-
-static luaL_Reg p_reg[] =
-{
- { "input_info", vlclua_input_info },
- { "is_playing", vlclua_is_playing },
- { "get_title", vlclua_get_title },
-
- { "fullscreen", vlclua_fullscreen },
-
- { "mdate", vlclua_mdate },
-
- { "module_command", vlclua_module_command },
- { "libvlc_command", vlclua_libvlc_command },
-
- { "decode_uri", vlclua_decode_uri },
- { "resolve_xml_special_chars", vlclua_resolve_xml_special_chars },
- { "convert_xml_special_chars", vlclua_convert_xml_special_chars },
-
- { "lock_and_wait", vlclua_lock_and_wait },
- { "signal", vlclua_signal },
-
- { "version", vlclua_version },
- { "license", vlclua_license },
- { "copyright", vlclua_copyright },
- { "should_die", vlclua_intf_should_die },
- { "quit", vlclua_quit },
-
- { "homedir", vlclua_homedir },
- { "datadir", vlclua_datadir },
- { "configdir", vlclua_configdir },
- { "cachedir", vlclua_cachedir },
- { "datadir_list", vlclua_datadir_list },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_object[] =
-{
- { "input", vlclua_get_input }, /* This is fast */
- { "playlist", vlclua_get_playlist }, /* This is fast */
- { "libvlc", vlclua_get_libvlc }, /* This is fast */
-
- { "find", vlclua_object_find }, /* This is slow */
- { "find_name", vlclua_object_find_name }, /* This is slow */
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_var[] =
-{
- { "get", vlclua_var_get },
- { "get_list", vlclua_var_get_list },
- { "set", vlclua_var_set },
- { "add_callback", vlclua_add_callback },
- { "del_callback", vlclua_del_callback },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_config[] =
-{
- { "get", vlclua_config_get },
- { "set", vlclua_config_set },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_msg[] =
-{
- { "dbg", vlclua_msg_dbg },
- { "warn", vlclua_msg_warn },
- { "err", vlclua_msg_err },
- { "info", vlclua_msg_info },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_playlist[] =
-{
- { "prev", vlclua_playlist_prev },
- { "next", vlclua_playlist_next },
- { "play", vlclua_playlist_play },
- { "stop", vlclua_playlist_stop },
- { "clear", vlclua_playlist_clear },
- { "repeat_", vlclua_playlist_repeat },
- { "loop", vlclua_playlist_loop },
- { "random", vlclua_playlist_random },
- { "goto", vlclua_playlist_goto },
- { "status", vlclua_playlist_status },
- { "add", vlclua_playlist_add },
- { "enqueue", vlclua_playlist_enqueue },
- { "get", vlclua_playlist_get },
- { "stats", vlclua_input_stats },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_volume[] =
-{
- { "get", vlclua_volume_get },
- { "set", vlclua_volume_set },
- { "up", vlclua_volume_up },
- { "down", vlclua_volume_down },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_osd[] =
-{
- { "icon", vlclua_osd_icon },
- { "message", vlclua_osd_message },
- { "slider", vlclua_osd_slider },
- { "channel_register", vlclua_spu_channel_register },
- { "channel_clear", vlclua_spu_channel_clear },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_net[] =
-{
- { "url_parse", vlclua_url_parse },
- { "listen_tcp", vlclua_net_listen_tcp },
- { "listen_close", vlclua_net_listen_close },
- { "accept", vlclua_net_accept },
- { "close", vlclua_net_close },
- { "send", vlclua_net_send },
- { "recv", vlclua_net_recv },
- { "select", vlclua_net_select },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_fd[] =
-{
-/* { "open", vlclua_fd_open },*/
- { "read", vlclua_fd_read },
- { "write", vlclua_fd_write },
- { "stat", vlclua_stat },
-
- { "opendir", vlclua_opendir },
-
- { "new_fd_set", vlclua_fd_set_new },
- { "fd_clr", vlclua_fd_clr },
- { "fd_isset", vlclua_fd_isset },
- { "fd_set", vlclua_fd_set },
- { "fd_zero", vlclua_fd_zero },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_vlm[] =
-{
- { "new", vlclua_vlm_new },
- { "delete", vlclua_vlm_delete },
- { "execute_command", vlclua_vlm_execute_command },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_httpd[] =
-{
- { "host_new", vlclua_httpd_tls_host_new },
- { "host_delete", vlclua_httpd_host_delete },
- { "handler_new", vlclua_httpd_handler_new },
- { "handler_delete", vlclua_httpd_handler_delete },
- { "file_new", vlclua_httpd_file_new },
- { "file_delete", vlclua_httpd_file_delete },
- { "redirect_new", vlclua_httpd_redirect_new },
- { "redirect_delete", vlclua_httpd_redirect_delete },
-
- { NULL, NULL }
-};
-
-static luaL_Reg p_reg_acl[] =
-{
- { "create", vlclua_acl_create },
- { "delete", vlclua_acl_delete },
- { "check", vlclua_acl_check },
- { "duplicate", vlclua_acl_duplicate },
- { "add_host", vlclua_acl_add_host },
- { "add_net", vlclua_acl_add_net },
- { "load_file", vlclua_acl_load_file },
-
- { NULL, NULL }
-};
-
-static void Run( intf_thread_t *p_intf );
-
-static char *FindFile( intf_thread_t *p_intf, const char *psz_name )