mirror of
https://github.com/subsurface/subsurface.git
synced 2024-12-01 06:30:26 +00:00
c9f927d547
Marble can't be static, so instead we build a shared library but give it a different name so it can be installed in parallel with the "real" libmarblewidget.so. Also make sure that the correct libusb is installed so that Atomics Aquatics dive computers are supported. Fixes #782 Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
195 lines
5.9 KiB
Text
195 lines
5.9 KiB
Text
#
|
|
# Global settings
|
|
#
|
|
# Set some C constructs to be diagnosed as errors:
|
|
# - calling implicit functions
|
|
# - casting from integers to pointers or vice-versa without an explicit cast
|
|
# Also turn on C99 mode with GNU extensions
|
|
*-g++*: QMAKE_CFLAGS += -Werror=int-to-pointer-cast -Werror=pointer-to-int-cast -Werror=implicit-int
|
|
|
|
# these warnings are in general just wrong and annoying - but should be
|
|
# turned on every once in a while in case they do show the occasional
|
|
# actual bug
|
|
# turns out the gcc 4.2 (as used on MacOS 10.6) doesn't have no-unused-result, yet
|
|
*-clang*: QMAKE_CFLAGS += -Wno-unused-result -Wno-pointer-sign -fno-strict-overflow
|
|
*-g++*: {
|
|
system( g++ --version | grep -e "4\\.2\\." > /dev/null ) {
|
|
QMAKE_CFLAGS += -Wno-pointer-sign -fno-strict-overflow
|
|
} else {
|
|
QMAKE_CFLAGS += -Wno-unused-result -Wno-pointer-sign -fno-strict-overflow
|
|
}
|
|
}
|
|
|
|
*-clang*: QMAKE_CFLAGS += -Wno-format-security
|
|
*-g++*: QMAKE_CXXFLAGS += -fno-strict-overflow
|
|
!win32: !mac: {
|
|
*-g++*: QMAKE_CXXFLAGS += -Wno-maybe-uninitialized
|
|
*-g++*: QMAKE_CFLAGS += -Wno-maybe-uninitialized
|
|
}
|
|
mac: QMAKE_CLAGS += -mmacosx-version-min=10.5
|
|
mac: QMAKE_CXXLAGS += -mmacosx-version-min=10.5
|
|
|
|
|
|
!win32-msvc*: QMAKE_CFLAGS += -std=gnu99
|
|
|
|
# Don't turn warnings on (but don't suppress them either)
|
|
CONFIG -= warn_on warn_off
|
|
|
|
# Turn exceptions off
|
|
!win32-msvc*: QMAKE_CXXFLAGS += -fno-exceptions
|
|
CONFIG += exceptions_off
|
|
|
|
# Check if we have pkg-config
|
|
isEmpty(PKG_CONFIG):PKG_CONFIG=pkg-config
|
|
equals($$QMAKE_HOST.os, "Windows"):NUL=NUL
|
|
else:NUL=/dev/null
|
|
PKG_CONFIG_OUT = $$system($$PKG_CONFIG --version 2> $$NUL)
|
|
!isEmpty(PKG_CONFIG_OUT) {
|
|
CONFIG += link_pkgconfig
|
|
} else {
|
|
message("pkg-config not found, no detection performed. See README for details")
|
|
}
|
|
|
|
#
|
|
# Find libdivecomputer
|
|
#
|
|
equals(LIBDCDEVEL, "1") {
|
|
# find it next to our sources
|
|
INCLUDEPATH += ../libdivecomputer/include $$OUT_PWD/../libdivecomputer/include
|
|
LIBS += ../libdivecomputer/src/.libs/libdivecomputer.a
|
|
LIBDC_LA = ../libdivecomputer/src/libdivecomputer.la
|
|
} else:!isEmpty(LIBDCDEVEL) {
|
|
# find it next to our sources
|
|
INCLUDEPATH += $$LIBDCDEVEL/include $$OUT_PWD/$$LIBDCDEVEL/include
|
|
LIBS += $$LIBDCDEVEL/src/.libs/libdivecomputer.a
|
|
LIBDC_LA = $$LIBDCDEVEL/src/libdivecomputer.la
|
|
} else:!isEmpty(CROSS_PATH):exists($${CROSS_PATH}"/lib/libdivecomputer.a"):exists($${CROSS_PATH}"/lib/libusb-1.0.a") {
|
|
LIBS += $${CROSS_PATH}"/lib/libdivecomputer.a" $${CROSS_PATH}"/lib/libusb-1.0.a"
|
|
} else:exists(/usr/local/lib/libdivecomputer.a) {
|
|
LIBS += /usr/local/lib/libdivecomputer.a
|
|
LIBDC_LA = /usr/local/lib/libdivecomputer.la
|
|
} else:exists(/usr/local/lib64/libdivecomputer.a) {
|
|
LIBS += /usr/local/lib64/libdivecomputer.a
|
|
LIBDC_LA = /usr/local/lib64/libdivecomputer.la
|
|
} else:link_pkgconfig {
|
|
# find it via pkg-config, but we need to pass the --static flag,
|
|
# so we can't use the PKGCONFIG variable.
|
|
LIBS += $$system($$PKG_CONFIG --static --libs libdivecomputer)
|
|
LIBDC_CFLAGS = $$system($$PKG_CONFIG --static --cflags libdivecomputer)
|
|
QMAKE_CFLAGS += $$LIBDC_CFLAGS
|
|
QMAKE_CXXFLAGS += $$LIBDC_CFLAGS
|
|
unset(LIBDC_CFLAGS)
|
|
}
|
|
|
|
!isEmpty(LIBDC_LA):exists($$LIBDC_LA) {
|
|
# Source the libtool .la file to get the dependent libs
|
|
LIBS += $$system(". $$LIBDC_LA && echo \$dependency_libs")
|
|
unset(LIBDC_LA)
|
|
}
|
|
|
|
#
|
|
# Find libxml2 and libxslt
|
|
#
|
|
# They come with shell scripts that contain the information we need, so we just
|
|
# run them. They also come with pkg-config files, but those are missing on
|
|
# Mac (where they are part of the XCode-supplied tools).
|
|
#
|
|
link_pkgconfig {
|
|
isEmpty(XML2_CFLAGS)|isEmpty(XML2_LIBS) {
|
|
XML2_CFLAGS = $$system($$PKG_CONFIG --cflags libxml2 2> $$NUL)
|
|
XML2_LIBS = $$system($$PKG_CONFIG --libs libxml2 2> $$NUL)
|
|
}
|
|
isEmpty(XML2_CFLAGS)|isEmpty(XML2_LIBS) {
|
|
XML2_CFLAGS = $$system($$PKG_CONFIG --cflags libxml-2.0 2> $$NUL)
|
|
XML2_LIBS = $$system($$PKG_CONFIG --libs libxml-2.0 2> $$NUL)
|
|
}
|
|
isEmpty(XSLT_CFLAGS)|isEmpty(XSLT_LIBS) {
|
|
XSLT_CFLAGS = $$system($$PKG_CONFIG --cflags libxslt 2> $$NUL)
|
|
XSLT_LIBS = $$system($$PKG_CONFIG --libs libxslt 2> $$NUL)
|
|
}
|
|
}
|
|
isEmpty(XML2_CFLAGS)|isEmpty(XML2_LIBS) {
|
|
XML2_CFLAGS = $$system(xml2-config --cflags 2>$$NUL)
|
|
XML2_LIBS = $$system(xml2-config --libs 2>$$NUL)
|
|
}
|
|
isEmpty(XSLT_CFLAGS)|isEmpty(XSLT_LIBS) {
|
|
XSLT_CFLAGS = $$system(xslt-config --cflags 2>$$NUL)
|
|
XSLT_LIBS = $$system(xslt-config --libs 2>$$NUL)
|
|
}
|
|
isEmpty(XML2_CFLAGS)|isEmpty(XML2_LIBS): \
|
|
error("Could not find libxml2. Did you forget to install it?")
|
|
isEmpty(XSLT_CFLAGS)|isEmpty(XSLT_LIBS): \
|
|
error("Could not find libxslt. Did you forget to install it?")
|
|
|
|
|
|
QMAKE_CFLAGS *= $$XML2_CFLAGS $$XSLT_CFLAGS
|
|
QMAKE_CXXFLAGS *= $$XML2_CFLAGS $$XSLT_CFLAGS
|
|
LIBS *= $$XSLT_LIBS $$XML2_LIBS
|
|
|
|
#
|
|
# Find other pkg-config-based projects
|
|
# We're searching for:
|
|
# libzip
|
|
# sqlite3
|
|
link_pkgconfig: PKGCONFIG += libzip sqlite3
|
|
|
|
isEmpty(LIBGIT2DEVEL) {
|
|
PKGCONFIG += libgit2
|
|
} else {
|
|
INCLUDEPATH += $$LIBGIT2DEVEL/include
|
|
isEmpty(LIBGIT2STATIC) {
|
|
LIBS += -L$$LIBGIT2DEVEL/build -lgit2 -lz -lcrypto
|
|
} else {
|
|
LIBS += $$LIBGIT2DEVEL/build/libgit2.a -Wl,-Bstatic -lz -lssl -lcrypto -Wl,-Bdynamic -ldl
|
|
}
|
|
}
|
|
|
|
# Add libiconv if needed
|
|
link_pkgconfig: packagesExist(libiconv): PKGCONFIG += libiconv
|
|
|
|
# disable things when were on android
|
|
contains(QMAKE_PLATFORM, android): DEFINES += NO_MARBLE NO_USERMANUAL NO_PRINTING
|
|
|
|
#
|
|
# Find libmarble
|
|
#
|
|
!isEmpty(LIBMARBLEDEVEL) {
|
|
# find it next to our sources
|
|
INCLUDEPATH += $$LIBMARBLEDEVEL/include
|
|
LIBS += -L$$LIBMARBLEDEVEL/lib
|
|
}
|
|
!contains(DEFINES, NO_MARBLE) {
|
|
win32: CONFIG(debug, debug|release): LIBS += -lmarblewidgetd
|
|
else: !isEmpty(SPECIAL_MARBLE_PREFIX) {
|
|
LIBS += -L$$LIBMARBLEDEVEL/src/lib/marble -lssrfmarblewidget
|
|
} else {
|
|
LIBS += -lmarblewidget
|
|
}
|
|
}
|
|
|
|
libgit21-api {
|
|
DEFINES += USE_LIBGIT21_API
|
|
}
|
|
|
|
win32: console {
|
|
DEFINES += WIN32_CONSOLE_APP
|
|
}
|
|
#
|
|
# Platform-specific changes
|
|
#
|
|
win32 {
|
|
LIBS += -lwsock32
|
|
DEFINES -= UNICODE
|
|
}
|
|
mac {
|
|
LIBS += -framework CoreServices
|
|
}
|
|
|
|
#
|
|
# misc
|
|
#
|
|
!equals(V, 1): !equals(QMAKE_HOST.os, "Windows"): CONFIG += silent
|
|
MOC_DIR = .moc
|
|
UI_DIR = .uic
|
|
RCC_DIR = .rcc
|
|
OBJECTS_DIR = .obj
|