# HG changeset patch # User ben # Date 1180464578 0 # Node ID 9bf57f60bf0a248719149fe44e9ba96737d82706 # Parent e80337bdc88605fc3f76602e1fa2d7bfbd394591 new -menu-chroot option that prevent OSD file selection menu to go to an unwanted location (yeah, chroot ;-)) diff -r e80337bdc886 -r 9bf57f60bf0a cfg-mplayer.h --- a/cfg-mplayer.h Tue May 29 16:14:52 2007 +0000 +++ b/cfg-mplayer.h Tue May 29 18:49:38 2007 +0000 @@ -71,6 +71,7 @@ #ifdef HAVE_MENU extern int menu_startup; extern int menu_keepdir; +extern char *menu_chroot; #ifdef USE_FRIBIDI extern char *menu_fribidi_charset; extern int menu_flip_hebrew; @@ -298,6 +299,7 @@ {"menu-cfg", &menu_cfg, CONF_TYPE_STRING, CONF_GLOBAL, 0, 0, NULL}, {"menu-startup", &menu_startup, CONF_TYPE_FLAG, CONF_GLOBAL, 0, 1, NULL}, {"menu-keepdir", &menu_keepdir, CONF_TYPE_FLAG, CONF_GLOBAL, 0, 1, NULL}, + {"menu-chroot", &menu_chroot, CONF_TYPE_STRING, 0, 0, 0, NULL}, #ifdef USE_FRIBIDI {"menu-fribidi-charset", &menu_fribidi_charset, CONF_TYPE_STRING, 0, 0, 0, NULL}, {"menu-flip-hebrew", &menu_flip_hebrew, CONF_TYPE_FLAG, 0, 0, 1, NULL}, diff -r e80337bdc886 -r 9bf57f60bf0a libmenu/menu_filesel.c --- a/libmenu/menu_filesel.c Tue May 29 16:14:52 2007 +0000 +++ b/libmenu/menu_filesel.c Tue May 29 18:49:38 2007 +0000 @@ -30,6 +30,7 @@ #define MENU_KEEP_PATH "/tmp/mp_current_path" int menu_keepdir = 0; +char *menu_chroot = NULL; struct list_entry_s { struct list_entry p; @@ -222,6 +223,12 @@ while ((dp = readdir(dirp)) != NULL) { if(dp->d_name[0] == '.' && strcmp(dp->d_name,"..") != 0) continue; + if (menu_chroot && !strcmp (dp->d_name,"..")) { + int len = strlen (menu_chroot); + if ((strlen (mpriv->dir) == len || strlen (mpriv->dir) == len + 1) + && !strncmp (mpriv->dir, menu_chroot, len)) + continue; + } mylstat(args,dp->d_name,&st); if (file_filter && extensions && !S_ISDIR(st.st_mode)) { if((ext = strrchr(dp->d_name,'.')) == NULL)