Update the buildsystem for KConfig finding Qt

The buildsystem will now only search for Qt 4 and Qt 5. Support for Qt 2
and 3 was dropped in the previous commits (Qt 3 was EOL'ed in 2010 or
so...).

For Qt 5, to be future-proof with the future direction notice appearing
in the 5.5 release, C++11 support is automatically enabled.

Signed-off-by: Thiago Macieira <thiago.macieira@intel.com>
Signed-off-by: Michal Marek <mmarek@suse.com>
This commit is contained in:
Thiago Macieira 2015-09-22 11:36:39 -07:00 committed by Michal Marek
parent b4ff1de3b8
commit d1b0dc90ab

View File

@ -226,53 +226,36 @@ $(obj)/.tmp_qtcheck: $(src)/Makefile
# Qt needs some extra effort... # Qt needs some extra effort...
$(obj)/.tmp_qtcheck: $(obj)/.tmp_qtcheck:
@set -e; $(kecho) " CHECK qt"; dir=""; pkg=""; \ @set -e; $(kecho) " CHECK qt"; \
if ! pkg-config --exists QtCore 2> /dev/null; then \ qtver=`qmake -query QT_VERSION` || { \
echo "* Unable to find the Qt4 tool qmake. Trying to use Qt3"; \ echo >&2 "*"; \
pkg-config --exists qt 2> /dev/null && pkg=qt; \ echo >&2 "* qmake failed."; \
pkg-config --exists qt-mt 2> /dev/null && pkg=qt-mt; \ echo >&2 "*"; \
if [ -n "$$pkg" ]; then \ exit 1; \
cflags="\$$(shell pkg-config $$pkg --cflags)"; \ }; \
libs="\$$(shell pkg-config $$pkg --libs)"; \ qtlibdir=`qmake -query QT_INSTALL_LIBS`; \
moc="\$$(shell pkg-config $$pkg --variable=prefix)/bin/moc"; \ qthdrdir=`qmake -query QT_INSTALL_HEADERS`; \
dir="$$(pkg-config $$pkg --variable=prefix)"; \ qtbindir=`qmake -query QT_INSTALL_BINS`; \
else \ cflags="-I$$qthdrdir -I$$qthdrdir/QtCore -I$$qthdrdir/QtGui"; \
for d in $$QTDIR /usr/share/qt* /usr/lib/qt*; do \ case "$$qtver" in \
if [ -f $$d/include/qconfig.h ]; then dir=$$d; break; fi; \ 5.*) \
done; \ cflags="$$cflags -I$$qthdrdir/QtWidgets -std=c++11 -fPIC"; \
if [ -z "$$dir" ]; then \ libs="-L$$qtlibdir -lQt5Widgets -lQt5Gui -lQt5Core "; \
echo >&2 "*"; \ ;; \
echo >&2 "* Unable to find any Qt installation. Please make sure that"; \ 4.*) \
echo >&2 "* the Qt4 or Qt3 development package is correctly installed and"; \ libs="-L$$qtlibdir -lQtGui -lQtCore"; \
echo >&2 "* either qmake can be found or install pkg-config or set"; \ ;; \
echo >&2 "* the QTDIR environment variable to the correct location."; \ *) \
echo >&2 "*"; \ echo >&2 "*"; \
false; \ echo >&2 "* Found qmake but it is for Qt version $$qtver, which is not supported."; \
fi; \ echo >&2 "* Please install either Qt 4.8 or 5.x."; \
libpath=$$dir/lib; lib=qt; osdir=""; \ echo >&2 "*"; \
$(HOSTCXX) -print-multi-os-directory > /dev/null 2>&1 && \ exit 1; \
osdir=x$$($(HOSTCXX) -print-multi-os-directory); \ ;; \
test -d $$libpath/$$osdir && libpath=$$libpath/$$osdir; \ esac; \
test -f $$libpath/libqt-mt.so && lib=qt-mt; \
cflags="-I$$dir/include"; \
libs="-L$$libpath -Wl,-rpath,$$libpath -l$$lib"; \
moc="$$dir/bin/moc"; \
fi; \
if [ ! -x $$dir/bin/moc -a -x /usr/bin/moc ]; then \
echo "*"; \
echo "* Unable to find $$dir/bin/moc, using /usr/bin/moc instead."; \
echo "*"; \
moc="/usr/bin/moc"; \
fi; \
else \
cflags="\$$(shell pkg-config QtCore QtGui --cflags)"; \
libs="\$$(shell pkg-config QtCore QtGui --libs)"; \
moc="\$$(shell pkg-config QtCore --variable=moc_location)"; \
[ -n "$$moc" ] || moc="\$$(shell pkg-config QtCore --variable=prefix)/bin/moc"; \
fi; \
echo "KC_QT_CFLAGS=$$cflags" > $@; \ echo "KC_QT_CFLAGS=$$cflags" > $@; \
echo "KC_QT_LIBS=$$libs" >> $@; \ echo "KC_QT_LIBS=$$libs" >> $@; \
echo "KC_QT_MOC=$$moc" >> $@ echo "KC_QT_MOC=$$qtbindir/moc" >> $@
endif endif
$(obj)/gconf.o: $(obj)/.tmp_gtkcheck $(obj)/gconf.o: $(obj)/.tmp_gtkcheck