Я получаю эту ошибку, когда пытаюсь построить проект gwmeta:
Build started 20.03.2020 10:54:54.
1>Project "C:\Users\Yil\Desktop\EP2000\Rel19-x64\gwmeta\gwmeta.vcxproj" on node 2 (Build target(s)).
1>Link:
C:\Program Files (x86)\Microsoft Visual Studio 11.0\VC\bin\x86_amd64\link.exe /ERRORREPORT:PROMPT /OUT:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.dll" /INCREMENTAL /NOLOGO /LIBPATH:"C:\Program Files (x86)\Visual Leak Detector\lib\Win32" kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /MANIFEST /MANIFESTUAC:"level='asInvoker' uiAccess='false'" /manifest:embed /DEBUG /PDB:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.pdb" /SUBSYSTEM:WINDOWS /TLBID:1 /DYNAMICBASE /NXCOMPAT /IMPLIB:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.lib" /MACHINE:X64 /DLL x64\Debug\gwmeta.res
x64\Debug\gwmeta.obj
x64\Debug\winmeta.obj
"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdbase.lib"
"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdcore.lib"
Creating library C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.lib and object C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.exp
1>winmeta.obj : error LNK2019: unresolved external symbol "int __cdecl MetaEnumProc(void *,struct tagHANDLETABLE *,struct tagMETARECORD *,int,__int64)" (?MetaEnumProc@@YAHPEAXPEAUtagHANDLETABLE@@PEAUtagMETARECORD@@H_J@Z) referenced in function "protected: void __cdecl MetaFile::GetMetaFileAndEnum(void *)" (?GetMetaFileAndEnum@MetaFile@@IEAAXPEAX@Z)
1>C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.dll : fatal error LNK1120: 1 unresolved externals
1>Done Building Project "C:\Users\Yil\Desktop\EP2000\Rel19-x64\gwmeta\gwmeta.vcxproj" (Build target(s)) -- FAILED.
Build FAILED.
Time Elapsed 00:00:00.19
А вот ошибка, которая возникает из:
void MetaFile::GetMetaFileAndEnum(HDC hDC)
{
// if there is a valid handle to a metafile begin enumerating it
if (hMF)
{
#ifdef __WIN16__
FARPROC lpprocEnumMF = MakeProcInstance((FARPROC)MetaEnumProc,
GwInstance());
EnumMetaFile(hDC, hMF, (FARPROC)lpprocEnumMF, (LPARAM) this);
FreeProcInstance ((FARPROC) lpprocEnumMF);
#else
if (bEnhanced)
{
RECT r;
GetClientRect (WindowFromDC(hDC),&r);
EnumEnhMetaFile(hDC, hMF, (ENHMFENUMPROC)EnhMetaEnumProc, (LPVOID) this,&r);
}
else
EnumMetaFile(hDC, hMF, static_cast<MFENUMPROC>(MetaEnumProc), (LPARAM) this);
#endif
}
else
{
GwCore::warning (GwERR_METAFILE_FAILED,"GetMetaFile failed");
}
}
Когда я удаляю строку EnumMetaFile(hDC, hMF, static_cast<MFENUMPROC>(MetaEnumProc), (LPARAM) this);
это строит. MetaEnumPro c здесь, по-видимому, является проблемой.
Я заметил еще одну вещь:
Ошибка компоновщика
Путь в красном поле для winmeta .obj не так. winmeta.obj находится в .. \ gwmeta \ x64 \ Debug \ winmeta.obj, а не в .. \ gwmeta \ winmeta.obj
Все мои проекты настроены на x64. Я также перестраивал и очищал свое решение несколько раз. Я работаю над VS2012. Я также пытался собрать его с VS2019, но проблема остается.
Если это помогает, это представление командной строки Linker->:
/OUT:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.dll" /MANIFEST /NXCOMPAT
/PDB:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.pdb" /DYNAMICBASE "kernel32.lib"
"user32.lib" "gdi32.lib" "winspool.lib" "comdlg32.lib" "advapi32.lib" "shell32.lib" "ole32.lib"
"oleaut32.lib" "uuid.lib" "odbc32.lib" "odbccp32.lib" "C:\Users\Yil\Desktop\EP2000\Rel19-
x64\x64\Debug\gdbase.lib" "C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdcore.lib"
/IMPLIB:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.lib" /DEBUG /DLL /MACHINE:X64
/INCREMENTAL /PGD:"C:\Users\Yil\Desktop\EP2000\Rel19-x64\x64\Debug\gdmeta.pgd" /SUBSYSTEM:WINDOWS
/MANIFESTUAC:"level='asInvoker' uiAccess='false'"
/ManifestFile:"x64\Debug\gdmeta.dll.intermediate.manifest" /ERRORREPORT:PROMPT /NOLOGO
/LIBPATH:"C:\Program Files (x86)\Visual Leak Detector\lib\Win32" /TLBID:1
MetaEnumPro c определяется в том же файле, что и приведенный выше код в winmeta.cxx
#ifdef __WIN16__
int FAR PASCAL __export MetaEnumProc(HDC hDC, LPHANDLETABLE lpHTable,
LPMETARECORD lpMFR, int nObj,
BYTE FAR* lpClientData)
#else
int CALLBACK MetaEnumProc(HDC hDC, LPHANDLETABLE lpHTable,
LPMETARECORD lpMFR, int nObj,
LPARAM UNUSED (lpClientData))
#endif
{
if ((lpMFR->rdFunction == 0x0234) &&
(lpMFR->rdParm[0] == 0))
{
lpMFR->rdParm[0] = 1;
}
// Play the record
PlayMetaFileRecord(hDC, lpHTable, lpMFR, (WORD)nObj);
// if we made it this far then continue the enumeration
return(1);
}
До этого он работал в x32, но у программы проблемы с x64.