亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pda_callbacks.c

?? VLC Player Source Code
?? C
?? 第 1 頁 / 共 3 頁
字號:
/***************************************************************************** * pda_callbacks.c : Callbacks for the pda Linux Gtk+ plugin. ***************************************************************************** * Copyright (C) 2000, 2001 the VideoLAN team * $Id$ * * Authors: Jean-Paul Saman <jpsaman _at_ videolan _dot_ org> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************//***************************************************************************** * Preamble *****************************************************************************/#include <sys/types.h>                                              /* off_t */#ifdef HAVE_CONFIG_H# include "config.h"#endif#include <vlc_common.h>#include <vlc_input.h>#include <vlc_interface.h>#include <vlc_playlist.h>#include <vlc_vout.h>#include <dirent.h>#include <sys/stat.h>#include <unistd.h>#include <pwd.h>#include <grp.h>#include <gtk/gtk.h>#include "pda_callbacks.h"#include "pda_interface.h"#include "pda_support.h"#include "pda.h"#define VLC_MAX_MRL     256static char *get_file_perms(struct stat st);/***************************************************************************** * Useful function to retrieve p_intf ****************************************************************************/void * __GtkGetIntf( GtkWidget * widget ){    void *p_data;    if( GTK_IS_MENU_ITEM( widget ) )    {        /* Look for a GTK_MENU */        while( widget->parent && !GTK_IS_MENU( widget ) )        {            widget = widget->parent;        }        /* Maybe this one has the data */        p_data = gtk_object_get_data( GTK_OBJECT( widget ), "p_intf" );        if( p_data )        {            return p_data;        }        /* Otherwise, the parent widget has it */        widget = gtk_menu_get_attach_widget( GTK_MENU( widget ) );    }    /* We look for the top widget */    widget = gtk_widget_get_toplevel( GTK_WIDGET( widget ) );    p_data = gtk_object_get_data( GTK_OBJECT( widget ), "p_intf" );    return p_data;}static void PlaylistAddItem(GtkWidget *widget, gchar *name, char **ppsz_options, int i_size){    intf_thread_t *p_intf = GtkGetIntf( widget );    playlist_t    *p_playlist;    int           i_id , i_pos=0;    GtkTreeView   *p_tvplaylist = NULL;    p_playlist = pl_Yield( p_intf );    if( p_playlist ==  NULL)    {   /* Bail out when VLC's playlist object is not found. */        return;    }    /* Add to playlist object. */    p_tvplaylist = (GtkTreeView *) lookup_widget( GTK_WIDGET(widget), "tvPlaylist");    if (p_tvplaylist)    {        GtkTreeModel *p_play_model;        GtkTreeIter   p_play_iter;        p_play_model = gtk_tree_view_get_model(p_tvplaylist);         if (p_play_model)        {            int i;            /* Add a new row to the playlist treeview model */            gtk_list_store_append (GTK_LIST_STORE(p_play_model), &p_play_iter);            gtk_list_store_set (GTK_LIST_STORE(p_play_model), &p_play_iter,                                    0, name,   /* Add path to it !!! */                                    1, "no info",                                    2, playlist_CurrentSize(p_playlist), /* Hidden index. */                                    -1 );            /* Add to VLC's playlist */#if 0            if (p_intf->p_sys->b_autoplayfile)            {                playlist_Add( p_playlist, (const char*)name, (const char**)ppsz_options, i_size,                              PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END);            }            else#endif            {                i_id = playlist_AddExt( p_playlist, (const char*)name,                              (const char*)name,                              PLAYLIST_APPEND, PLAYLIST_END,                              (mtime_t) 0,                              (const char **) ppsz_options, i_pos,                              true, pl_Unlocked );            }            /* Cleanup memory */            for (i=0; i<i_size; i++)                free(ppsz_options[i]);            free(ppsz_options);        }    }    pl_Release( p_intf );}void PlaylistRebuildListStore( intf_thread_t *p_intf,    GtkListStore * p_list, playlist_t * p_playlist ){    GtkTreeIter iter;    int         i_dummy;    gchar *     ppsz_text[2];#if 0    GdkColor    red;    red.red     = 65535;    red.blue    = 0;    red.green   = 0;#endif    vlc_object_lock( p_playlist );    for( i_dummy = 0; i_dummy < playlist_CurrentSize(p_playlist) ; i_dummy++ )    {        playlist_item_t *p_item = playlist_ItemGetById( p_playlist, i_dummy, pl_Locked );        if( p_item )        {            ppsz_text[0] = p_item->p_input->psz_name;            ppsz_text[1] = "no info";            gtk_list_store_append (p_list, &iter);            gtk_list_store_set (p_list, &iter,                                0, ppsz_text[0],                                1, ppsz_text[1],                                2, i_dummy, /* Hidden index */                                -1);        }    }    vlc_object_unlock( p_playlist );}/***************************************************************** * Read directory helper function. ****************************************************************/void ReadDirectory(intf_thread_t *p_intf, GtkListStore *p_list, char *psz_dir ){    GtkTreeIter    iter;    struct dirent **pp_namelist;    struct passwd *p_pw;    struct group  *p_grp;    struct stat    st;    int n=-1, status=-1;    msg_Dbg(p_intf, "Changing to dir %s", psz_dir);    if (psz_dir)    {       status = chdir(psz_dir);       if (status<0)          msg_Dbg(p_intf, "permision denied" );    }    n = scandir(".", &pp_namelist, 0, alphasort);    if (n<0)        perror("scandir");    else    {        int i;        gchar *ppsz_text[4];        if (lstat("..", &st)==0)        {            /* user, group  */            p_pw  = getpwuid(st.st_uid);            p_grp = getgrgid(st.st_gid);            /* XXX : kludge temporaire pour yopy */            ppsz_text[0] = "..";            ppsz_text[1] = get_file_perms(st);            ppsz_text[2] = p_pw->pw_name;            ppsz_text[3] = p_grp->gr_name;            /* Add a new row to the model */            gtk_list_store_append (p_list, &iter);            gtk_list_store_set (p_list, &iter,                                0, ppsz_text[0],                                1, ppsz_text[1],                                2, st.st_size,                                3, ppsz_text[2],                                4, ppsz_text[3],                                -1);            free(ppsz_text[1]);        }            /* kludge */        for (i=0; i<n; i++)        {            if ((pp_namelist[i]->d_name[0] != '.') &&                (lstat(pp_namelist[i]->d_name, &st)==0))            {                /* user, group  */                p_pw  = getpwuid(st.st_uid);                p_grp = getgrgid(st.st_gid);                /* This is a list of strings. */                ppsz_text[0] = pp_namelist[i]->d_name;                ppsz_text[1] = get_file_perms(st);                ppsz_text[2] = p_pw->pw_name;                ppsz_text[3] = p_grp->gr_name;#if 0                msg_Dbg(p_intf, "(%d) file: %s permission: %s user: %s group: %s", i, ppsz_text[0], ppsz_text[1], ppsz_text[2], ppsz_text[3] );#endif                gtk_list_store_append (p_list, &iter);                gtk_list_store_set (p_list, &iter,                                    0, ppsz_text[0],                                    1, ppsz_text[1],                                    2, st.st_size,                                    3, ppsz_text[2],                                    4, ppsz_text[3],                                    -1);                free(ppsz_text[1]);            }        }        free(pp_namelist);    }}static char *get_file_perms(const struct stat st){    char  *psz_perm;    psz_perm = (char *) malloc(sizeof(char)*10);    strncpy( psz_perm, "----------", sizeof("----------"));    /* determine permission modes */    if (S_ISLNK(st.st_mode))        psz_perm[0]= 'l';    else if (S_ISDIR(st.st_mode))        psz_perm[0]= 'd';    else if (S_ISCHR(st.st_mode))        psz_perm[0]= 'c';    else if (S_ISBLK(st.st_mode))        psz_perm[0]= 'b';    else if (S_ISFIFO(st.st_mode))        psz_perm[0]= 'f';    else if (S_ISSOCK(st.st_mode))        psz_perm[0]= 's';    else if (S_ISREG(st.st_mode))        psz_perm[0]= '-';    else /* Unknown type is an error */        psz_perm[0]= '?';    /* Get file permissions */    /* User */    if (st.st_mode & S_IRUSR)        psz_perm[1]= 'r';    if (st.st_mode & S_IWUSR)        psz_perm[2]= 'w';    if (st.st_mode & S_IXUSR)    {        if (st.st_mode & S_ISUID)            psz_perm[3] = 's';        else            psz_perm[3]= 'x';    }    else if (st.st_mode & S_ISUID)        psz_perm[3] = 'S';    /* Group */    if (st.st_mode & S_IRGRP)        psz_perm[4]= 'r';    if (st.st_mode & S_IWGRP)        psz_perm[5]= 'w';    if (st.st_mode & S_IXGRP)    {        if (st.st_mode & S_ISGID)            psz_perm[6] = 's';        else            psz_perm[6]= 'x';    }    else if (st.st_mode & S_ISGID)        psz_perm[6] = 'S';    /* Other */    if (st.st_mode & S_IROTH)        psz_perm[7]= 'r';    if (st.st_mode & S_IWOTH)        psz_perm[8]= 'w';    if (st.st_mode & S_IXOTH)    {        /* 'sticky' bit */        if (st.st_mode &S_ISVTX)            psz_perm[9] = 't';        else            psz_perm[9]= 'x';    }    else if (st.st_mode &S_ISVTX)        psz_perm[9]= 'T';    return psz_perm;}/* * Main interface callbacks */gboolean onPDADeleteEvent(GtkWidget *widget, GdkEvent *event, gpointer user_data){    intf_thread_t *p_intf = GtkGetIntf( widget );    vlc_mutex_lock( &p_intf->change_lock );    vlc_object_kill( p_intf->p_libvlc );    vlc_mutex_unlock( &p_intf->change_lock );    msg_Dbg( p_intf, "about to exit vlc ... signaled" );    return TRUE;}void onRewind(GtkButton *button, gpointer user_data){    intf_thread_t *p_intf = GtkGetIntf( button );    if (p_intf->p_sys->p_input != NULL)    {        var_SetVoid( p_intf->p_sys->p_input, "rate-slower" );    }}void onPause(GtkButton *button, gpointer user_data){    intf_thread_t *p_intf = GtkGetIntf( button );    if (p_intf->p_sys->p_input != NULL)    {        var_SetInteger( p_intf->p_sys->p_input, "state", PAUSE_S );    }}void onPlay(GtkButton *button, gpointer user_data){    intf_thread_t *p_intf = GtkGetIntf( GTK_WIDGET( button ) );    playlist_t *p_playlist = pl_Yield( p_intf );    if (p_playlist)    {        vlc_object_lock( p_playlist );        if (playlist_CurrentSize(p_playlist))        {            vlc_object_unlock( p_playlist );            playlist_Play( p_playlist );            gdk_window_lower( p_intf->p_sys->p_window->window );        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区视频在线| 2023国产精品自拍| 一区二区三区国产精华| 色综合久久天天| 国产精品久久久久久户外露出 | caoporen国产精品视频| 欧美国产日韩亚洲一区| 成人一级视频在线观看| 中文字幕字幕中文在线中不卡视频| 成人激情电影免费在线观看| 亚洲私人影院在线观看| 色一区在线观看| 亚洲小说欧美激情另类| 91精品福利在线一区二区三区| 蜜臀av国产精品久久久久 | 色综合天天综合给合国产| 亚洲精品中文字幕在线观看| 欧美日韩一区不卡| 国产一区二区主播在线| 综合婷婷亚洲小说| 欧美高清视频在线高清观看mv色露露十八 | 六月丁香婷婷久久| 欧美极品少妇xxxxⅹ高跟鞋| 欧亚一区二区三区| 久久99精品网久久| 中文字幕日韩欧美一区二区三区| 色吧成人激情小说| 精品在线播放午夜| 中文字幕亚洲精品在线观看| 欧美一二三四在线| 成人精品免费看| 亚洲欧美激情视频在线观看一区二区三区| 欧美日韩三级视频| 精品一区二区三区香蕉蜜桃| 国产精品激情偷乱一区二区∴| 欧美日韩你懂得| 国产一区二区不卡在线| 亚洲国产精品久久人人爱| 精品精品国产高清a毛片牛牛 | 大美女一区二区三区| 亚洲线精品一区二区三区八戒| 欧美一区二区三区电影| 91视频国产资源| 久久草av在线| 午夜久久久久久久久| 国产精品久久久久久久蜜臀| 日韩一级精品视频在线观看| 日本久久一区二区| 成人激情图片网| 国产一区二区三区在线观看免费| 一区二区高清在线| 亚洲国产精品精华液ab| 欧美mv和日韩mv的网站| 欧美日本高清视频在线观看| 97久久超碰国产精品电影| 国产美女主播视频一区| 蜜桃av一区二区三区| 亚洲综合成人在线| 国产欧美日韩在线看| 日韩精品一区二区三区视频在线观看| 91官网在线免费观看| av午夜精品一区二区三区| 国产精品一区2区| 视频一区免费在线观看| 亚洲精品网站在线观看| 国产精品久久久久久久久免费丝袜 | 久久久久久夜精品精品免费| 欧美一区二区三区四区视频| 在线视频欧美精品| 色综合视频在线观看| av中文字幕不卡| 不卡的电影网站| 成人黄色777网| 成人免费观看av| 成人一区二区视频| 成a人片亚洲日本久久| 福利电影一区二区| 国产成人午夜电影网| 成人免费高清视频| av电影在线观看完整版一区二区| 国产91丝袜在线观看| 国产高清久久久| 国产91丝袜在线播放九色| 国产精品一区二区三区乱码| 国产精品18久久久久| 国产+成+人+亚洲欧洲自线| 风间由美一区二区av101| 成人激情图片网| 色综合天天狠狠| 欧美影院精品一区| 51精品视频一区二区三区| 欧美福利视频导航| 欧美电视剧在线观看完整版| 久久亚洲春色中文字幕久久久| 国产婷婷色一区二区三区| 中文子幕无线码一区tr| 亚洲欧美日韩国产中文在线| 亚洲综合偷拍欧美一区色| 婷婷六月综合亚洲| 激情五月婷婷综合| 99国产精品久久久久久久久久久| 91免费看片在线观看| 欧美久久久影院| 精品国产乱码久久久久久图片| 日本一区免费视频| 亚洲天天做日日做天天谢日日欢| 亚洲激情成人在线| 免费在线观看成人| 从欧美一区二区三区| 欧美自拍偷拍一区| 精品久久久久久久久久久久包黑料 | 91精品国产麻豆| 久久综合给合久久狠狠狠97色69| 国产嫩草影院久久久久| 亚洲国产精品嫩草影院| 韩国精品一区二区| 91久久久免费一区二区| 日韩限制级电影在线观看| 中文欧美字幕免费| 婷婷丁香久久五月婷婷| 国产91在线|亚洲| 欧美日韩在线免费视频| 国产亚洲欧美日韩俺去了| 一区二区三区日韩欧美| 国产一区二区三区久久悠悠色av| 91年精品国产| 欧美不卡一区二区三区| 亚洲欧美一区二区在线观看| 蜜桃视频在线观看一区| 一本色道久久综合亚洲aⅴ蜜桃| 欧美成人激情免费网| 亚洲综合另类小说| 成人91在线观看| 日韩欧美第一区| 亚洲国产一区二区视频| 国产91精品一区二区麻豆网站| 欧美美女网站色| ㊣最新国产の精品bt伙计久久| 日本在线不卡一区| 91视频xxxx| 欧美激情一区二区三区在线| 男女男精品网站| 欧美日韩国产乱码电影| 亚洲欧美一区二区久久 | 国产精品1024| 日韩欧美第一区| 午夜视黄欧洲亚洲| 欧美在线小视频| 中文字幕日韩av资源站| 成人亚洲一区二区一| 日韩免费高清电影| 日韩精品亚洲一区二区三区免费| 91久久精品一区二区三| 国产精品视频在线看| 国产精品资源在线看| 欧美成人video| 久久精品免费看| 4438x亚洲最大成人网| 婷婷成人综合网| 欧美日韩一区二区在线观看 | 亚洲一区二区三区中文字幕在线| 成人午夜激情在线| 久久久久久久久久久久电影| 美女精品自拍一二三四| 884aa四虎影成人精品一区| 五月婷婷综合在线| 欧美日本一区二区三区| 亚洲电影你懂得| 欧美精三区欧美精三区| 亚洲国产综合视频在线观看| 欧美性猛片aaaaaaa做受| 一区二区三区欧美亚洲| 欧美色图第一页| 日韩专区中文字幕一区二区| 欧美一区二区黄色| 玖玖九九国产精品| 久久精品无码一区二区三区| 极品少妇一区二区三区精品视频| 日韩一区二区三免费高清| 麻豆成人久久精品二区三区红 | 精品国产百合女同互慰| 国产麻豆精品视频| 中文字幕 久热精品 视频在线| 成人av网址在线观看| 亚洲欧洲一区二区在线播放| 色视频一区二区| 亚洲午夜av在线| 精品三级av在线| 粉嫩av一区二区三区| 1024成人网| 欧美天堂一区二区三区| 亚洲成人动漫在线免费观看| 日韩一区二区三区电影在线观看| 国产精品一区二区黑丝| 亚洲免费伊人电影| 日韩一本二本av| 成人美女在线视频| 午夜免费久久看| 久久亚洲春色中文字幕久久久| 国产成人激情av|