From 0773cf03134bc5b3ca9cbb113d8c9e29b9767efe Mon Sep 17 00:00:00 2001 From: Martin Wilke Date: Tue, 27 Mar 2007 09:59:53 +0000 Subject: [PATCH] PyQt4 is a set of Python bindings for Trolltech's Qt4 application framework. This package provides the QtXml module. WWW: http://www.riverbankcomputing.co.uk/pyqt/ PR: ports/109622 Submitted by: Danny Pansters --- textproc/Makefile | 1 + textproc/py-qt4-xml/Makefile | 72 +++++++++ textproc/py-qt4-xml/distinfo | 3 + textproc/py-qt4-xml/files/patch-configure.py | 160 +++++++++++++++++++ textproc/py-qt4-xml/pkg-descr | 4 + textproc/py-qt4-xml/pkg-plist | 12 ++ 6 files changed, 252 insertions(+) create mode 100644 textproc/py-qt4-xml/Makefile create mode 100644 textproc/py-qt4-xml/distinfo create mode 100644 textproc/py-qt4-xml/files/patch-configure.py create mode 100644 textproc/py-qt4-xml/pkg-descr create mode 100644 textproc/py-qt4-xml/pkg-plist diff --git a/textproc/Makefile b/textproc/Makefile index 09d75c4f9575..80793e1c90e0 100644 --- a/textproc/Makefile +++ b/textproc/Makefile @@ -759,6 +759,7 @@ SUBDIR += py-lucene SUBDIR += py-markdown SUBDIR += py-pyx12 + SUBDIR += py-qt4-xml SUBDIR += py-rdflib SUBDIR += py-reverend SUBDIR += py-rss2gen diff --git a/textproc/py-qt4-xml/Makefile b/textproc/py-qt4-xml/Makefile new file mode 100644 index 000000000000..e47d4e5ac119 --- /dev/null +++ b/textproc/py-qt4-xml/Makefile @@ -0,0 +1,72 @@ +# New ports collection makefile for: py-qt4-xml +# Date created: 2007-02-20 +# Whom: Danny Pansters +# +# $FreeBSD$ + +PORTNAME= xml +PORTVERSION= 20070318 +CATEGORIES= textproc devel python +MASTER_SITES= http://www.riverbankcomputing.com/Downloads/Snapshots/PyQt4/ \ + http://freebsd.ricin.com/ports/distfiles/ +PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX}qt4- +DISTNAME= PyQt-x11-gpl-4-snapshot-${PORTVERSION} + +MAINTAINER= danny@ricin.com +COMMENT= Python bindings for the Qt4 toolkit, QtXml module + +BUILD_DEPENDS= ${PYTHON_SITELIBDIR}/PyQt4/QtGui.so:${PORTSDIR}/x11-toolkits/py-qt4-gui +RUN_DEPENDS= ${BUILD_DEPENDS} + +HAS_CONFIGURE= yes +USE_PYTHON= 2.3+ +USE_QT_VER= 4 +QT_COMPONENTS= xml qmake + +OPTIONS= API "Install QtXml API for QScintilla2" on \ + DEBUG "Enable debugging in generated code" off \ + SIPFILES "Install the QtXml SIP files" on \ + TRACING "Enable tracing in generated code" off + +OPTIONSFILE= ${PORT_DBDIR}/py-qt4-${PORTNAME}/options +APIFILE= ${QT_PREFIX}/share/qt4/qsci/api/python/QtXml.api +SIPDIR= ${PREFIX}/share/py-sip +ARGS= -b ${PREFIX}/bin -c -j 2 -d ${PYTHONPREFIX_SITELIBDIR}/PyQt4 \ + -q ${QT_PREFIX}/bin/qmake-qt4 -a + +.include + +.if defined(WITH_DEBUG) +ARGS+= -u +.endif +.if defined(WITHOUT_API) +PLIST_SUB+= API="@comment " +PLIST_SUB+= APIFILE="@comment " +.else +LIB_DEPENDS+= qscintilla2:${PORTSDIR}/devel/qscintilla2 +PLIST_SUB+= API="" +PLIST_SUB+= APIFILE="share/qt4/qsci/api/python/QtXml.api" +.endif +.if defined(WITHOUT_SIPFILES) +ARGS+= -v /dev/null +PLIST_SUB+= SIPFILES="@comment " +PLIST_SUB+= SIPDIR="@comment " +.else +ARGS+= -v ${SIPDIR} +PLIST_SUB+= SIPFILES="" +PLIST_SUB+= SIPDIR="share/py-sip" +.endif +.if defined(WITH_TRACING) +ARGS+= -r +.endif + +do-configure: + ( cd ${WRKSRC} && ${SETENV} ${CONFIGURE_ENV} \ + ${PYTHON_CMD} configure.py ${ARGS} ) + +post-install: +.if defined(WITHOUT_API) + ( ${RM} ${APIFILE} ) +.endif + +.include diff --git a/textproc/py-qt4-xml/distinfo b/textproc/py-qt4-xml/distinfo new file mode 100644 index 000000000000..b42fc45ded6f --- /dev/null +++ b/textproc/py-qt4-xml/distinfo @@ -0,0 +1,3 @@ +MD5 (PyQt-x11-gpl-4-snapshot-20070318.tar.gz) = 538cd5167ccb14a6b6a3ee687432617a +SHA256 (PyQt-x11-gpl-4-snapshot-20070318.tar.gz) = d98516e20b02194264c199deddda2562845efca64315608522cc05a36c9210c7 +SIZE (PyQt-x11-gpl-4-snapshot-20070318.tar.gz) = 1076275 diff --git a/textproc/py-qt4-xml/files/patch-configure.py b/textproc/py-qt4-xml/files/patch-configure.py new file mode 100644 index 000000000000..74435f754b89 --- /dev/null +++ b/textproc/py-qt4-xml/files/patch-configure.py @@ -0,0 +1,160 @@ +--- configure.py.orig Mon Feb 19 04:39:13 2007 ++++ configure.py Tue Feb 20 16:13:30 2007 +@@ -133,21 +133,21 @@ + } + + def check_modules(self): +- pyqt_modules.append("QtCore") ++ #pyqt_modules.append("QtCore") + +- check_module("QtGui", "qwidget.h", "new QWidget()") +- check_module("QtNetwork", "qhostaddress.h", "new QHostAddress()") +- check_module("QtOpenGL", "qgl.h", "new QGLWidget()") +- check_module("QtSql", "qsqldatabase.h", "new QSqlDatabase()") +- check_module("QtSvg", "qsvgwidget.h", "new QSvgWidget()") +- check_module("QtTest", "QtTest", "QTest::qSleep(0)") ++ #check_module("QtGui", "qwidget.h", "new QWidget()") ++ #check_module("QtNetwork", "qhostaddress.h", "new QHostAddress()") ++ #check_module("QtOpenGL", "qgl.h", "new QGLWidget()") ++ #check_module("QtSql", "qsqldatabase.h", "new QSqlDatabase()") ++ #check_module("QtSvg", "qsvgwidget.h", "new QSvgWidget()") ++ #check_module("QtTest", "QtTest", "QTest::qSleep(0)") + check_module("QtXml", "qdom.h", "new QDomDocument()") +- check_module("QtAssistant", "qassistantclient.h", "new QAssistantClient(\"foo\")") +- check_module("QtDesigner", "QExtensionFactory", "new QExtensionFactory()") +- check_module("QAxContainer", "qaxobject.h", "new QAxObject()", "QAxContainer") ++ #check_module("QtAssistant", "qassistantclient.h", "new QAssistantClient(\"foo\")") ++ #check_module("QtDesigner", "QExtensionFactory", "new QExtensionFactory()") ++ #check_module("QAxContainer", "qaxobject.h", "new QAxObject()", "QAxContainer") + +- if os.path.isdir("dbus"): +- check_dbus() ++ #if os.path.isdir("dbus"): ++ # check_dbus() + + def code(self): + # Note that the order of the dependent modules is important. +@@ -201,31 +201,31 @@ + generate_code("QAxContainer", ["QAxContainer", "QtGui", "QtCore"]) + + # Generate the consolidated module. +- sipconfig.inform("Creating Qt consolidated module...") +- f = open("Qt.py", "w") ++ #sipconfig.inform("Creating Qt consolidated module...") ++ #f = open("Qt.py", "w") + +- for m in pyqt_modules: +- f.write("from PyQt4.%s import *\n" % m) ++ #for m in pyqt_modules: ++ # f.write("from PyQt4.%s import *\n" % m) + +- f.close() ++ #f.close() + + # Generate the QScintilla API file. +- sipconfig.inform("Creating QScintilla API file...") +- f = open("PyQt4.api", "w") ++ #sipconfig.inform("Creating QScintilla API file...") ++ #f = open("PyQt4.api", "w") + +- for m in pyqt_modules: +- api = open(m + ".api") ++ #for m in pyqt_modules: ++ # api = open(m + ".api") + +- for l in api: +- f.write("PyQt4." + l) ++ # for l in api: ++ # f.write("PyQt4." + l) + +- api.close() +- os.remove(m + ".api") ++ # api.close() ++ # os.remove(m + ".api") + +- f.close() ++ #f.close() + + def module_installs(self): +- return ["__init__.py", "Qt.py", "pyqtconfig.py"] ++ return [] + + def qpylibs(self): + # See which QPy libraries to build. +@@ -278,7 +278,7 @@ + tool.append("dbus") + + # Only include ElementTree for older versions of Python. +- if sipcfg.py_version < 0x020500: ++ """if sipcfg.py_version < 0x020500: + sipconfig.inform("Creating elementtree Makefile...") + + makefile = sipconfig.PythonModuleMakefile( +@@ -309,7 +309,7 @@ + ) + + makefile.generate() +- tool.append("pyuic") ++ tool.append("pyuic")""" + + if "QtXml" in pyqt_modules: + sipconfig.inform("Creating pylupdate4 Makefile...") +@@ -428,7 +428,7 @@ + + sipconfig.inform("The PyQt .sip files will be installed in %s." % opt_pyqtsipdir) + +- sipconfig.inform("pyuic4, pyrcc4 and pylupdate4 will be installed in %s." % opt_pyqtbindir) ++ #sipconfig.inform("pyuic4, pyrcc4 and pylupdate4 will be installed in %s." % opt_pyqtbindir) + + if opt_vendorcheck: + sipconfig.inform("PyQt will only be usable with signed interpreters.") +@@ -761,7 +761,8 @@ + sipfiles = [] + + for s in glob.glob("sip/" + mname + "/*.sip"): +- sipfiles.append(os.path.join("..", "sip", mname, os.path.basename(s))) ++ if mname == "QtXml": ++ sipfiles.append(os.path.join("..", "sip", mname, os.path.basename(s))) + + installs.append([sipfiles, os.path.join(opt_pyqtsipdir, mname)]) + +@@ -825,7 +826,7 @@ + sipconfig.error("This version of PyQt and the %s edition of Qt have incompatible licenses." % qted) + + # Confirm the license. +- print ++ """print + print "Type 'L' to view the license." + print "Type 'yes' to accept the terms of the license." + print "Type 'no' to decline the terms of the license." +@@ -847,7 +848,7 @@ + + if resp == "l": + os.system("more LICENSE") +- ++ """ + # If there should be a license file then check it is where it should be. + if lfile: + if os.access(os.path.join("sip", lfile), os.F_OK): +@@ -1367,16 +1368,18 @@ + scidir = os.path.join(qt_datadir, "qsci") + + if opt_api or os.path.isdir(scidir): +- installs.append(("PyQt4.api", os.path.join(scidir, "api", "python"))) ++ installs.append(("QtXml.api", os.path.join(scidir, "api", "python"))) ++ ++ pyqt_modules = ["QtXml"] + + sipconfig.ParentMakefile( + configuration=sipcfg, +- subdirs=pyqt.qpylibs() + pyqt_modules + pyqt.tools(), ++ subdirs=pyqt_modules + pyqt.tools(), + installs=installs + ).generate() + + # Install the configuration module. +- create_config("pyqtconfig.py", "pyqtconfig.py.in", macros) ++ #create_config("pyqtconfig.py", "pyqtconfig.py.in", macros) + + + ############################################################################### diff --git a/textproc/py-qt4-xml/pkg-descr b/textproc/py-qt4-xml/pkg-descr new file mode 100644 index 000000000000..38b706087770 --- /dev/null +++ b/textproc/py-qt4-xml/pkg-descr @@ -0,0 +1,4 @@ +PyQt4 is a set of Python bindings for Trolltech's Qt4 application framework. +This package provides the QtXml module. + +WWW: http://www.riverbankcomputing.co.uk/pyqt/ diff --git a/textproc/py-qt4-xml/pkg-plist b/textproc/py-qt4-xml/pkg-plist new file mode 100644 index 000000000000..47490ebd46d3 --- /dev/null +++ b/textproc/py-qt4-xml/pkg-plist @@ -0,0 +1,12 @@ +bin/pylupdate4 +bin/pyrcc4 +%%PYTHON_SITELIBDIR%%/PyQt4/QtXml.so +%%SIPFILES%%%%SIPDIR%%/QtXml/QtXmlmod.sip +%%SIPFILES%%%%SIPDIR%%/QtXml/qdom.sip +%%SIPFILES%%%%SIPDIR%%/QtXml/qxml.sip +%%SIPFILES%%@dirrm %%SIPDIR%%/QtXml +@cwd %%LOCALBASE%% +%%API%%%%APIFILE%% +%%API%%@dirrmtry share/qt4/qsci/api/python +%%API%%@dirrmtry share/qt4/qsci/api +%%API%%@dirrmtry share/qt4/qsci