Mercurial > mplayer.hg
changeset 9983:14c92818ab75
alternative timer and glob emulation code for mingw32 port
author | faust3 |
---|---|
date | Fri, 25 Apr 2003 10:00:18 +0000 |
parents | cd76f332bdee |
children | 84b64dece730 |
files | osdep/Makefile osdep/getch2-win.c osdep/glob-win.c osdep/glob.h osdep/timer-win2.c |
diffstat | 5 files changed, 145 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/osdep/Makefile Fri Apr 25 00:57:04 2003 +0000 +++ b/osdep/Makefile Fri Apr 25 10:00:18 2003 +0000 @@ -17,11 +17,12 @@ timer = timer-macosx.c endif ifeq ($(TARGET_CYGWIN),yes) -timer = timer-win.c +timer = timer-win2.c endif ifeq ($(TARGET_MINGW32),yes) -timer = timer-win.c +timer = timer-win2.c getch = getch2-win.c +SRCS += glob-win.c endif SRCS += $(timer) SRCS += $(getch)
--- a/osdep/getch2-win.c Fri Apr 25 00:57:04 2003 +0000 +++ b/osdep/getch2-win.c Fri Apr 25 10:00:18 2003 +0000 @@ -99,7 +99,7 @@ void getch2_enable(){ - int retval; + DWORD retval; stdin = GetStdHandle(STD_INPUT_HANDLE); if(!GetNumberOfConsoleInputEvents(stdin,&retval)) {
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/osdep/glob-win.c Fri Apr 25 10:00:18 2003 +0000 @@ -0,0 +1,91 @@ +#include <sys/types.h> +#include <stdio.h> + +#include "../config.h" + +#ifndef HAVE_GLOB +#ifdef __MINGW32__ +#undef DATADIR +#include <windows.h> +#include "glob.h" + +int glob(const char *pattern, int flags, + int (*errfunc)(const char *epath, int eerrno), glob_t *pglob) +{ + HANDLE searchhndl; + WIN32_FIND_DATA found_file; + if(errfunc)printf("glob():ERROR:Sorry errfunc not supported by this implementation\n"); + if(flags)printf("glob():ERROR:Sorry no flags supported by this globimplementation\n"); + //printf("PATTERN \"%s\"\n",pattern); + pglob->gl_pathc = 0; + searchhndl = FindFirstFile( pattern,&found_file); + if(searchhndl == INVALID_HANDLE_VALUE) + { + if(GetLastError() == ERROR_FILE_NOT_FOUND) + { + pglob->gl_pathc = 0; + //printf("could not find a file matching your search criteria\n"); + return 1; + } + else + { + //printf("glob():ERROR:FindFirstFile: %i\n",GetLastError()); + return 1; + } + } + pglob->gl_pathv = malloc(sizeof(char*)); + pglob->gl_pathv[0] = strdup(found_file.cFileName); + pglob->gl_pathc++; + while(1) + { + if(!FindNextFile(searchhndl,&found_file)) + { + if(GetLastError()==ERROR_NO_MORE_FILES) + { + //printf("glob(): no more files found\n"); + break; + } + else + { + //printf("glob():ERROR:FindNextFile:%i\n",GetLastError()); + return 1; + } + } + else + { + //printf("glob: found file %s\n",found_file.cFileName); + pglob->gl_pathc++; + pglob->gl_pathv = realloc(pglob->gl_pathv,pglob->gl_pathc * sizeof(char*)); + pglob->gl_pathv[pglob->gl_pathc-1] = strdup(found_file.cFileName); + } + } + FindClose(searchhndl); + return 0; +} + +void globfree(glob_t *pglob) +{ + int i; + for(i=0; i <pglob->gl_pathc ;i++) + { + free(pglob->gl_pathv[i]); + } + free(pglob->gl_pathv); +} +#endif /*__MINGW32__*/ +#endif /*HAVE_GLOB*/ + +#if 0 +int main(){ + glob_t gg; + printf("globtest\n"); + glob( "*.jpeg",0,NULL,&gg ); + { + int i; + for(i=0;i<gg.gl_pathc;i++)printf("GLOBED:%i %s\n",i,gg.gl_pathv[i]); + } + globfree(&gg); + + return 0; +} +#endif
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/osdep/glob.h Fri Apr 25 10:00:18 2003 +0000 @@ -0,0 +1,16 @@ +#include "../config.h" + +#ifndef HAVE_GLOB +#ifdef __MINGW32__ +typedef struct { + size_t gl_pathc; + char **gl_pathv; + size_t gl_offs; +} glob_t; + +void globfree(glob_t *pglob); + +int glob(const char *pattern, int flags, int (*errfunc)(const char *epath, int eerrno), glob_t *pglob); + +#endif +#endif
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/osdep/timer-win2.c Fri Apr 25 10:00:18 2003 +0000 @@ -0,0 +1,34 @@ +// Precise timer routines for WINDOWS + +#include <windows.h> +#include <mmsystem.h> +#include "timer.h" + +// Returns current time in microseconds +unsigned int GetTimer(){ + return timeGetTime() * 1000; +} + +// Returns current time in milliseconds +unsigned int GetTimerMS(){ + return timeGetTime() ; +} + +int usec_sleep(int usec_delay){ + Sleep( usec_delay/1000); + return 0; +} + +static DWORD RelativeTime = 0; + +float GetRelativeTime(){ + DWORD t, r; + t = GetTimer(); + r = t - RelativeTime; + RelativeTime = t; + return (float) r *0.000001F; +} + +void InitTimer(){ + GetRelativeTime(); +}