Cairo 依赖于 FontConfig。FontConfig 依赖于 Freetype。我已经构建了 FreeType,但是当我尝试构建 FontConfig 时出现链接错误,因为 FreeType 需要 HarfBuzz。
当我尝试构建 Harfbuzz 时,它依赖于 FreeType。因此我们有一个循环依赖。此时生成文件已损坏:当它尝试构建测试时,它们无法链接,因为它们需要来自 Harbuzz 本身的符号。这可以通过在链接行中使用两次 HarfBuzz 来解决。或者通过删除我所做的所有测试。这样就解决了这个问题。
Harfbuzz 有一个名为“helper-cairo.cc”的文件。当我尝试编译它时,它抱怨缺少 FontConfig 头文件,因此显然存在对 FontConfig 的依赖。但是,如果不先构建 HarfBuzz,我就无法构建 FontConfig!
我不知道如何解决这种依赖关系。也许我可以在构建 HarfBuzz 时禁用 Cairo 助手,使用生成的库来构建 FontConfig,然后使用生成的 FontConfig 重新构建 HarfBuzz,然后重新构建 FontConfig?这一切似乎都是一个大麻烦。
我正在使用 MinGW 构建,而 Windows DLL 不喜欢未解析的符号,所以我认为我无法使用共享库来解决这个问题。我不太确定为什么在链接 FontConfig 时需要 HarfBuzz - 也许它正在尝试构建一个 DLL :(
任何想法如何在不丢失重要功能的情况下解决这个问题?