/*
* The ManaPlus Client
* Copyright (C) 2017 The ManaPlus Developers
*
* This file is part of The ManaPlus Client.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "utils/dumplibs.h"
#include "logger.h"
#include "utils/stringutils.h"
#include <png.h>
#include <SDL_image.h>
#include <SDL_mixer.h>
PRAGMACLANG6(GCC diagnostic push)
PRAGMACLANG6(GCC diagnostic ignored "-Wold-style-cast")
#include <SDL_net.h>
PRAGMACLANG6(GCC diagnostic pop)
#include <SDL_ttf.h>
PRAGMA45(GCC diagnostic push)
PRAGMA45(GCC diagnostic ignored "-Wlong-long")
#include <physfs.h>
PRAGMA45(GCC diagnostic pop)
#include <zlib.h>
#include <curl/curl.h>
#ifdef ENABLE_LIBXML
#include <libxml/xmlversion.h>
#endif // ENABLE_LIBXML
#include "debug.h"
#define dumpCompiledSdlVersion(text, prefix) \
logger->log(" " text ": %d.%d.%d", \
prefix##_MAJOR_VERSION, \
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)
{
if (version)
{
logger->log(" %s: %d.%d.%d",
text,
version->major,
version->minor,
version->patch);
}
}
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:");
logger->log(" zLib: %s", ZLIB_VERSION);
#ifdef ENABLE_LIBXML
logger->log(" libxml2: %s", LIBXML_DOTTED_VERSION);
#endif // ENABLE_LIBXML
logger->log(" libcurl: %s", LIBCURL_VERSION);
logger->log(" libpng: %s", PNG_LIBPNG_VER_STRING);
#ifdef USE_PHYSFS
PHYSFS_Version physfsVersion;
PHYSFS_VERSION(&physfsVersion);
const std::string physfsCompiled = strprintf("%d.%d.%d",
physfsVersion.major,
physfsVersion.minor,
physfsVersion.patch);
logger->log(" libphysfs: %s", physfsCompiled.c_str());
#endif // USE_PHYSFS
dumpCompiledSdlVersion("SDL", SDL);
dumpCompiledSdlVersion("SDL_net", SDL_NET);
dumpCompiledSdlVersion("SDL_image", SDL_IMAGE);
dumpCompiledSdlVersion("SDL_mixer", SDL_MIXER);
dumpCompiledSdlVersion("SDL_ttf", SDL_TTF);
logger->log("Linked with:");
#if ZLIB_VERNUM >= 0x1020
logger->log(" zLib: %s", zlibVersion());
#endif // ZLIB_VERNUM >= 0x1020
#ifdef USE_PHYSFS
PHYSFS_getLinkedVersion(&physfsVersion);
const std::string physfsLinked = strprintf("%d.%d.%d",
physfsVersion.major,
physfsVersion.minor,
physfsVersion.patch);
logger->log(" libphysfs: %s", physfsLinked.c_str());
#endif // USE_PHYSFS
#ifdef LIBXML_TEST_VERSION
LIBXML_TEST_VERSION
#endif // LIBXML_TEST_VERSION
#ifdef USE_SDL2
SDL_version sdlVersion;
sdlVersion.major = 0;
sdlVersion.minor = 0;
sdlVersion.patch = 0;
SDL_GetVersion(&sdlVersion);
dumpLinkedSdlVersion("SDL", &sdlVersion);
#else // USE_SDL2
dumpLinkedSdlVersion("SDL", SDL_Linked_Version());
#endif // USE_SDL2
dumpLinkedSdlVersion("SDL_net", SDLNet_Linked_Version());
dumpLinkedSdlVersion("SDL_image", IMG_Linked_Version());
dumpLinkedSdlVersion("SDL_mixer", Mix_Linked_Version());
dumpLinkedSdlVersion("SDL_ttf", TTF_Linked_Version());
compareVersions("zLib", ZLIB_VERSION, zlibVersion());
#ifdef USE_PHYSFS
compareVersions("libphysfs", physfsCompiled.c_str(), physfsLinked.c_str());
#endif // USE_PHYSFS
#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_mixer",
sdlVersionJoin(SDL_MIXER),
Mix_Linked_Version());
compareSDLVersions("SDL_ttf",
sdlVersionJoin(SDL_TTF),
TTF_Linked_Version());
}