update drivers
[vuplus_openembedded] / classes / sip.bbclass
index e69de29..30c08b1 100644 (file)
@@ -0,0 +1,62 @@
+# Build Class for Sip based Python Bindings
+# (C) Michael 'Mickey' Lauer <mickey@Vanille.de>
+#
+
+# yes, python-sip is actually a build-time dependency, since
+# the recipe installs sip.h
+DEPENDS += "sip-native python-sip"
+
+# default stuff, do not uncomment
+# EXTRA_SIPTAGS = "-tWS_X11 -tQt_4_3_0"
+
+sip_do_generate() {
+       if [ -z "${SIP_MODULES}" ]; then 
+               MODULES="`ls sip/*mod.sip`"
+       else
+               MODULES="${SIP_MODULES}"
+       fi
+
+       if [ -z "$MODULES" ]; then
+               die "SIP_MODULES not set and no modules found in $PWD"
+        else
+               oenote "using modules '${SIP_MODULES}' and tags '${EXTRA_SIPTAGS}'"
+       fi
+
+       if [ -z "${EXTRA_SIPTAGS}" ]; then
+               die "EXTRA_SIPTAGS needs to be set!"
+       else
+               SIPTAGS="${EXTRA_SIPTAGS}"
+       fi
+
+       if [ ! -z "${SIP_FEATURES}" ]; then
+               FEATURES="-z ${SIP_FEATURES}"
+               oenote "sip feature file: ${SIP_FEATURES}"
+       fi
+
+       for module in $MODULES
+       do
+               install -d ${module}/
+               echo "calling 'sip -I sip -I ${STAGING_SIPDIR} ${SIPTAGS} ${FEATURES} -c ${module} -b ${module}/${module}.pro.in sip/${module}/${module}mod.sip'"
+               sip -I ${STAGING_SIPDIR} -I sip ${SIPTAGS} ${FEATURES} -c ${module} -b ${module}/${module}.sbf \
+                       sip/${module}/${module}mod.sip || die "Error calling sip on ${module}"
+               cat ${module}/${module}.sbf     | sed s,target,TARGET, \
+                                               | sed s,sources,SOURCES, \
+                                               | sed s,headers,HEADERS, \
+                                               | sed s,"moc_HEADERS =","HEADERS +=", \
+               >${module}/${module}.pro
+               echo "TEMPLATE=lib" >>${module}/${module}.pro
+               [ "${module}" = "qt" ]          && echo ""              >>${module}/${module}.pro
+               [ "${module}" = "qtcanvas" ]    && echo ""              >>${module}/${module}.pro
+               [ "${module}" = "qttable" ]     && echo ""              >>${module}/${module}.pro
+               [ "${module}" = "qwt" ]         && echo ""              >>${module}/${module}.pro
+               [ "${module}" = "qtpe" ]        && echo ""              >>${module}/${module}.pro
+               [ "${module}" = "qtpe" ]        && echo "LIBS+=-lqpe"   >>${module}/${module}.pro
+               true
+       done
+}
+
+do_generate[deptask] = "do_populate_staging"
+
+EXPORT_FUNCTIONS do_generate
+
+addtask generate after do_unpack do_patch before do_configure