From 1d88842d44152834872927ceb9b96eb9e4083cb8 Mon Sep 17 00:00:00 2001 From: Benjamin A. Beasley Date: Mar 16 2021 21:42:09 +0000 Subject: Initial package --- diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..5c58b5e --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/asyncpg-0.22.0.tar.gz diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..b9a48b3 --- /dev/null +++ b/Makefile @@ -0,0 +1,225 @@ +# Makefile for Sphinx documentation +# + +# You can set these variables from the command line. +SPHINXOPTS = +SPHINXBUILD = python -m sphinx +PAPER = +BUILDDIR = _build + +# Internal variables. +PAPEROPT_a4 = -D latex_paper_size=a4 +PAPEROPT_letter = -D latex_paper_size=letter +ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . +# the i18n builder cannot share the environment and doctrees with the others +I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . + +.PHONY: help +help: + @echo "Please use \`make ' where is one of" + @echo " html to make standalone HTML files" + @echo " dirhtml to make HTML files named index.html in directories" + @echo " singlehtml to make a single large HTML file" + @echo " pickle to make pickle files" + @echo " json to make JSON files" + @echo " htmlhelp to make HTML files and a HTML help project" + @echo " qthelp to make HTML files and a qthelp project" + @echo " applehelp to make an Apple Help Book" + @echo " devhelp to make HTML files and a Devhelp project" + @echo " epub to make an epub" + @echo " epub3 to make an epub3" + @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter" + @echo " latexpdf to make LaTeX files and run them through pdflatex" + @echo " latexpdfja to make LaTeX files and run them through platex/dvipdfmx" + @echo " text to make text files" + @echo " man to make manual pages" + @echo " texinfo to make Texinfo files" + @echo " info to make Texinfo files and run them through makeinfo" + @echo " gettext to make PO message catalogs" + @echo " changes to make an overview of all changed/added/deprecated items" + @echo " xml to make Docutils-native XML files" + @echo " pseudoxml to make pseudoxml-XML files for display purposes" + @echo " linkcheck to check all external links for integrity" + @echo " doctest to run all doctests embedded in the documentation (if enabled)" + @echo " coverage to run coverage check of the documentation (if enabled)" + @echo " dummy to check syntax errors of document sources" + +.PHONY: clean +clean: + rm -rf $(BUILDDIR)/* + +.PHONY: html +html: + $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/html." + +.PHONY: dirhtml +dirhtml: + $(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml." + +.PHONY: singlehtml +singlehtml: + $(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml + @echo + @echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml." + +.PHONY: pickle +pickle: + $(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle + @echo + @echo "Build finished; now you can process the pickle files." + +.PHONY: json +json: + $(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json + @echo + @echo "Build finished; now you can process the JSON files." + +.PHONY: htmlhelp +htmlhelp: + $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp + @echo + @echo "Build finished; now you can run HTML Help Workshop with the" \ + ".hhp project file in $(BUILDDIR)/htmlhelp." + +.PHONY: qthelp +qthelp: + $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp + @echo + @echo "Build finished; now you can run "qcollectiongenerator" with the" \ + ".qhcp project file in $(BUILDDIR)/qthelp, like this:" + @echo "# qcollectiongenerator $(BUILDDIR)/qthelp/asyncpg.qhcp" + @echo "To view the help file:" + @echo "# assistant -collectionFile $(BUILDDIR)/qthelp/asyncpg.qhc" + +.PHONY: applehelp +applehelp: + $(SPHINXBUILD) -b applehelp $(ALLSPHINXOPTS) $(BUILDDIR)/applehelp + @echo + @echo "Build finished. The help book is in $(BUILDDIR)/applehelp." + @echo "N.B. You won't be able to view it unless you put it in" \ + "~/Library/Documentation/Help or install it in your application" \ + "bundle." + +.PHONY: devhelp +devhelp: + $(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp + @echo + @echo "Build finished." + @echo "To view the help file:" + @echo "# mkdir -p $$HOME/.local/share/devhelp/asyncpg" + @echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/asyncpg" + @echo "# devhelp" + +.PHONY: epub +epub: + $(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub + @echo + @echo "Build finished. The epub file is in $(BUILDDIR)/epub." + +.PHONY: epub3 +epub3: + $(SPHINXBUILD) -b epub3 $(ALLSPHINXOPTS) $(BUILDDIR)/epub3 + @echo + @echo "Build finished. The epub3 file is in $(BUILDDIR)/epub3." + +.PHONY: latex +latex: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo + @echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex." + @echo "Run \`make' in that directory to run these through (pdf)latex" \ + "(use \`make latexpdf' here to do that automatically)." + +.PHONY: latexpdf +latexpdf: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo "Running LaTeX files through pdflatex..." + $(MAKE) -C $(BUILDDIR)/latex all-pdf + @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex." + +.PHONY: latexpdfja +latexpdfja: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo "Running LaTeX files through platex and dvipdfmx..." + $(MAKE) -C $(BUILDDIR)/latex all-pdf-ja + @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex." + +.PHONY: text +text: + $(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text + @echo + @echo "Build finished. The text files are in $(BUILDDIR)/text." + +.PHONY: man +man: + $(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man + @echo + @echo "Build finished. The manual pages are in $(BUILDDIR)/man." + +.PHONY: texinfo +texinfo: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo + @echo "Build finished. The Texinfo files are in $(BUILDDIR)/texinfo." + @echo "Run \`make' in that directory to run these through makeinfo" \ + "(use \`make info' here to do that automatically)." + +.PHONY: info +info: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo "Running Texinfo files through makeinfo..." + make -C $(BUILDDIR)/texinfo info + @echo "makeinfo finished; the Info files are in $(BUILDDIR)/texinfo." + +.PHONY: gettext +gettext: + $(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale + @echo + @echo "Build finished. The message catalogs are in $(BUILDDIR)/locale." + +.PHONY: changes +changes: + $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes + @echo + @echo "The overview file is in $(BUILDDIR)/changes." + +.PHONY: linkcheck +linkcheck: + $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck + @echo + @echo "Link check complete; look for any errors in the above output " \ + "or in $(BUILDDIR)/linkcheck/output.txt." + +.PHONY: doctest +doctest: + $(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest + @echo "Testing of doctests in the sources finished, look at the " \ + "results in $(BUILDDIR)/doctest/output.txt." + +.PHONY: coverage +coverage: + $(SPHINXBUILD) -b coverage $(ALLSPHINXOPTS) $(BUILDDIR)/coverage + @echo "Testing of coverage in the sources finished, look at the " \ + "results in $(BUILDDIR)/coverage/python.txt." + +.PHONY: xml +xml: + $(SPHINXBUILD) -b xml $(ALLSPHINXOPTS) $(BUILDDIR)/xml + @echo + @echo "Build finished. The XML files are in $(BUILDDIR)/xml." + +.PHONY: pseudoxml +pseudoxml: + $(SPHINXBUILD) -b pseudoxml $(ALLSPHINXOPTS) $(BUILDDIR)/pseudoxml + @echo + @echo "Build finished. The pseudo-XML files are in $(BUILDDIR)/pseudoxml." + +.PHONY: dummy +dummy: + $(SPHINXBUILD) -b dummy $(ALLSPHINXOPTS) $(BUILDDIR)/dummy + @echo + @echo "Build finished. Dummy builder generates no files." diff --git a/python-asyncpg.spec b/python-asyncpg.spec new file mode 100644 index 0000000..a47f884 --- /dev/null +++ b/python-asyncpg.spec @@ -0,0 +1,155 @@ +%global srcname asyncpg + +Name: python-%{srcname} +Summary: A fast PostgreSQL Database Client Library for Python/asyncio +Version: 0.22.0 +Release: 2%{?dist} + +License: ASL 2.0 +URL: https://github.com/MagicStack/%{srcname} +Source0: %{pypi_source} +# Temporary workaround; see https://github.com/MagicStack/asyncpg/pull/708. +Source1: https://raw.githubusercontent.com/MagicStack/%{srcname}/v%{version}/docs/Makefile +Source2: https://raw.githubusercontent.com/MagicStack/%{srcname}/v%{version}/docs/_static/theme_overrides.css + +BuildRequires: gcc +BuildRequires: python3-devel +BuildRequires: python3dist(setuptools) +BuildRequires: pyproject-rpm-macros +BuildRequires: python3-docs + +BuildRequires: make + +# For tests: +# +# For pg_config binary +BuildRequires: libpq-devel +# For pg_ctl binary +BuildRequires: postgresql-server +# For citext extension +BuildRequires: postgresql-contrib + +# Note that asyncpg/pgproto comes from a git submodule referencing a separate +# project, https://github.com/MagicStack/py-pgproto. However, we do not treat +# it as a bundled dependency because it contains only sources; it has no build +# system and is not designed for separate installation; and it is managed as a +# part of the asyncpg package, as evidenced by the comment “This module is part +# of asyncpg” in the file headers. + +%global common_description %{expand: +asyncpg is a database interface library designed specifically for PostgreSQL +and Python/asyncio. asyncpg is an efficient, clean implementation of PostgreSQL +server binary protocol for use with Python’s asyncio framework. You can read +more about asyncpg in an introductory blog post +http://magic.io/blog/asyncpg-1m-rows-from-postgres-to-python/.} + +%description %{common_description} + + +%generate_buildrequires +%pyproject_buildrequires -x dev + + +%package -n python3-%{srcname} +Summary: %{summary} + +Requires: python3-docs + + +%description -n python3-%{srcname} %{common_description} + + +%package doc +Summary: Documentation for %{name} + +BuildArch: noarch + +%description doc %{common_description} + + +%prep +%autosetup -n %{srcname}-%{version} +rm -rvf %{srcname}.egg-info + +# Remove pre-generated C sources from Cython to ensure they are re-generated +# and not used in the build. Note that recordobj.c is not a generated source, +# and must not be removed! +find %{srcname} -type f -name '*.c' ! -name 'recordobj.c' -print -delete + +# Loosen pinned versions in setup.py +sed -r -i 's/~=/>=/g' setup.py + +cp -p '%{SOURCE1}' docs/ +mkdir -p docs/_static +cp -p '%{SOURCE2}' docs/_static/ + +# Use local inventory in intersphinx mapping: +sed -r -i 's|https://docs.python.org/3|/%{_docdir}/python3-docs/html|' \ + docs/conf.py + + +%build +%set_build_flags +%py3_build + +# Temporary local installation so we can import the Cython extension module to +# build documentation: +PYROOT="${PWD}/%{_vpath_builddir}/pyroot" +%{__python3} %{py_setup} %{?py_setup_args} install \ + -O1 --skip-build --root "${PYROOT}" +export PYTHONPATH="${PYROOT}%{python3_sitearch}" + +%make_build -C docs html \ + SPHINXBUILD='sphinx-build' \ + SPHINXOPTS='%{?_smp_mflags}' +rm -vf docs/_build/html/.buildinfo docs/_build/html/.nojekyll + + +%install +%py3_install +# The Cython implementation files (.pyx) and Cython-generated C sources (.c) +# are included in the installed package. These are definitely not needed. +# +# The C header files (.h) and Cython definition files (.pxd) would be needed to +# compile Cython extension code using the internal APIs of the package. The +# upstream documentation does not indicate that this is an intended use, so we +# do not ship them. If we did, we would need to put them in a new subpackage +# called python3-%%{srcname}-devel. +find %{buildroot}%{python3_sitearch} -type f \( \ + -name '*.pyx' -o -name '*.c' \ + -o -name '*.pxd' -o -name '*.h' \ + \) -print -delete + + +%check +# It is not clear why the tests always import asyncpg as ../asyncpg/__init__.py +# even if we set PYTHONPATH to the installed sitearch directory. This +# workaround is ugly, but there is nothing actually wrong with it, as the +# install is already done by the time the check section runs: +rm -rf %{srcname} +ln -s %{buildroot}%{python3_sitearch}/%{srcname}/ + +# Do not run flake8 code style tests (which may fail) +k='not TestFlake8' + +%pytest -k "${k}" + + +%files -n python3-%{srcname} +%license LICENSE +%{python3_sitearch}/%{srcname} +%{python3_sitearch}/%{srcname}-%{version}-py%{python3_version}.egg-info + + +%files doc +%license LICENSE +%doc README.rst +%doc docs/_build/html + + +%changelog +* Wed Mar 03 2021 Benjamin A. Beasley - 0.22.0-2 +- Fix intersphinx inventory path + +* Tue Mar 02 2021 Benjamin A. Beasley - 0.22.0-1 +- Initial package diff --git a/sources b/sources new file mode 100644 index 0000000..988db9c --- /dev/null +++ b/sources @@ -0,0 +1 @@ +SHA512 (asyncpg-0.22.0.tar.gz) = b953290e10ea408ad67ac28f394bb3aaf84c4e42d136f0af9e2f7befcf03e34faf46ef1806c98099453028963142a6e3bce63ff3cbe118b2026744de2103eb37 diff --git a/theme_overrides.css b/theme_overrides.css new file mode 100644 index 0000000..aaf464f --- /dev/null +++ b/theme_overrides.css @@ -0,0 +1,12 @@ +/* override table width restrictions */ +@media screen and (min-width: 767px) { + + .wy-table-responsive table td { + white-space: normal !important; + vertical-align: top !important; + } + + .wy-table-responsive { + overflow: visible !important; + } +}