%global upstream_name Sphinx %global py3_default 0 Name: python-sphinx Version: 1.7.9 Release: 2%{?_dist_release} Summary: Python documentation generator Group: Development/Tools # Unless otherwise noted, the license for code is BSD # sphinx/util/stemmer.py Public Domain # sphinx/pycode/pgen2 Python # jquery (MIT or GPLv2) License: BSD and Public Domain and Python and (MIT or GPLv2) URL: http://sphinx.pocoo.org/ Vendor: Project Vine Distribution: Vine Linux Source0: http://pypi.python.org/packages/source/S/%{upstream_name}/%{upstream_name}-%{version}.tar.gz Source1: python2-sphinx Source2: python3-sphinx Source3: zz-modules-python-sphinx.sh Source4: zz-modules-python-sphinx.csh Source5: README.fedora # environment-modules file to select whether the py2 or py3 version of # python-sphinx execuitables is default Source6: default-sphinx-command.in # Make the test_latex_remote_images an expected failure # since it requires an active internet connection # to fetch images, which is not possible in koji or mock. Patch0: xfail-test_latex_remote_images.patch # Allow extra themes to exist. We pull in python[23]-sphinx-theme-alabaster # which causes that test to fail. Patch1: sphinx-test_theming.diff BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root BuildArch: noarch BuildRequires: python-rpm-macros BuildRequires: python-devel BuildRequires: python-setuptools BuildRequires: python-six BuildRequires: python-jinja2 BuildRequires: python-pygments BuildRequires: python-docutils BuildRequires: python-snowballstemmer BuildRequires: python-babel BuildRequires: python-sphinx-theme-alabaster BuildRequires: python-imagesize BuildRequires: python-requests BuildRequires: python-packaging BuildRequires: python-typing BuildRequires: python-sphinxcontrib-websupport Requires: python-sphinx-locale = %{version}-%{release} Requires: python-six Requires: python-jinja2 Requires: python-pygments Requires: python-docutils Requires: python-snowballstemmer Requires: python-babel Requires: python-sphinx-theme-alabaster Requires: python-imagesize Requires: python-requests Requires: python-packaging Requires: python-typing Requires: python-sphinxcontrib-websupport %description Sphinx is a tool that makes it easy to create intelligent and beautiful documentation for Python projects (or other documents consisting of multiple reStructuredText sources), written by Georg Brandl. It was originally created to translate the new Python documentation, but has now been cleaned up in the hope that it will be useful to many other projects. Sphinx uses reStructuredText as its markup language, and many of its strengths come from the power and straightforwardness of reStructuredText and its parsing and translating suite, the Docutils. Although it is still under constant development, the following features are already present, work fine and can be seen "in action" in the Python docs: * Output formats: HTML (including Windows HTML Help) and LaTeX, for printable PDF versions * Extensive cross-references: semantic markup and automatic links for functions, classes, glossary terms and similar pieces of information * Hierarchical structure: easy definition of a document tree, with automatic links to siblings, parents and children * Automatic indices: general index as well as a module index * Code handling: automatic highlighting using the Pygments highlighter * Various extensions are available, e.g. for automatic testing of snippets and inclusion of appropriately formatted docstrings. %package -n python3-sphinx Summary: Python documentation generator Group: Development/Tools BuildRequires: python3-rpm-macros BuildRequires: python3-devel BuildRequires: python3-setuptools BuildRequires: python3-six BuildRequires: python3-jinja2 BuildRequires: python3-pygments BuildRequires: python3-docutils BuildRequires: python3-snowballstemmer BuildRequires: python3-babel BuildRequires: python3-sphinx-theme-alabaster BuildRequires: python3-imagesize BuildRequires: python3-requests BuildRequires: python3-packaging BuildRequires: python3-sphinxcontrib-websupport Requires: python-sphinx-locale = %{version}-%{release} Requires: python3-six Requires: python3-jinja2 Requires: python3-pygments Requires: python3-docutils Requires: python3-snowballstemmer Requires: python3-babel Requires: python3-sphinx-theme-alabaster Requires: python3-imagesize Requires: python3-requests Requires: python3-packaging Requires: python3-sphinxcontrib-websupport %description -n python3-sphinx Sphinx is a tool that makes it easy to create intelligent and beautiful documentation for Python projects (or other documents consisting of multiple reStructuredText sources), written by Georg Brandl. It was originally created to translate the new Python documentation, but has now been cleaned up in the hope that it will be useful to many other projects. Sphinx uses reStructuredText as its markup language, and many of its strengths come from the power and straightforwardness of reStructuredText and its parsing and translating suite, the Docutils. Although it is still under constant development, the following features are already present, work fine and can be seen "in action" in the Python docs: * Output formats: HTML (including Windows HTML Help) and LaTeX, for printable PDF versions * Extensive cross-references: semantic markup and automatic links for functions, classes, glossary terms and similar pieces of information * Hierarchical structure: easy definition of a document tree, with automatic links to siblings, parents and children * Automatic indices: general index as well as a module index * Code handling: automatic highlighting using the Pygments highlighter * Various extensions are available, e.g. for automatic testing of snippets and inclusion of appropriately formatted docstrings. %package locale Summary: Locale files for %{name} Group: Development/Tools License: BSD %description locale Sphinx is a tool that makes it easy to create intelligent and beautiful documentation for Python projects (or other documents consisting of multiple reStructuredText sources), written by Georg Brandl. It was originally created to translate the new Python documentation, but has now been cleaned up in the hope that it will be useful to many other projects. This package contains locale files for Sphinx %package doc Summary: Documentation for %{name} Group: Documentation License: BSD Requires: %{name} = %{version}-%{release} %description doc Sphinx is a tool that makes it easy to create intelligent and beautiful documentation for Python projects (or other documents consisting of multiple reStructuredText sources), written by Georg Brandl. It was originally created to translate the new Python documentation, but has now been cleaned up in the hope that it will be useful to many other projects. This package contains documentation in reST and HTML formats. %prep %autosetup -n %{upstream_name}-%{version} -p1 cp %{SOURCE5} . # fix line encoding of bundled jquery.js perl -pi -e 's/\r//' ./sphinx/themes/basic/static/jquery.js %if 0%{?with_python3} rm -rf %{py3dir} cp -a . %{py3dir} %endif # with_python3 %build %{py_build} %{py3_build} export PYTHONPATH=$PWD pushd doc export SPHINXBUILD="%{__python3} ../sphinx/cmd/build.py" make html SPHINXBUILD="$SPHINXBUILD" make man SPHINXBUILD="$SPHINXBUILD" rm -rf _build/html/.buildinfo mv _build/html .. popd %install %__rm -rf %{buildroot} %{py3_install} install -d %{buildroot}%{_libexecdir}/python3-sphinx for i in sphinx-{apidoc,autogen,build,quickstart}; do mv %{buildroot}%{_bindir}/$i %{buildroot}%{_bindir}/$i-%{python3_version} ln -s $i-%{python3_version} %{buildroot}%{_bindir}/$i-3 ln -s %{_bindir}/$i-3 %{buildroot}%{_libexecdir}/python3-sphinx/$i done %{py_install} install -d %{buildroot}%{_libexecdir}/python2-sphinx install -d %{buildroot}%{_libexecdir}/python2-sphinx for i in sphinx-{apidoc,autogen,build,quickstart}; do mv %{buildroot}%{_bindir}/$i %{buildroot}%{_bindir}/$i-%{python_version} ln -s $i-%{python_version} %{buildroot}%{_bindir}/$i-2 ln -s %{_bindir}/$i-2 %{buildroot}%{_libexecdir}/python2-sphinx/$i done pushd doc # Deliver man pages install -d %{buildroot}%{_mandir}/man1 for f in _build/man/sphinx-*.1; do ### TODO: these are all the same. Do we really need to ship them three ### times or is it fine to just ship them as e.g. sphinx-build.1 cp -p $f %{buildroot}%{_mandir}/man1/$(basename $f) cp -p $f %{buildroot}%{_mandir}/man1/$(basename $f | sed -e "s|.1$|-%{python_version}.1|") cp -p $f %{buildroot}%{_mandir}/man1/$(basename $f | sed -e "s|.1$|-%{python3_version}.1|") done # Remove language files, they're identical to the ones from the # Python 2 build that will be moved to /usr/share below find %{buildroot}%{python3_sitelib}/sphinx/locale -maxdepth 1 -mindepth 1 -type d -not -path '*/\.*' -exec rm -rf '{}' \; popd # Clean up non-python files rm -f %{buildroot}%{python_sitelib}/sphinx/locale/.DS_Store rm -rf %{buildroot}%{python_sitelib}/sphinx/locale/.tx rm -f %{buildroot}%{python3_sitelib}/sphinx/locale/.DS_Store rm -rf %{buildroot}%{python3_sitelib}/sphinx/locale/.tx # Deliver rst files rm -rf doc/_build sed -i 's|python ../sphinx-build.py|/usr/bin/sphinx-build|' doc/Makefile mv doc reST # Move language files to /usr/share; # patch to support this incorporated in 0.6.6 pushd %{buildroot}%{python_sitelib} for lang in `find sphinx/locale -maxdepth 1 -mindepth 1 -type d -not -path '*/\.*' -printf "%f "`; do install -d %{buildroot}%{_datadir}/sphinx/locale/$lang install -d %{buildroot}%{_datadir}/locale/$lang/LC_MESSAGES mv sphinx/locale/$lang/LC_MESSAGES/sphinx.js \ %{buildroot}%{_datadir}/sphinx/locale/$lang/ mv sphinx/locale/$lang/LC_MESSAGES/sphinx.mo \ %{buildroot}%{_datadir}/locale/$lang/LC_MESSAGES/ rm -rf sphinx/locale/$lang done popd #install -d %{buildroot}%{_modulesdir}/python-sphinx #install -m 0644 %{SOURCE1} %{buildroot}%{_modulesdir}/python-sphinx/ #sed -i 's|@python2_sphinx_dir@|%{_libexecdir}/python2-sphinx|' %{buildroot}%{_modulesdir}/python-sphinx/python2-sphinx #install -m 0644 %{SOURCE2} %{buildroot}%{_modulesdir}/python-sphinx/ #sed -i 's|@python3_sphinx_dir@|%{_libexecdir}/python3-sphinx|' %{buildroot}%{_modulesdir}/python-sphinx/python3-sphinx install -d %{buildroot}%{_sysconfdir}/profile.d install -m 0644 %{SOURCE3} %{buildroot}%{_sysconfdir}/profile.d/zz-modules-python-sphinx.sh install -m 0644 %{SOURCE4} %{buildroot}%{_sysconfdir}/profile.d/zz-modules-python-sphinx.csh %if %{py3_default} #sed 's/@PYTHONVER@/3/' < %{SOURCE6} > %{buildroot}%{_modulesdir}/python-sphinx/.version # These symlinks establish a default for when a package is first installed (and # therefore, environment modules is not loaded). The user can immediately # switch them by using module swap python-sphinx/python2-sphinx for filename in sphinx-{build,apidoc,autogen,quickstart} ; do ln -s %{_libexecdir}/python3-sphinx/$filename %{buildroot}%{_bindir}/$filename done %else #sed 's/@PYTHONVER@/2/' < %{SOURCE6} > %{buildroot}%{_modulesdir}/python-sphinx/.version # These symlinks establish a default for when a package is first installed (and # therefore, environment modules is not loaded). The user can immediately # switch them by using module swap python-sphinx/python3-sphinx for filename in sphinx-{build,apidoc,autogen,quickstart} ; do ln -s %{_libexecdir}/python2-sphinx/$filename %{buildroot}%{_bindir}/$filename done %endif %find_lang sphinx # Language files; Since these are javascript, it's not immediately obvious to # find_lang that they need to be marked with a language. (cd %{buildroot} && find . -name 'sphinx.js') | sed -e 's|^.||' | sed -e \ 's:\(.*/locale/\)\([^/_]\+\)\(.*\.js$\):%lang(\2) \1\2\3:' \ >> sphinx.lang %clean %__rm -rf %{buildroot} %check #__make test %files %defattr(-,root,root,-) %license LICENSE %doc AUTHORS CHANGES EXAMPLES README.* %{_bindir}/sphinx-*-2* %{_bindir}/sphinx-build %{_bindir}/sphinx-apidoc %{_bindir}/sphinx-autogen %{_bindir}/sphinx-quickstart %{python_sitelib}/sphinx/ %{python_sitelib}/Sphinx-%{version}-py%{python_version}.egg-info/ %exclude %{_mandir}/man1/sphinx-*-%{python3_version}.1* %{_mandir}/man1/* %{_libexecdir}/python2-sphinx/ #{_modulesdir}/python-sphinx/python2-sphinx %if !%{py3_default} #{_modulesdir}/python-sphinx/.version %endif %config(noreplace) %{_sysconfdir}/profile.d/zz-modules-python-sphinx.sh %config(noreplace) %{_sysconfdir}/profile.d/zz-modules-python-sphinx.csh %files -n python3-sphinx %license LICENSE %doc AUTHORS CHANGES EXAMPLES README.* %{_bindir}/sphinx-*-3* %{python3_sitelib}/sphinx/ %{python3_sitelib}/Sphinx-%{version}-py%{python3_version}.egg-info/ %{_mandir}/man1/sphinx-*-%{python3_version}.1* %{_libexecdir}/python3-sphinx/ #{_modulesdir}/python-sphinx/python3-sphinx %if %{py3_default} #{_modulesdir}/python-sphinx/.version %endif %config(noreplace) %{_sysconfdir}/profile.d/zz-modules-python-sphinx.sh %config(noreplace) %{_sysconfdir}/profile.d/zz-modules-python-sphinx.csh %files locale -f sphinx.lang %license LICENSE %dir %{_datadir}/sphinx/ %dir %{_datadir}/sphinx/locale %dir %{_datadir}/sphinx/locale/* %files doc %defattr(-,root,root,-) %doc html reST %changelog * Thu Nov 29 2018 Tomohiro "Tomo-p" KATO 1.7.9-2 - fixed R:. * Wed Nov 28 2018 Tomohiro "Tomo-p" KATO 1.7.9-1 - new upstream release. - dropped Patch2. - imported Patch0-1 from rawhide. - added python3 support. * Wed May 09 2018 Toshiaki Ara 1.1.3-3 - added patch2 from RedHat * Thu Jul 2 2015 Tomohiro "Tomo-p" KATO 1.1.3-2 - added patch0. * Sun Jun 30 2013 Toshiharu Kudoh 1.1.3-1 - new upstream release * Sun Feb 19 2012 Yoji TOYODA 1.0.7-2 - rebuild with python-2.7.2 * Thu May 5 2011 IWAI, Masaharu 1.0.7-1 - new upstream release - add BuildRequires: python-simplejson for Vine5 - add Vendor and Distribution tags * Wed Dec 01 2010 Shu KONNO 1.0.5-1 - update sphinx to 1.0.5 * Mon Aug 23 2010 Munehiro Yamamoto 1.0-1.b2 - initial build based on Fedora development * Thu Jul 22 2010 David Malcolm - 1.0-0.1.b2.1 - Rebuilt for https://fedoraproject.org/wiki/Features/Python_2.7/MassRebuild * Mon May 31 2010 Toshio Kuratomi - 1.0-0.2.b2 - Update to 1.0 beta 2 - Fixes problem building html documentation in non-English locales * Wed May 26 2010 Michel Salim - 1.0-0.1.b1 - Update to 1.0 beta 1 * Tue May 25 2010 Michel Salim - 0.6.6-1 - Update to 0.6.6 * Fri May 21 2010 Toshio Kuratomi - 0.6.5-2 - Few minor tweaks to Gareth's spec file update * Mon May 10 2010 Gareth Armstrong - 0.6.5-1.hp - Update to 0.6.5 - Initial import of python-sphinx from Fedora Rawhide for use in HP CMS - Enforce that Sphinx requires Python 2.4 or later via an explicit BR - Minor tweaks to spec file - Move language files to %%{_datadir}, idea borrowed from Debian's sphinx package - Deliver man pages for sphinx-build & sphinx-quickstart - Deliver rst documentation files to reST directory in doc sub-package - Add %%check section for Python2 and add BR on python-nose * Wed Jan 13 2010 Toshio Kuratomi - 0.6.4-1 - Update to 0.6.4 - Fixes a problem using autodoc with pylons projects. * Fri Sep 4 2009 Michel Salim - 0.6.3-1 - Update to 0.6.3 * Mon Aug 17 2009 Toshio Kuratomi - 0.6.2-1 - Update to 0.6.2 -- upstream bugfix requested inside bz#512438 * Sun Jul 26 2009 Fedora Release Engineering - 0.6.1-3 - Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild * Fri Jun 05 2009 Luke Macken - 0.6.1-2 - Add a patch to use our own setuptools package * Fri Apr 17 2009 Michel Salim - 0.6.1-1 - Update to 0.6.1 * Thu Feb 26 2009 Fedora Release Engineering - 0.5.1-2 - Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild * Fri Jan 2 2009 Michel Salim - 0.5.1-1 - Update to 0.5.1 * Sat Nov 29 2008 Ignacio Vazquez-Abrams - 0.5-2 - Rebuild for Python 2.6 * Mon Nov 24 2008 Michel Salim - 0.5-1 - Update to 0.5 * Fri Oct 10 2008 Michel Salim - 0.4.3-1 - Update to 0.4.3 * Wed Aug 27 2008 Toshio Kuratomi - 0.4.2-1.1 - Fix for EL-5 build. * Mon Aug 25 2008 Michel Salim - 0.4.2-1 - Update to 0.4.2 * Mon May 26 2008 Michel Salim - 0.3-1 - Update to 0.3 * Fri May 2 2008 Michel Salim - 0.1.61950-3 - Split documentation into subpackage - Exclude C files (not built by default anyway) * Wed Apr 16 2008 José Matos - 0.1.61950-2 - Build html documentation, include it and include the rst documentation. * Thu Mar 27 2008 Michel Salim 0.1.61950-1 - Initial package