summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2017-01-30 17:51:57 +0300
committerAndrei Karas <akaras@inbox.ru>2017-01-30 17:51:57 +0300
commit6fa245a1cb5037118ba19a084f219abcc00f6294 (patch)
treeac2daa86b99e9feae67ab72ebc5f60559552d6fa
parent24723fcdc94820daf50ee53ae1979b12caf05f8c (diff)
downloadmv-6fa245a1cb5037118ba19a084f219abcc00f6294.tar.gz
mv-6fa245a1cb5037118ba19a084f219abcc00f6294.tar.bz2
mv-6fa245a1cb5037118ba19a084f219abcc00f6294.tar.xz
mv-6fa245a1cb5037118ba19a084f219abcc00f6294.zip
Add checks for compiler and linked libs in dumplibs.
-rw-r--r--src/utils/dumplibs.cpp69
1 files changed, 67 insertions, 2 deletions
diff --git a/src/utils/dumplibs.cpp b/src/utils/dumplibs.cpp
index 915e46e3d..a81d056a0 100644
--- a/src/utils/dumplibs.cpp
+++ b/src/utils/dumplibs.cpp
@@ -22,6 +22,8 @@
#include "logger.h"
+#include "utils/stringutils.h"
+
#include <png.h>
#include <SDL_image.h>
PRAGMACLANG6(GCC diagnostic push)
@@ -44,6 +46,11 @@ PRAGMACLANG6(GCC diagnostic pop)
prefix##_MINOR_VERSION, \
prefix##_PATCHLEVEL)
+#define sdlVersionJoin(prefix) \
+ prefix##_MAJOR_VERSION, \
+ prefix##_MINOR_VERSION, \
+ prefix##_PATCHLEVEL
+
static void dumpLinkedSdlVersion(const char *const text,
const SDL_version *const version)
{
@@ -57,6 +64,44 @@ static void dumpLinkedSdlVersion(const char *const text,
}
}
+static void compareVersions(const char *const libName,
+ const char *const buildVersion,
+ const char *const linkedVersion)
+{
+ if (strcmp(buildVersion, linkedVersion) != 0)
+ {
+ logger->assertLog(
+ "%s: compiled and linked versions not same: %s vs %s",
+ libName,
+ buildVersion,
+ linkedVersion);
+ }
+}
+
+static void compareSDLVersions(const char *const libName,
+ const int major,
+ const int minor,
+ const int patch,
+ const SDL_version *const linkedVersion)
+{
+ const std::string buildVersionStr = strprintf("%d.%d.%d",
+ major,
+ minor,
+ patch);
+ const std::string linkedVersionStr = strprintf("%d.%d.%d",
+ linkedVersion->major,
+ linkedVersion->minor,
+ linkedVersion->patch);
+ if (buildVersionStr != linkedVersionStr)
+ {
+ logger->assertLog(
+ "%s: compiled and linked versions not same: %s vs %s",
+ libName,
+ buildVersionStr.c_str(),
+ linkedVersionStr.c_str());
+ }
+}
+
void dumpLibs()
{
logger->log("Compiled with:");
@@ -66,10 +111,11 @@ void dumpLibs()
logger->log(" libpng: %s", PNG_LIBPNG_VER_STRING);
PHYSFS_Version physfsVersion;
PHYSFS_VERSION(&physfsVersion);
- logger->log(" libphysfs: %d.%d.%d",
+ const std::string physfsCompiled = strprintf("%d.%d.%d",
physfsVersion.major,
physfsVersion.minor,
physfsVersion.patch);
+ logger->log(" libphysfs: %s", physfsCompiled.c_str());
dumpCompiledSdlVersion("SDL", SDL);
dumpCompiledSdlVersion("SDL_net", SDL_NET);
dumpCompiledSdlVersion("SDL_image", SDL_IMAGE);
@@ -80,10 +126,11 @@ void dumpLibs()
logger->log(" zLib: %s", zlibVersion());
#endif // ZLIB_VERNUM >= 0x1020
PHYSFS_getLinkedVersion(&physfsVersion);
- logger->log(" libphysfs: %d.%d.%d",
+ const std::string physfsLinked = strprintf("%d.%d.%d",
physfsVersion.major,
physfsVersion.minor,
physfsVersion.patch);
+ logger->log(" libphysfs: %s", physfsLinked.c_str());
#ifdef LIBXML_TEST_VERSION
LIBXML_TEST_VERSION
#endif // LIBXML_TEST_VERSION
@@ -100,4 +147,22 @@ void dumpLibs()
dumpLinkedSdlVersion("SDL_net", SDLNet_Linked_Version());
dumpLinkedSdlVersion("SDL_image", IMG_Linked_Version());
dumpLinkedSdlVersion("SDL_ttf", TTF_Linked_Version());
+
+ compareVersions("zLib", ZLIB_VERSION, zlibVersion());
+ compareVersions("libphysfs", physfsCompiled.c_str(), physfsLinked.c_str());
+#ifdef USE_SDL2
+ compareSDLVersions("SDL", sdlVersionJoin(SDL), sdlVersion);
+#else // USE_SDL2
+ compareSDLVersions("SDL", sdlVersionJoin(SDL), SDL_Linked_Version());
+#endif // USE_SDL2
+
+ compareSDLVersions("SDL_net",
+ sdlVersionJoin(SDL_NET),
+ SDLNet_Linked_Version());
+ compareSDLVersions("SDL_image",
+ sdlVersionJoin(SDL_IMAGE),
+ IMG_Linked_Version());
+ compareSDLVersions("SDL_ttf",
+ sdlVersionJoin(SDL_TTF),
+ TTF_Linked_Version());
}