# HG changeset patch # User alex # Date 1046187576 0 # Node ID 241bba8f60e8c61492a309a59a9efa8335ff82c4 # Parent d64c5617222012a44e34adbb10a767355d09ca82 MACOSX support patch, based on Dan Christiansens work diff -r d64c56172220 -r 241bba8f60e8 libmpcodecs/ad.c --- a/libmpcodecs/ad.c Tue Feb 25 08:22:00 2003 +0000 +++ b/libmpcodecs/ad.c Tue Feb 25 15:39:36 2003 +0000 @@ -67,7 +67,7 @@ #endif &mpcodecs_ad_acm, #endif -#ifdef USE_QTX_CODECS +#if defined(USE_QTX_CODECS) || defined(MACOSX) &mpcodecs_ad_qtaudio, #endif #ifdef HAVE_FAAD diff -r d64c56172220 -r 241bba8f60e8 libmpcodecs/ad_qtaudio.c --- a/libmpcodecs/ad_qtaudio.c Tue Feb 25 08:22:00 2003 +0000 +++ b/libmpcodecs/ad_qtaudio.c Tue Feb 25 15:39:36 2003 +0000 @@ -5,7 +5,7 @@ #include "config.h" -#ifdef USE_QTX_CODECS +#if defined(USE_QTX_CODECS) || defined(MACOSX) #include "ad_internal.h" #include "bswap.h" @@ -14,6 +14,10 @@ #include "ldt_keeper.h" #endif +#ifdef MACOSX +#include +#endif + static ad_info_t info = { "QuickTime Audio Decoder", "qtaudio", @@ -24,6 +28,7 @@ LIBAD_EXTERN(qtaudio) +#ifdef USE_QTX_CODECS typedef struct OpaqueSoundConverter* SoundConverter; typedef unsigned long OSType; typedef unsigned long UnsignedFixed; @@ -150,6 +155,7 @@ printf("loader_init DONE???\n"); return 0; } +#endif /* USE_QTX_CODECS */ static SoundConverter myConverter = NULL; static SoundComponentData InputFormatInfo,OutputFormatInfo; @@ -166,7 +172,11 @@ printf("win32 libquicktime loader (c) Sascha Sommer\n"); +#ifdef MACOSX + EnterMovies(); +#else if(loader_init()) return 0; // failed to load DLL +#endif printf("loader_init DONE!\n"); @@ -258,6 +268,9 @@ // FreeLibrary( qtml_dll ); // qtml_dll = NULL; // printf("qt dll loader uninit done\n"); +#ifdef MACOSX + ExitMovies(); +#endif } static int decode_audio(sh_audio_t *sh,unsigned char *buf,int minlen,int maxlen){ diff -r d64c56172220 -r 241bba8f60e8 libmpcodecs/vd.c --- a/libmpcodecs/vd.c Tue Feb 25 08:22:00 2003 +0000 +++ b/libmpcodecs/vd.c Tue Feb 25 15:39:36 2003 +0000 @@ -118,7 +118,7 @@ &mpcodecs_vd_libdv, #endif &mpcodecs_vd_lcl, -#ifdef USE_QTX_CODECS +#if defined(USE_QTX_CODECS) || defined(MACOSX) &mpcodecs_vd_qtvideo, #endif NULL diff -r d64c56172220 -r 241bba8f60e8 libmpcodecs/vd_qtvideo.c --- a/libmpcodecs/vd_qtvideo.c Tue Feb 25 08:22:00 2003 +0000 +++ b/libmpcodecs/vd_qtvideo.c Tue Feb 25 15:39:36 2003 +0000 @@ -3,7 +3,7 @@ #include "config.h" -#ifdef USE_QTX_CODECS +#if defined(USE_QTX_CODECS) || defined(MACOSX) #include "mp_msg.h" #include "vd_internal.h" @@ -23,13 +23,21 @@ LIBVD_EXTERN(qtvideo) #include "../bswap.h" + +#ifdef MACOSX +#include +#define dump_ImageDescription(x) +#else #include "qtx/qtxsdk/components.h" +#endif +#ifdef USE_QTX_CODECS //#include "wine/windef.h" HMODULE WINAPI LoadLibraryA(LPCSTR); FARPROC WINAPI GetProcAddress(HMODULE,LPCSTR); int WINAPI FreeLibrary(HMODULE); +#endif //static ComponentDescription desc; // for FindNextComponent() static ComponentInstance ci=NULL; // codec handle @@ -46,6 +54,7 @@ //static HINSTANCE qtml_dll; static HMODULE handler; +#ifdef USE_QTX_CODECS static Component (*FindNextComponent)(Component prev,ComponentDescription* desc); static OSErr (*GetComponentInfo)(Component prev,ComponentDescription* desc,Handle h1,Handle h2,Handle h3); static long (*CountComponents)(ComponentDescription* desc); @@ -80,7 +89,7 @@ void *baseAddr, long rowBytes); static OSErr (*NewHandleClear)(Size byteCount); - +#endif // to set/get/query special features/parameters static int control(sh_video_t *sh,int cmd,void* arg,...){ @@ -98,6 +107,10 @@ CodecInfo cinfo; // for ImageCodecGetCodecInfo() ImageSubCodecDecompressCapabilities icap; // for ImageCodecInitialize() +#ifdef MACOSX + EnterMovies(); +#else + #ifdef WIN32_LOADER Setup_LDT_Keeper(); #endif @@ -130,6 +143,7 @@ printf("InitializeQTML returned %i\n",result); // result=EnterMovies(); // printf("EnterMovies->%d\n",result); +#endif /* !MACOSX */ #if 0 memset(&desc,0,sizeof(desc)); @@ -268,6 +282,9 @@ // uninit driver static void uninit(sh_video_t *sh){ +#ifdef MACOSX + ExitMovies(); +#endif } // decode a frame diff -r d64c56172220 -r 241bba8f60e8 libmpdemux/demux_mov.c --- a/libmpdemux/demux_mov.c Tue Feb 25 08:22:00 2003 +0000 +++ b/libmpdemux/demux_mov.c Tue Feb 25 15:39:36 2003 +0000 @@ -36,6 +36,10 @@ #include "../loader/qtx/qtxsdk/components.h" #endif +#ifdef MACOSX +#include +#endif + #ifdef HAVE_ZLIB #include #endif @@ -1000,7 +1004,7 @@ // 82 char[4] atom type // 86 ... atom data -#ifdef USE_QTX_CODECS +#if defined(USE_QTX_CODECS) || defined(MACOSX) { ImageDescription* id=malloc(8+trak->stdata_len); trak->desc=id; id->idSize=8+trak->stdata_len;