diff options
author | Steve Wills <swills@FreeBSD.org> | 2019-06-03 16:01:49 +0000 |
---|---|---|
committer | Steve Wills <swills@FreeBSD.org> | 2019-06-03 16:01:49 +0000 |
commit | 33260ec98a8a176cea52edb7b67fbdd93ff088a3 (patch) | |
tree | 7ca721738feb9ed717f60b6ffd58b5cd32125bcb /java | |
parent | java/openjdk6: fix build with freetype2 2.10.0 (diff) |
java/openjdk7: fix build with freetype2 2.10.0
PR: 238225
Notes
Notes:
svn path=/head/; revision=503400
Diffstat (limited to 'java')
-rw-r--r-- | java/openjdk7/files/patch-jdk_make_tools_freetypecheck_freetypecheck.c | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/java/openjdk7/files/patch-jdk_make_tools_freetypecheck_freetypecheck.c b/java/openjdk7/files/patch-jdk_make_tools_freetypecheck_freetypecheck.c new file mode 100644 index 000000000000..6b9453bdc746 --- /dev/null +++ b/java/openjdk7/files/patch-jdk_make_tools_freetypecheck_freetypecheck.c @@ -0,0 +1,78 @@ +--- ./jdk/make/tools/freetypecheck/freetypecheck.c.orig 2013-09-06 14:27:43.000000000 -0400 ++++ ./jdk/make/tools/freetypecheck/freetypecheck.c 2019-05-29 18:16:30.696642000 -0400 +@@ -74,26 +74,65 @@ + #define QUOTEMACRO(x) QUOTEME(x) + #define QUOTEME(x) #x + ++int compare_versions(FT_Int req_major, FT_Int req_minor, FT_Int req_patch, ++ FT_Int major, FT_Int minor, FT_Int patch) { ++ if (major > req_major) { ++ printf("Major version %d greater than required major version %d\n", ++ major, req_major); ++ return 0; ++ } ++ if (major < req_major) { ++ printf("Major version %d less than required major version %d\n", ++ major, req_major); ++ return -1; ++ } ++ printf("Major version %d equal to required major version %d\n", ++ major, req_major); ++ if (minor > req_minor) { ++ printf("Minor version %d greater than required minor version %d\n", ++ minor, req_minor); ++ return 0; ++ } ++ if (minor < req_minor) { ++ printf("Minor version %d less than required minor version %d\n", ++ minor, req_minor); ++ return -2; ++ } ++ printf("Minor version %d equal to required minor version %d\n", ++ minor, req_minor); ++ if (patch >= req_patch) { ++ printf("Patch version %d greater than or equal to required patch version %d\n", ++ patch, req_patch); ++ return 0; ++ } ++ printf("Patch version %d less than required patch version %d\n", ++ patch, req_patch); ++ return -3; ++} ++ + int main(int argc, char** argv) { +- char v[50]; +- FT_Int major, minor, patch; ++ FT_Int major, minor, patch, req_major, req_minor, req_patch; + FT_Library library; +- sprintf(v, "%d.%d.%d", FREETYPE_MAJOR, FREETYPE_MINOR, FREETYPE_PATCH); + +- printf("Required version of freetype: %s\n", +- QUOTEMACRO(REQUIRED_FREETYPE_VERSION)); ++ sscanf(QUOTEMACRO(REQUIRED_FREETYPE_VERSION), ++ "%d.%d.%d", &req_major, &req_minor, &req_patch); ++ printf("Required version of freetype: %d.%d.%d\n", ++ req_major, req_minor, req_patch); + +- printf("Detected freetype headers: %s\n", v); +- if (strcmp(v, QUOTEMACRO(REQUIRED_FREETYPE_VERSION)) < 0) { ++ printf("Detected freetype headers: %d.%d.%d\n", ++ FREETYPE_MAJOR, FREETYPE_MINOR, FREETYPE_PATCH); ++ if (compare_versions(req_major, req_minor, req_patch, ++ FREETYPE_MAJOR, FREETYPE_MINOR, FREETYPE_PATCH) < 0) { + printf("Failed: headers are too old.\n"); + } + + FT_Init_FreeType(&library); + FT_Library_Version(library, &major, &minor, &patch); +- sprintf(v, "%d.%d.%d", major, minor, patch); + +- printf("Detected freetype library: %s\n", v); +- if (strcmp(v, QUOTEMACRO(REQUIRED_FREETYPE_VERSION)) < 0) { ++ printf("Detected freetype library: %d.%d.%d\n", ++ major, minor, patch); ++ if (compare_versions(req_major, req_minor, req_patch, ++ major, minor, patch) < 0) { + printf("Failed: too old library.\n"); + } + |