亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
中文字幕在线不卡| 日韩色视频在线观看| 亚洲人成在线播放网站岛国| 91在线视频在线| 一区二区三区在线播放| 欧美精品日韩一区| 久久99精品网久久| 欧美国产一区视频在线观看| 97精品视频在线观看自产线路二| 一区二区三区四区激情| 欧美精品丝袜中出| 韩国理伦片一区二区三区在线播放 | 婷婷综合五月天| 日韩欧美国产精品| 成人久久视频在线观看| 亚洲黄一区二区三区| 5月丁香婷婷综合| 国产精品99久久久久久久vr| 国产精品久久精品日日| 欧美日韩国产片| 国产精品一区二区三区99| 尤物视频一区二区| 欧美xingq一区二区| 91小视频在线| 麻豆精品新av中文字幕| 国产精品久久久久9999吃药| 欧美日韩国产123区| 高清av一区二区| 亚洲国产va精品久久久不卡综合| 久久一日本道色综合| 色综合久久综合中文综合网| 黄页视频在线91| 亚洲一区自拍偷拍| 欧美激情综合网| 欧美精品一卡二卡| 99久久国产综合精品色伊| 久久精品免费观看| 樱花草国产18久久久久| 久久久亚洲国产美女国产盗摄| 欧美体内she精高潮| 国产精品一区二区三区网站| 日韩激情一区二区| 日韩美女精品在线| 国产日产精品1区| 欧美一区二区性放荡片| 欧美在线不卡一区| 成人丝袜18视频在线观看| 日本vs亚洲vs韩国一区三区二区| 国产精品美女一区二区三区| 日韩欧美国产一区二区三区| 色94色欧美sute亚洲线路二| 国产精品69久久久久水密桃 | 另类调教123区| 一区二区三区丝袜| 国产精品久久久久婷婷二区次| 日韩免费观看2025年上映的电影| 91黄色小视频| 色综合视频一区二区三区高清| 国产精品一区二区三区99| 美女视频黄久久| 日本va欧美va瓶| 丝袜亚洲另类欧美综合| 亚洲高清中文字幕| 亚洲一区二区三区四区在线免费观看| 国产午夜精品一区二区三区视频| 日韩欧美第一区| 日韩美女一区二区三区| 日韩一区二区在线免费观看| 欧美日韩情趣电影| 欧美精品精品一区| 91精品国产综合久久国产大片| 日本韩国一区二区三区| 一本到不卡免费一区二区| 99国产精品一区| 色一情一伦一子一伦一区| av综合在线播放| 91丨porny丨最新| 91免费在线看| 欧洲av在线精品| 欧美日本精品一区二区三区| 欧美日韩成人综合| 欧美一区二区在线观看| 精品国产91亚洲一区二区三区婷婷| 日韩欧美www| 久久久亚洲精品一区二区三区| 久久一区二区视频| 国产精品天干天干在观线| 国产精品久久久久影院色老大| 亚洲欧美激情一区二区| 亚洲一区二区三区免费视频| 亚洲成av人片在线观看| 久久精品国产亚洲一区二区三区| 毛片不卡一区二区| 国产成人av一区| 91伊人久久大香线蕉| 欧美日本韩国一区| 日韩精品影音先锋| 日本一区二区视频在线观看| 亚洲男人的天堂av| 午夜a成v人精品| 久久精品国产免费看久久精品| 国产一区三区三区| 色婷婷亚洲综合| 日韩一区国产二区欧美三区| 国产欧美精品在线观看| 一区二区三区四区在线免费观看 | 精品99一区二区三区| 中文字幕精品一区二区精品绿巨人 | 中文字幕中文在线不卡住| 亚洲自拍偷拍欧美| 免费观看成人鲁鲁鲁鲁鲁视频| 高清视频一区二区| 精品视频色一区| 久久精品人人做人人爽人人| 亚洲欧美一区二区三区孕妇| 亚洲国产日韩精品| 国产真实精品久久二三区| 99久久国产综合精品色伊 | 欧洲在线/亚洲| 久久只精品国产| 亚洲精品亚洲人成人网| 国产在线视视频有精品| 欧美亚洲一区二区在线| 久久精品亚洲精品国产欧美| 亚洲高清视频中文字幕| 国产成人在线影院| 日韩一区二区三区视频| 一区二区欧美视频| 国产成人精品免费在线| 51精品国自产在线| 亚洲免费三区一区二区| 国内精品免费在线观看| 日本韩国欧美国产| 国产精品欧美一级免费| 国内一区二区视频| 欧美精品vⅰdeose4hd| 亚洲女爱视频在线| 成人h动漫精品一区二区| 欧美一区二区三区公司| 亚洲综合一区二区| 波多野洁衣一区| 久久久久久久久久美女| 精品在线视频一区| 666欧美在线视频| 亚洲一区二区三区四区在线观看| 99久久精品免费观看| 久久精品网站免费观看| 国内国产精品久久| 日韩女优视频免费观看| 日韩高清欧美激情| 在线视频综合导航| 亚洲猫色日本管| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲国产成人私人影院tom| 久久疯狂做爰流白浆xx| 在线综合亚洲欧美在线视频| 亚洲成人av免费| 欧美日韩国产大片| 午夜一区二区三区视频| 欧美午夜寂寞影院| 亚洲一级电影视频| 欧美少妇一区二区| 亚洲成人第一页| 91精品午夜视频| 免费在线看一区| 精品理论电影在线| 久久精品国产99国产| 欧美tk—视频vk| 国产一区日韩二区欧美三区| 久久九九久精品国产免费直播| 国产精品91xxx| 日本一二三四高清不卡| 不卡av在线免费观看| 最新久久zyz资源站| 色哟哟国产精品免费观看| 亚洲一区二区五区| 欧美另类变人与禽xxxxx| 美女国产一区二区| 欧美精品一区视频| 丁香天五香天堂综合| 亚洲日本乱码在线观看| 在线视频亚洲一区| 日韩高清在线不卡| 国产色91在线| 97超碰欧美中文字幕| 亚洲高清三级视频| 精品捆绑美女sm三区| 成人精品在线视频观看| 亚洲精品乱码久久久久久黑人| 欧美色综合影院| 久久99精品国产.久久久久久| 国产欧美一区二区精品仙草咪| 91香蕉视频污在线| 天天做天天摸天天爽国产一区| 久久综合色综合88| 一本一本久久a久久精品综合麻豆| 五月开心婷婷久久| 国产欧美一区二区精品仙草咪| 欧美性大战久久久| 国产精品一区二区在线观看网站|