Author: wiget                        Date: Sat Mar 27 15:14:51 2010 GMT
Module: packages                      Tag: HEAD
---- Log message:
- build python2 and python3 versions from one spec
- release 2

---- Files affected:
packages/python-lxml:
   python-lxml.spec (1.19 -> 1.20) , python3.patch (NONE -> 1.1)  (NEW)

---- Diffs:

================================================================
Index: packages/python-lxml/python-lxml.spec
diff -u packages/python-lxml/python-lxml.spec:1.19 
packages/python-lxml/python-lxml.spec:1.20
--- packages/python-lxml/python-lxml.spec:1.19  Wed Mar  3 19:57:33 2010
+++ packages/python-lxml/python-lxml.spec       Sat Mar 27 16:14:46 2010
@@ -1,21 +1,31 @@
 # $Revision$, $Date$
 #
+%bcond_without python3
+%bcond_without python2
 %define                module  lxml
 #
 Summary:       A Pythonic binding for the libxml2 and libxslt libraries
 Summary(pl.UTF-8):     Pythonowe wiązanie do bibliotek libxml2 i libxslt
 Name:          python-%{module}
 Version:       2.2.6
-Release:       1
+Release:       2
 License:       BSD
 Group:         Libraries/Python
 Source0:       http://codespeak.net/lxml/%{module}-%{version}.tgz
 # Source0-md5: b1f700fb22d7ee9b977ee3eceb65b20c
+Patch0:                python3.patch
 URL:           http://codespeak.net/lxml/
 BuildRequires: libxml2-devel
 BuildRequires: libxslt-devel
+%if %{with python2}
 BuildRequires: python-devel
 BuildRequires: python-modules
+%endif
+%if %{with python3}
+BuildRequires: python3-Cython
+BuildRequires: python3-devel
+BuildRequires: python3-modules
+%endif
 BuildRequires: rpm-pythonprov
 BuildRequires: rpmbuild(macros) >= 1.219
 BuildRequires: unzip
@@ -27,24 +37,56 @@
 %description -l pl.UTF-8
 lxml to pythonowe wiązanie do bibliotek libxml2 i libxslt.
 
+%package -n    python3-%{module}
+Summary:       A Pythonic binding for the libxml2 and libxslt libraries
+Summary(pl.UTF-8):     Pythonowe wiązanie do bibliotek libxml2 i libxslt
+Version:       %{version}
+Release:       %{release}
+Group:         Libraries/Python
+
+%description -n python3-%{module}
+lxml is a Pythonic binding for the libxml2 and libxslt libraries.
+
+%description -n python3-%{module} -l pl.UTF-8
+lxml to pythonowe wiązanie do bibliotek libxml2 i libxslt.
+
 %prep
 %setup -q -n %{module}-%{version}
+%patch0 -p1
 
 %build
-python setup.py build
+%if %{with python2}
+%{__python} setup.py build
+%endif
+%if %{with python3}
+%{__python3} setup.py build
+%endif
 
 %install
 rm -rf $RPM_BUILD_ROOT
 
-python setup.py install \
+%if %{with python2}
+%{__python} setup.py \
+       install \
        --root=$RPM_BUILD_ROOT \
        --optimize=2
 
 %py_postclean
+%endif
+
+%if %{with python3}
+%{__python3} setup.py \
+       install \
+       --root=$RPM_BUILD_ROOT \
+       --optimize=2
+
+%py3_postclean
+%endif
 
 %clean
 rm -rf $RPM_BUILD_ROOT
 
+%if %{with python2}
 %files
 %defattr(644,root,root,755)
 %doc doc/* CHANGES.txt CREDITS.txt TODO.txt
@@ -55,6 +97,20 @@
 %attr(755,root,root) %{py_sitedir}/lxml/etree.so
 %attr(755,root,root) %{py_sitedir}/lxml/objectify.so
 %{py_sitedir}/lxml-*.egg-info
+%endif
+
+%if %{with python3}
+%files -n python3-%{module}
+%defattr(644,root,root,755)
+%doc doc/* CHANGES.txt CREDITS.txt TODO.txt
+%dir %{py3_sitedir}/lxml
+%{py3_sitedir}/lxml/*.py[co]
+%dir %{py3_sitedir}/lxml/html
+%{py3_sitedir}/lxml/html/*.py[co]
+%attr(755,root,root) %{py3_sitedir}/lxml/etree.so
+%attr(755,root,root) %{py3_sitedir}/lxml/objectify.so
+%{py3_sitedir}/lxml-*.egg-info
+%endif
 
 %define date   %(echo `LC_ALL="C" date +"%a %b %d %Y"`)
 %changelog
@@ -62,6 +118,10 @@
 All persons listed below can be reached at <cvs_login>@pld-linux.org
 
 $Log$
+Revision 1.20  2010/03/27 15:14:46  wiget
+- build python2 and python3 versions from one spec
+- release 2
+
 Revision 1.19  2010/03/03 18:57:33  wiget
 - 2.2.6
 

================================================================
Index: packages/python-lxml/python3.patch
diff -u /dev/null packages/python-lxml/python3.patch:1.1
--- /dev/null   Sat Mar 27 16:14:51 2010
+++ packages/python-lxml/python3.patch  Sat Mar 27 16:14:46 2010
@@ -0,0 +1,42 @@
+--- lxml-2.2.6/src/lxml/html/_html5builder.py.wiget    2009-09-11 
10:55:58.000000000 +0200
++++ lxml-2.2.6/src/lxml/html/_html5builder.py  2010-03-27 16:04:28.693916731 
+0100
+@@ -7,6 +7,11 @@ html5lib style guide.
+ from html5lib.treebuilders import _base, etree as etree_builders
+ from lxml import html, etree
+ 
++try:
++    empty_string = unicode()
++except NameError:
++    empty_string = str()
++
+ 
+ class DocumentType(object):
+ 
+@@ -77,7 +82,7 @@ class TreeBuilder(_base.TreeBuilder):
+                                                   self.doctype.systemId))
+             buf.append('>')
+         buf.append('<html></html>')
+-        root = html.fromstring(u''.join(buf))
++        root = html.fromstring(empty_string.join(buf))
+ 
+         # Append the initial comments:
+         for comment in self.initialComments:
+--- lxml-2.2.6/src/lxml/html/_diffcommand.py.wiget     2009-09-11 
10:55:58.000000000 +0200
++++ lxml-2.2.6/src/lxml/html/_diffcommand.py   2010-03-27 16:02:10.727258598 
+0100
+@@ -34,7 +34,7 @@ def main(args=None):
+     if options.annotation:
+         return annotate(options, args)
+     if len(args) != 2:
+-        print 'Error: you must give two files'
++        print('Error: you must give two files')
+         parser.print_help()
+         sys.exit(1)
+     file1, file2 = args
+@@ -82,6 +82,6 @@ def split_body(html):
+     return pre, html, post
+ 
+ def annotate(options, args):
+-    print "Not yet implemented"
++    print("Not yet implemented")
+     sys.exit(1)
+     
================================================================

---- CVS-web:
    
http://cvs.pld-linux.org/cgi-bin/cvsweb.cgi/packages/python-lxml/python-lxml.spec?r1=1.19&r2=1.20&f=u

_______________________________________________
pld-cvs-commit mailing list
[email protected]
http://lists.pld-linux.org/mailman/listinfo/pld-cvs-commit

Reply via email to