1
0
mirror of https://github.com/mpv-player/mpv synced 2024-12-19 05:15:12 +00:00

using expLoadLibraryA instead of LoadLibraryA

git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@343 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
arpi_esp 2001-04-11 02:11:39 +00:00
parent 9f33c6e1bc
commit 7b946afcf6
2 changed files with 9 additions and 7 deletions

View File

@ -11,7 +11,8 @@ using namespace std;
typedef long STDCALL (*GETCLASS) (const GUID*, const GUID*, void**);
extern "C" char* def_path;
extern "C" int STDCALL LoadLibraryA(const char*);
extern "C" int STDCALL expLoadLibraryA(const char*);
//extern "C" int WINAPI expLoadLibraryA(char* name);
extern "C" STDCALL void* GetProcAddress(int, const char*);
extern "C" int STDCALL FreeLibrary(int);
@ -26,17 +27,18 @@ DS_Filter::DS_Filter()
{
}
void DS_Filter::Create(string dllname, const GUID* id, AM_MEDIA_TYPE* in_fmt, AM_MEDIA_TYPE* out_fmt)
void DS_Filter::Create(char* dllname, const GUID* id, AM_MEDIA_TYPE* in_fmt, AM_MEDIA_TYPE* out_fmt)
{
Setup_LDT_Keeper();
try
{
string _fullname=def_path;
_fullname+="/";
_fullname+=dllname;
m_iHandle= LoadLibraryA(_fullname.c_str());
// string _fullname=def_path;
// _fullname+="/";
// _fullname+=dllname;
// m_iHandle= LoadLibraryA(_fullname.c_str());
m_iHandle= expLoadLibraryA(dllname);
if(!m_iHandle)throw FATAL("Could not open DLL");
GETCLASS func=(GETCLASS)GetProcAddress(m_iHandle, "DllGetClassObject");
if(!func)throw FATAL("Illegal or corrupt DLL");

View File

@ -16,7 +16,7 @@ protected:
public:
DS_Filter();
virtual ~DS_Filter();
void Create(string dllname, const GUID* id, AM_MEDIA_TYPE* in_fmt, AM_MEDIA_TYPE* out_fmt);
void Create(char* dllname, const GUID* id, AM_MEDIA_TYPE* in_fmt, AM_MEDIA_TYPE* out_fmt);
void Start();
void Stop();
int m_iHandle;