From cfa30a8b32d474ac2718831804caf5218dc430d3 Mon Sep 17 00:00:00 2001 From: arpi Date: Sat, 28 Dec 2002 13:46:55 +0000 Subject: [PATCH] This patch fixes the reading of the menu.conf, because stream_open() isn't a good idea, it messes with dvd playback. Andreas Hess git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@8605 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmenu/menu.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/libmenu/menu.c b/libmenu/menu.c index d807b0ee03..87898c0b4b 100644 --- a/libmenu/menu.c +++ b/libmenu/menu.c @@ -4,6 +4,8 @@ #include #include #include +#include +#include #include "../libvo/osd.h" #include "../libvo/font_load.h" @@ -115,8 +117,8 @@ int menu_init(char* cfg_file) { char* buffer = NULL; int bl = BUF_STEP, br = 0; int f; - stream_t* stream = open_stream(cfg_file,0,&f); - if(!stream) { + int fd = open(cfg_file, O_RDONLY); + if(fd < 0) { printf("Can't open menu config file: %s\n",cfg_file); return 0; } @@ -126,14 +128,14 @@ int menu_init(char* cfg_file) { if(bl - br < BUF_MIN) { if(bl >= BUF_MAX) { printf("Menu config file is too big (> %d KB)\n",BUF_MAX/1024); - free_stream(stream); + close(fd); free(buffer); return 0; } bl += BUF_STEP; buffer = realloc(buffer,bl); } - r = stream_read(stream,buffer+br,bl-br); + r = read(fd,buffer+br,bl-br); if(r == 0) break; br += r; } @@ -143,6 +145,8 @@ int menu_init(char* cfg_file) { } buffer[br-1] = '\0'; + close(fd); + f = menu_parse_config(buffer); free(buffer); return f;