mirror of https://github.com/odrling/Aegisub
Use EnumFontFamiliesEx to try to find the correct match when fontconfig gives several options
Fixes collection of ITC Cheltenham, ITC Tiffany, Zurich, Delicious, Jacoby, Segoe WP, Agilita LT, and a bunch of dumb improperly modified fonts I have lying around. Closes #1806.
This commit is contained in:
parent
580386b229
commit
54a7d43cf1
|
@ -16,6 +16,7 @@
|
||||||
|
|
||||||
#include "font_file_lister.h"
|
#include "font_file_lister.h"
|
||||||
|
|
||||||
|
#include <libaegisub/charset_conv_win.h>
|
||||||
#include <libaegisub/log.h>
|
#include <libaegisub/log.h>
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
|
@ -113,6 +114,38 @@ CollectionResult FontConfigFontFileLister::GetFontPaths(std::string const& facen
|
||||||
|
|
||||||
auto match = matches->fonts[0];
|
auto match = matches->fonts[0];
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
wxMemoryDC dc;
|
||||||
|
// Use EnumFontFamiliesEx to verify the match, as fontconfig sometimes gives
|
||||||
|
// us some incorrect matches along with the correct one
|
||||||
|
for (FcPattern *pat : boost::make_iterator_range(&matches->fonts[0], &matches->fonts[matches->nfont])) {
|
||||||
|
FcChar8 *fullname;
|
||||||
|
if (FcPatternGetString(pat, FC_FULLNAME, 0, &fullname) != FcResultMatch)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
LOGFONT lf = {0};
|
||||||
|
lf.lfCharSet = DEFAULT_CHARSET;
|
||||||
|
wcsncpy(lf.lfFaceName, agi::charset::ConvertW((const char *)fullname).c_str(), 31);
|
||||||
|
|
||||||
|
auto cb = [&](const LOGFONT *lf) {
|
||||||
|
auto face = agi::charset::ConvertW(lf->lfFaceName);
|
||||||
|
boost::to_lower(face);
|
||||||
|
return face == family;
|
||||||
|
};
|
||||||
|
|
||||||
|
using type = decltype(cb);
|
||||||
|
bool found = !EnumFontFamiliesEx(dc.GetHDC(), &lf,
|
||||||
|
[](const LOGFONT *lf, const TEXTMETRIC *, DWORD, LPARAM lParam) -> int {
|
||||||
|
return !(*reinterpret_cast<type*>(lParam))(lf);
|
||||||
|
}, (LPARAM)&cb, 0);
|
||||||
|
|
||||||
|
if (found) {
|
||||||
|
match = pat;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
FcChar8 *file;
|
FcChar8 *file;
|
||||||
if(FcPatternGetString(match, FC_FILE, 0, &file) != FcResultMatch)
|
if(FcPatternGetString(match, FC_FILE, 0, &file) != FcResultMatch)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in New Issue