diff options
Diffstat (limited to 'package/qte/qte.mk')
-rw-r--r-- | package/qte/qte.mk | 251 |
1 files changed, 251 insertions, 0 deletions
diff --git a/package/qte/qte.mk b/package/qte/qte.mk new file mode 100644 index 000000000..a17758afc --- /dev/null +++ b/package/qte/qte.mk @@ -0,0 +1,251 @@ +############################################################# +# +# qte: Qt/E build, includes Qt/E-2, QVfb, and Qtopia-2 +# +############################################################# +BR2_QTE_C_QTE_VERSION:=$(shell echo $(BR2_QTE_VERSION)| sed -e 's/"//g') +BR2_QTE_C_QT3_VERSION:=$(shell echo $(BR2_QTE_QT3_VERSION)| sed -e 's/"//g') +BR2_QTE_C_QVFB_VERSION:=$(shell echo $(BR2_QTE_QVFB_VERSION)| sed -e 's/"//g') +BR2_QTE_C_QTOPIA_VERSION:=$(shell echo $(BR2_QTE_QTOPIA_VERSION)| sed -e 's/"//g') +BR2_QTE_C_TMAKE_VERSION:=$(shell echo $(BR2_QTE_TMAKE_VERSION)| sed -e 's/"//g') +BR2_QTE_C_USERNAME:=$(shell echo $(BR2_PACKAGE_QTE_COMMERCIAL_USERNAME)| sed -e 's/"//g') +BR2_QTE_C_PASSWORD:=$(shell echo $(BR2_PACKAGE_QTE_COMMERCIAL_PASSWORD)| sed -e 's/"//g') +QTE_QTE_SOURCE:=qt-embedded-$(BR2_QTE_C_QTE_VERSION)-commercial.tar.gz +QTE_QT3_SOURCE:=qt-$(BR2_QTE_C_QT3_VERSION)-commercial.tar.gz +QTE_TMAKE_SOURCE:=tmake-$(BR2_QTE_C_TMAKE_VERSION).tar.gz +QTE_QVFB_SOURCE:=qt-x11-$(BR2_QTE_C_QVFB_VERSION)-commercial.tar.gz +QTE_QTOPIA_SOURCE:=qtopia-phone-source-$(BR2_QTE_C_QTOPIA_VERSION).tar.gz +QTE_SITE:=http://$(BR2_QTE_C_USERNAME):$(BR2_QTE_C_PASSWORD)@dist.trolltech.com/$(BR2_QTE_C_USERNAME) +QTE_QTE_DIR:=$(BUILD_DIR)/qt-$(BR2_QTE_C_QTE_VERSION) +QTE_QT3_DIR:=$(BUILD_DIR)/qt-$(BR2_QTE_C_QT3_VERSION) +QTE_TMAKE_DIR:=$(BUILD_DIR)/tmake-$(BR2_QTE_C_TMAKE_VERSION) +QTE_QVFB_DIR:=$(BUILD_DIR)/qt-$(BR2_QTE_C_QVFB_VERSION) +QTE_QTOPIA_DIR:=$(BUILD_DIR)/qtopia-phone-$(BR2_QTE_C_QTOPIA_VERSION) + +QTE_CAT:=zcat +TMAKE:=$(QTE_TMAKE_DIR)/bin/tmake +QTE_UIC_BINARY:=bin/uic +QTE_QVFB_BINARY:=bin/qvfb +QTE_QTE_LIB:=$(QTE_QTE_DIR)/lib/libqte-mt.so.$(BR2_QTE_C_QTE_VERSION) +#QTE_QTE_LIB:=$(TARGET_DIR)/lib/libqte-mt.so.$(BR2_QTE_C_QTE_VERSION) +QTE_QTOPIA_FILE:=$(QTE_QTOPIA_DIR)/bin/qpe +QTE_QTOPIA_IFILE:=$(QTE_QTOPIA_DIR)/opt/Qtopia/bin/qpe + +#export QT2DIR=$(pwd)/qt-2.3.2 +#export QT3DIR=$(pwd)/qt-%{qt_version} +#export QTEDIR=$(pwd)/qt-%{qte_version} +#export QPEDIR=$(pwd) + +############################################################# +# +# Calculate configure options... scary eventually, trivial now +# +# currently only tested with threading +# FIXME: I should use the staging directory here, but I don't yet. +# +############################################################# +# I choose to make the link in libqte so that the linking later is trivial -- a user may choose to use -luuid, or not, and it'll just work. +# ...since libqte* needs -luuid anyhow... +QTE_QTE_CONFIGURE:=-no-xft -L$(E2FSPROGS_DIR)/lib -luuid +QTE_QVFB_CONFIGURE:=-no-xft +QTE_QTOPIA_CONFIGURE:= +QTE_QT3_CONFIGURE:= + +ifeq ($(BR2_PTHREADS_NATIVE),y) +QTE_QTE_CONFIGURE:=$(QTE_QTE_CONFIGURE) -thread +QTE_QVFB_CONFIGURE:=$(QTE_QVFB_CONFIGURE) -thread +QTE_QTOPIA_CONFIGURE:=$(QTE_QTOPIA_CONFIGURE) -thread +QTE_QT3_CONFIGURE:=$(QTE_QT3_CONFIGURE) -thread +endif + +ifeq ($(BR2_PACKAGE_JPEG),y) +QTE_QTE_CONFIGURE:=$(QTE_QTE_CONFIGURE) -system-jpeg +#FIXME: Do I need an else on this? +endif + +ifeq ($(BR2_PACKAGE_LIBPNG),y) +QTE_QTE_CONFIGURE:=$(QTE_QTE_CONFIGURE) -system-libpng +else +QTE_QTE_CONFIGURE:=$(QTE_QTE_CONFIGURE) -qt-libpng +endif + +# as of 2005-08-17's snapshot, uClibc's pthread does NOT support pthread_yield, which is needed +# for ffmpeg's qtopia-phone-2.1.1/src/3rdparty/plugins/codecs/libffmpeg/mediapacketbuffer.h:230 +# (also called at line 232). ...so we have to disable ffmpeg +QTE_QTOPIA_CONFIGURE:=$(QTE_QTOPIA_CONFIGURE) -without-libffmpeg + +QTE_QTOPIA_CONFIGURE:=$(QTE_QTOPIA_CONFIGURE) -L $(E2FSPROGS_DIR)/lib -I $(E2FSPROGS_DIR)/lib -luuid + +############################################################# +# +# Build portion +# +############################################################# + +ifneq ($(BR2_QTE_C_QTE_VERSION),$(BR2_QTE_C_QT3_VERSION)) +$(DL_DIR)/$(QTE_QT3_SOURCE): + $(WGET) -P $(DL_DIR) $(QTE_SITE)/$(@F) +endif + +$(DL_DIR)/$(QTE_QTE_SOURCE) $(DL_DIR)/$(QTE_QVFB_SOURCE) $(DL_DIR)/$(QTE_QTOPIA_SOURCE): + $(WGET) -P $(DL_DIR) $(QTE_SITE)/$(@F) + +$(QTE_TMAKE_DIR)/.unpacked: $(DL_DIR)/$(QTE_TMAKE_SOURCE) + $(QTE_CAT) $(DL_DIR)/$(QTE_TMAKE_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + touch $@ + +ifneq ($(BR2_QTE_C_QTE_VERSION),$(BR2_QTE_C_QT3_VERSION)) + $(QTE_QT3_DIR)/.unpacked: $(DL_DIR)/$(QTE_QT3_SOURCE) + $(QTE_CAT) $(DL_DIR)/$(QTE_QT3_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + touch $@ +endif + + $(QTE_QTE_DIR)/.unpacked: $(DL_DIR)/$(QTE_QTE_SOURCE) + $(QTE_CAT) $(DL_DIR)/$(QTE_QTE_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + touch $@ + +$(QTE_QVFB_DIR)/.unpacked: $(DL_DIR)/$(QTE_QVFB_SOURCE) + $(QTE_CAT) $(DL_DIR)/$(QTE_QVFB_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + touch $@ + +$(QTE_QTOPIA_DIR)/.unpacked: $(DL_DIR)/$(QTE_QTOPIA_SOURCE) + $(QTE_CAT) $(DL_DIR)/$(QTE_QTOPIA_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + # Allow patches -- copy from busybox usage of kernel patcher + toolchain/patch-kernel.sh $(@D) package/qte qtopia-$(BR2_QTE_C_QTOPIA_VERSION)-\*.patch + touch $@ + + +# currently, this assumes that Qtopis is always involved. The dependency fails and the cp is wrong if Qtopis is not selected. +# I'll fix that later. +$(QTE_QTE_DIR)/.configured: $(QTE_QTE_DIR)/.unpacked $(QTE_TMAKE_DIR)/.unpacked $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) $(QTE_QTE_DIR)/$(QTE_QVFB_BINARY) $(QTE_QTOPIA_DIR)/.unpacked + cp $(QTE_QTOPIA_DIR)/src/qt/qconfig-qpe.h $(QTE_QTE_DIR)/src/tools/ + (cd $(@D); export QTDIR=`pwd`; export TMAKEPATH=$(QTE_TMAKE_DIR)/lib/qws/linux-x86-g++; export PATH=$(STAGING_DIR)/bin:$$QTDIR/bin:$$PATH; export LD_LIBRARY_PATH=$$QTDIR/lib:$$LD_LIBRARY_PATH; echo 'yes' | \ + $(TARGET_CONFIGURE_OPTS) CC_FOR_BUILD=$(HOSTCC) \ + CFLAGS="$(TARGET_CFLAGS)" \ + ./configure \ + $(QTE_QTE_CONFIGURE) -qconfig qpe -keypad-mode -qvfb -depths 4,8,16,32 -xplatform $(BR2_QTE_CROSS_PLATFORM) \ + ); + touch $@ + +ifneq ($(BR2_QTE_C_QTE_VERSION),$(BR2_QTE_C_QT3_VERSION)) +# this is a host-side build, so we don't use any staging dir stuff, nor any TARGET_CONFIGURE_OPTS +$(QTE_QT3_DIR)/.configured: $(QTE_QT3_DIR)/.unpacked $(QTE_TMAKE_DIR)/.unpacked + (cd $(@D); export QTDIR=`pwd`; export TMAKEPATH=$(QTE_TMAKE_DIR)/lib/qws/linux-x86-g++; export PATH=$$QTDIR/bin:$$PATH; export LD_LIBRARY_PATH=$$QTDIR/lib:$$LD_LIBRARY_PATH; echo 'yes' | \ + CC_FOR_BUILD=$(HOSTCC) \ + ./configure \ + -fast $(QTE_QT3_CONFIGURE) \ + ); + touch $@ +endif + +$(QTE_QVFB_DIR)/.configured: $(QTE_QVFB_DIR)/.unpacked $(QTE_TMAKE_DIR)/.unpacked + (cd $(@D); export QTDIR=`pwd`; export TMAKEPATH=$(QTE_TMAKE_DIR)/lib/linux-g++; export $$QTDIR/bin:$$PATH; export LD_LIBRARY_PATH=$$QTDIR/lib:$$LD_LIBRARY_PATH; echo 'yes' | \ + $(TARGET_CONFIGURE_OPTS) CC_FOR_BUILD=$(HOSTCC) \ + CFLAGS="$(TARGET_CFLAGS)" \ + ./configure \ + $(QTE_QVFB_CONFIGURE) \ + ); + touch $@ + +# --edition {other} +# This has some kooky logic. Qtopia requires a Qt <= 3.3.0 to build, yet we like to use s Qt-2.3.x for size constraints on an embedded device +# This target depends on both $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) **and** $(QTE_QT3_DIR)/.configured. if BR2_QTE_C_QTE_VERSION == BR2_QTE_C_QT3_VERSION, +# then it really depends on $(QTE_QTE_DIR)/.configured, which $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) needs, so it's redundant. If QTE is 3.3.0 or later, +# then BR2_QTE_C_QTE_VERSION != BR2_QTE_C_QT3_VERSION, then we need to unpack the other Qt/E, so this dependency is not redundant. + +$(QTE_QTOPIA_DIR)/.configured: $(QTE_QTOPIA_DIR)/.unpacked $(QTE_TMAKE_DIR)/.unpacked $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) $(QTE_QTE_DIR)/$(QTE_QVFB_BINARY) $(QTE_QT3_DIR)/.configured + (cd $(@D); export QTDIR=$(QTE_QTE_DIR); export QPEDIR=$(QTE_QTOPIA_DIR); export PATH=$(STAGING_DIR)/bin:$$QTDIR/bin:$$PATH; QT3DIR=$(QTE_QTE_DIR); echo 'yes' | \ + $(TARGET_CONFIGURE_OPTS) CC_FOR_BUILD=$(HOSTCC) \ + CFLAGS="$(TARGET_CFLAGS)" \ + ./configure \ + $(QTE_QTOPIA_CONFIGURE) --edition phone -no-qtopiadesktop -dqt $(QTE_QT3_DIR) -arch generic -displaysize 160-240 -languages en_US \ + -platform linux-g++ -qvfb -xplatform $(BR2_QTE_CROSS_PLATFORM) \ + ); + touch $@ + +# there is no build for tmake, only unpack +$(TMAKE): $(QTE_TMAKE_DIR)/.unpacked + +# This must NOT use TARGET_CC -- it is a host-side tool +$(QTE_QVFB_DIR)/.make: $(QTE_QVFB_DIR)/.configured $(TMAKE) + #$(TARGET_CONFIGURE_OPTS) + export QTDIR=$(QTE_QVFB_DIR); export PATH=$$QTDIR/bin:$$PATH; \ + $(MAKE) -C $(QTE_QVFB_DIR) src-moc + touch $@ + +$(QTE_QTE_DIR)/$(QTE_UIC_BINARY): $(QTE_QVFB_DIR)/.make $(QTE_QTE_DIR)/.unpacked + export QTDIR=$(QTE_QVFB_DIR); export PATH=$$QTDIR/bin:$$PATH; \ + $(MAKE) -C $(QTE_QVFB_DIR)/tools/designer/uic + test -d $(@D) || install -dm 0755 $(@D) + install -m 0755 $(QTE_QVFB_DIR)/bin/$(@F) $@ + +ifneq ($(BR2_QTE_C_QTE_VERSION),$(BR2_QTE_C_QT3_VERSION)) +$(QTE_QT3_DIR)/.make: $(QTE_QT3_DIR)/.unpacked + ( export QTDIR=$(QTE_QT3_DIR); export PATH=$$QTDIR/bin:$$PATH; export LD_LIBRARY_PATH=$$QTDIR/lib:$$LD_LIBRARY_PATH; \ + $(MAKE) -C $(QTE_QT3_DIR) sub-src && \ + $(MAKE) -C $(QTE_QT3_DIR)/tools/linguist/lrelease \ + $(MAKE) -C $(QTE_QT3_DIR)/tools/linguist/lupdate \ + $(MAKE) -C $(QTE_QT3_DIR)/tools/designer/uilib \ + $(MAKE) -C $(QTE_QT3_DIR)/tools/designer/uic + ); + touch $@ +endif + +$(QTE_QTE_DIR)/$(QTE_QVFB_BINARY): $(QTE_QVFB_DIR)/.make $(QTE_QTE_DIR)/.unpacked $(TMAKE) + (cd $(QTE_QVFB_DIR)/tools/qvfb && TMAKEPATH=$(QTE_TMAKE_DIR)/lib/linux-g++ $(TMAKE) -o Makefile qvfb.pro) + #$(TARGET_CONFIGURE_OPTS) + export QTDIR=$(QTE_QVFB_DIR); export PATH=$$QTDIR/bin:$$PATH; \ + $(MAKE) -C $(QTE_QVFB_DIR)/tools/qvfb + test -d $(@D) || install -dm 0755 $(@D) + install -m 0755 $(QTE_QVFB_DIR)/tools/qvfb/$(@F) $@ + +$(QTE_QTE_DIR)/src-mt.mk: $(QTE_QTE_DIR)/.configured + # I don't like the src-mk that gets built, so blow it away. Too many includes to override yet + echo "SHELL=/bin/sh" > $@ + echo "" >> $@ + echo "src-mt:" >> $@ + echo " cd src; "'$$(MAKE)'" 'QT_THREAD_SUFFIX=-mt' 'QT_LFLAGS_MT="'$$$$(SYSCONF_LFLAGS_THREAD)'" "'$$$$(SYSCONF_LIBS_THREAD)'"' 'QT_CXX_MT="'$$$$(SYSCONF_CXXFLAGS_THREAD)'" -DQT_THREAD_SUPPORT' 'QT_C_MT="'$$$$(SYSCONF_CFLAGS_THREAD)'" -DQT_THREAD_SUPPORT'" >> $@ + +$(QTE_QTE_LIB): $(QTE_QTE_DIR)/src-mt.mk + export QTDIR=$(QTE_QTE_DIR); export QPEDIR=$(QTE_QTOPIA_DIR); export PATH=$(STAGING_DIR)/bin:$$QTDIR/bin:$$PATH; \ + $(TARGET_CONFIGURE_OPTS) $(MAKE) $(TARGET_CC) -C $(QTE_QTE_DIR) src-mt + $(TARGET_CONFIGURE_OPTS) $(MAKE) $(TARGET_CC) DESTDIR=$(TARGET_DIR)/lib -C $(QTE_QTE_DIR) src-mt + # ... and make sure it actually built... grrr... make deep-deep-deep makefile recursion for this habit + test -f $@ + +$(QTE_QTOPIA_FILE): $(QTE_QTOPIA_DIR)/.configured + export QTDIR=$(QTE_QT3_DIR); export QPEDIR=$(QTE_QTOPIA_DIR); export PATH=$(STAGING_DIR)/bin:$$QTDIR/bin:$$PATH; \ + $(TARGET_CONFIGURE_OPTS) $(MAKE) CC=$(TARGET_CC) -C $(QTE_QTOPIA_DIR) + +$(QTE_QTOPIA_IFILE): $(QTE_QTOPIA_FILE) + export QTDIR=$(QTE_QT3_DIR); export QPEDIR=$(QTE_QTOPIA_DIR); export PATH=$(STAGING_DIR)/bin:$$QTDIR/bin:$$PATH; \ + $(TARGET_CONFIGURE_OPTS) $(MAKE) CC=$(TARGET_CC) -C $(QTE_QTOPIA_DIR) install PREFIX=$(TARGET_DIR) + + +qte:: $(QTE_QTE_LIB) + +ifeq ($(strip $(BR2_PACKAGE_QTE_QTOPIA)),y) +qte:: $(QTE_QTOPIA_IFILE) +endif + +# kinda no-op right now, these are built anyhow +ifeq ($(strip $(BR2_PACKAGE_QTE_QVFB)),y) +qte:: $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) $(QTE_QTE_DIR)/$(QTE_QVFB_BINARY) +endif + +qte-clean: + rm -f $(QTE_QTE_DIR)/$(QTE_UIC_BINARY) $(QTE_QTE_DIR)/$(QTE_QVFB_BINARY) $(QTE_QTE_LIB) $(QTE_QTOPIA_FILE) + -$(MAKE) -C $(QTE_QTE_DIR) clean + -$(MAKE) -C $(QTE_QVFB_DIR) clean + -$(MAKE) -C $(QTE_QTOPIA_DIR) clean + +qte-dirclean: + rm -rf $(QTE_QTE_DIR) $(QTE_QVFB_DIR) $(QTE_QTOPIA_DIR) +############################################################# +# +# Toplevel Makefile options +# +############################################################# +ifeq ($(strip $(BR2_PACKAGE_QTE)),y) +TARGETS+=qte +endif |