📄 mvar.c
字号:
module_GetName( p_parser, true ) ); mvar_AppendVar( s, sd ); } } vlc_list_release( p_list ); return s;}mvar_t *mvar_InputVarSetNew( intf_thread_t *p_intf, char *name, input_thread_t *p_input, const char *psz_variable ){ intf_sys_t *p_sys = p_intf->p_sys; mvar_t *s = mvar_New( name, "set" ); vlc_value_t val, val_list, text_list; int i_type, i; if( p_input == NULL ) { return s; } /* Check the type of the object variable */ i_type = var_Type( p_sys->p_input, psz_variable ); /* Make sure we want to display the variable */ if( i_type & VLC_VAR_HASCHOICE ) { var_Change( p_sys->p_input, psz_variable, VLC_VAR_CHOICESCOUNT, &val, NULL ); if( val.i_int == 0 ) return s; if( (i_type & VLC_VAR_TYPE) != VLC_VAR_VARIABLE && val.i_int == 1 ) return s; } else { return s; } switch( i_type & VLC_VAR_TYPE ) { case VLC_VAR_VOID: case VLC_VAR_BOOL: case VLC_VAR_VARIABLE: case VLC_VAR_STRING: case VLC_VAR_INTEGER: break; default: /* Variable doesn't exist or isn't handled */ return s; } if( var_Get( p_sys->p_input, psz_variable, &val ) < 0 ) { return s; } if( var_Change( p_sys->p_input, psz_variable, VLC_VAR_GETLIST, &val_list, &text_list ) < 0 ) { if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string ); return s; } for( i = 0; i < val_list.p_list->i_count; i++ ) { char *psz, psz_int[16]; mvar_t *itm; switch( i_type & VLC_VAR_TYPE ) { case VLC_VAR_STRING: itm = mvar_New( name, "set" ); /* FIXME: Memory leak here?? (remove strdup?) */ psz = strdup( text_list.p_list->p_values[i].psz_string ); mvar_AppendNewVar( itm, "name", psz ); mvar_AppendNewVar( itm, "id", val_list.p_list->p_values[i].psz_string ); snprintf( psz_int, sizeof(psz_int), "%d", ( !strcmp( val.psz_string, val_list.p_list->p_values[i].psz_string ) && !( i_type & VLC_VAR_ISCOMMAND ) ) ); mvar_AppendNewVar( itm, "selected", psz_int ); mvar_AppendVar( s, itm ); break; case VLC_VAR_INTEGER: itm = mvar_New( name, "set" ); psz = strdup( text_list.p_list->p_values[i].psz_string ); mvar_AppendNewVar( itm, "name", psz ); snprintf( psz_int, sizeof(psz_int), "%d", val_list.p_list->p_values[i].i_int ); mvar_AppendNewVar( itm, "id", psz_int ); snprintf( psz_int, sizeof(psz_int), "%d", ( val.i_int == val_list.p_list->p_values[i].i_int ) && !( i_type & VLC_VAR_ISCOMMAND ) ); mvar_AppendNewVar( itm, "selected", psz_int ); mvar_AppendVar( s, itm ); break; default: break; } } /* clean up everything */ if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string ); var_Change( p_sys->p_input, psz_variable, VLC_VAR_FREELIST, &val_list, &text_list ); return s;}#if 0mvar_t *mvar_HttpdInfoSetNew( char *name, httpd_t *p_httpd, int i_type ){ mvar_t *s = mvar_New( name, "set" ); httpd_info_t info; int i; if( !p_httpd->pf_control( p_httpd, i_type, &info, NULL ) ) { for( i= 0; i < info.i_count; ) { mvar_t *inf; inf = mvar_New( name, "set" ); do { /* fprintf( stderr," mvar_HttpdInfoSetNew: append name=`%s' value=`%s'\n", info.info[i].psz_name, info.info[i].psz_value ); */ mvar_AppendNewVar( inf, info.info[i].psz_name, info.info[i].psz_value ); i++; } while( i < info.i_count && strcmp( info.info[i].psz_name, "id" ) ); mvar_AppendVar( s, inf ); } } /* free mem */ for( i = 0; i < info.i_count; i++ ) { free( info.info[i].psz_name ); free( info.info[i].psz_value ); } if( info.i_count > 0 ) { free( info.info ); } return s;}#endifmvar_t *mvar_FileSetNew( intf_thread_t *p_intf, char *name, char *psz_dir ){ mvar_t *s = mvar_New( name, "set" ); char **ppsz_dir_content; int i_dir_content, i; psz_dir = RealPath( psz_dir ); /* parse psz_src dir */ if( ( i_dir_content = utf8_scandir( psz_dir, &ppsz_dir_content, Filter, InsensitiveAlphasort ) ) == -1 ) { if( errno != ENOENT && errno != ENOTDIR ) msg_Warn( p_intf, "error while scanning dir %s (%m)", psz_dir ); free( psz_dir ); return s; } for( i = 0; i < i_dir_content; i++ ) {#ifdef HAVE_SYS_STAT_H struct stat stat_info;#endif char *psz_name = ppsz_dir_content[i], *psz_ext, *psz_dummy; char psz_tmp[strlen( psz_dir ) + 1 + strlen( psz_name ) + 1]; mvar_t *f;#if defined( WIN32 ) if( psz_dir[0] == '\0' || (psz_dir[0] == '\\' && psz_dir[1] == '\0') ) { strcpy( psz_tmp, psz_name ); } else#endif { sprintf( psz_tmp, "%s"DIR_SEP"%s", psz_dir, psz_name );#ifdef HAVE_SYS_STAT_H if( utf8_stat( psz_tmp, &stat_info ) == -1 ) { free( psz_name ); continue; }#endif } f = mvar_New( name, "set" ); /* put lower-case file extension in 'ext' */ psz_ext = strrchr( psz_name, '.' ); psz_ext = strdup( psz_ext != NULL ? psz_ext + 1 : "" ); for( psz_dummy = psz_ext; *psz_dummy != '\0'; psz_dummy++ ) *psz_dummy = tolower( *psz_dummy ); mvar_AppendNewVar( f, "ext", psz_ext ); free( psz_ext );#if defined( WIN32 ) if( psz_dir[0] == '\0' || (psz_dir[0] == '\\' && psz_dir[1] == '\0') ) { char psz_tmp[3]; sprintf( psz_tmp, "%c:", psz_name[0] ); mvar_AppendNewVar( f, "name", psz_name ); mvar_AppendNewVar( f, "basename", psz_tmp ); mvar_AppendNewVar( f, "type", "directory" ); mvar_AppendNewVar( f, "size", "unknown" ); mvar_AppendNewVar( f, "date", "unknown" ); } else#endif { char psz_buf[26]; char psz_tmp[strlen( psz_dir ) + 1 + strlen( psz_name ) + 1]; sprintf( psz_tmp, "%s"DIR_SEP"%s", psz_dir, psz_name ); mvar_AppendNewVar( f, "name", psz_tmp ); mvar_AppendNewVar( f, "basename", psz_name );#ifdef HAVE_SYS_STAT_H if( S_ISDIR( stat_info.st_mode ) ) { mvar_AppendNewVar( f, "type", "directory" ); } else if( S_ISREG( stat_info.st_mode ) ) { mvar_AppendNewVar( f, "type", "file" ); } else { mvar_AppendNewVar( f, "type", "unknown" ); } snprintf( psz_buf, sizeof( psz_buf ), "%"PRId64, (int64_t)stat_info.st_size ); mvar_AppendNewVar( f, "size", psz_buf ); /* FIXME memory leak FIXME */# ifdef HAVE_CTIME_R ctime_r( &stat_info.st_mtime, psz_buf ); mvar_AppendNewVar( f, "date", psz_buf );# else mvar_AppendNewVar( f, "date", ctime( &stat_info.st_mtime ) );# endif#else mvar_AppendNewVar( f, "type", "unknown" ); mvar_AppendNewVar( f, "size", "unknown" ); mvar_AppendNewVar( f, "date", "unknown" );#endif } mvar_AppendVar( s, f ); free( psz_name ); } free( psz_dir ); free( ppsz_dir_content ); return s;}static void mvar_VlmSetNewLoop( char *name, vlm_t *vlm, mvar_t *s, vlm_message_t *el, bool b_name ){ /* Over name */ mvar_t *set; int k; /* Add a node with name and info */ set = mvar_New( name, "set" ); if( b_name == true ) { mvar_AppendNewVar( set, "name", el->psz_name ); } for( k = 0; k < el->i_child; k++ ) { vlm_message_t *ch = el->child[k]; if( ch->i_child > 0 ) { mvar_VlmSetNewLoop( ch->psz_name, vlm, set, ch, false ); } else { if( ch->psz_value ) { mvar_AppendNewVar( set, ch->psz_name, ch->psz_value ); } else { mvar_AppendNewVar( set, el->psz_name, ch->psz_name ); } } } mvar_AppendVar( s, set );}mvar_t *mvar_VlmSetNew( char *name, vlm_t *vlm ){ mvar_t *s = mvar_New( name, "set" );#ifdef ENABLE_VLM vlm_message_t *msg; int i; if( vlm == NULL ) return s; if( vlm_ExecuteCommand( vlm, "show", &msg ) ) return s; for( i = 0; i < msg->i_child; i++ ) { /* Over media, schedule */ vlm_message_t *ch = msg->child[i]; int j; for( j = 0; j < ch->i_child; j++ ) { /* Over name */ vlm_message_t *el = ch->child[j]; vlm_message_t *inf, *desc; char psz[6 + strlen(el->psz_name)]; sprintf( psz, "show %s", el->psz_name ); if( vlm_ExecuteCommand( vlm, psz, &inf ) ) continue; desc = inf->child[0]; mvar_VlmSetNewLoop( el->psz_name, vlm, s, desc, true ); vlm_MessageDelete( inf ); } } vlm_MessageDelete( msg );#endif /* ENABLE_VLM */ return s;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -