From af639f91f7041c4deb07cf568b26750bcde74bee Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 May 2020 00:34:39 +0200 Subject: [PATCH 01/12] Fix weblogolib -> weblogo name change --- pbxplore/analysis/visualization.py | 18 +++++++++--------- pbxplore/scripts/PBstat.py | 2 +- pbxplore/tests/__init__.py | 2 +- pbxplore/tests/test_regression.py | 2 +- 4 files changed, 12 insertions(+), 12 deletions(-) diff --git a/pbxplore/analysis/visualization.py b/pbxplore/analysis/visualization.py index 2a92986..7d8ceaa 100644 --- a/pbxplore/analysis/visualization.py +++ b/pbxplore/analysis/visualization.py @@ -15,14 +15,14 @@ import matplotlib.pyplot as plt try: - import weblogolib + import weblogo # Weblogo compatibility # With version < 3.5, the color class is 'ColorGroup'. In version >= 3.5, # it is 'SymbolColor'. Here, we change to always have 'ColorGroup'. try: - ColorGroup = weblogolib.SymbolColor + ColorGroup = weblogo.SymbolColor except AttributeError: - ColorGroup = weblogolib.ColorGroup + ColorGroup = weblogo.ColorGroup except ImportError: IS_WEBLOGO = False else: @@ -221,22 +221,22 @@ def generate_weblogo(fname, count_mat, idx_first_residue=1, residue_min=1, resid count = utils._slice_matrix(count_mat, idx_first_residue, residue_min, residue_max) # Create a custom color scheme for PB - colors = weblogolib.ColorScheme([ColorGroup("d", "#1240AB", "strand main"), + colors = weblogo.ColorScheme([ColorGroup("d", "#1240AB", "strand main"), ColorGroup("abcdef", "#1240AB", "strand others"), ColorGroup("ghij", "#0BD500", "coil"), ColorGroup("m", "#FD0006", "helix main"), ColorGroup("klnop", "#FD0006", "helix others")]) # Load data from an occurence matrix - data = weblogolib.LogoData.from_counts(PB.NAMES, count) + data = weblogo.LogoData.from_counts(PB.NAMES, count) # Create options - options = weblogolib.LogoOptions(fineprint=False, logo_title=title, color_scheme=colors, - stack_width=weblogolib.std_sizes["large"], + options = weblogo.LogoOptions(fineprint=False, logo_title=title, color_scheme=colors, + stack_width=weblogo.std_sizes["large"], first_residue=residue_min) # Generate weblogo - logo = weblogolib.LogoFormat(data, options) + logo = weblogo.LogoFormat(data, options) # Retrieve image format image_format = os.path.splitext(fname)[1][1:] @@ -245,7 +245,7 @@ def generate_weblogo(fname, count_mat, idx_first_residue=1, residue_min=1, resid try: if image_format == 'jpg': image_format = 'jpeg' - formatter = weblogolib.formatters[image_format] + formatter = weblogo.formatters[image_format] except KeyError: raise ValueError("Invalid format image '{0}'." " Valid ones are : eps, png, pdf, jpg/jpeg, svg".format(image_format)) diff --git a/pbxplore/scripts/PBstat.py b/pbxplore/scripts/PBstat.py index 12ae894..c8c55d4 100755 --- a/pbxplore/scripts/PBstat.py +++ b/pbxplore/scripts/PBstat.py @@ -25,7 +25,7 @@ # Weblogolib is an optional requirement try: - import weblogolib + import weblogo except: IS_WEBLOGO = False else: diff --git a/pbxplore/tests/__init__.py b/pbxplore/tests/__init__.py index 1f02bd9..3a12468 100644 --- a/pbxplore/tests/__init__.py +++ b/pbxplore/tests/__init__.py @@ -37,7 +37,7 @@ def system_info(): module_info("numpy") module_info("MDAnalysis") module_info("matplotlib") - module_info("weblogolib") + module_info("weblogo") py_version = sys.version.replace('\n', '') print("Python version {0}".format(py_version)) diff --git a/pbxplore/tests/test_regression.py b/pbxplore/tests/test_regression.py index 3b44c22..23326f2 100644 --- a/pbxplore/tests/test_regression.py +++ b/pbxplore/tests/test_regression.py @@ -31,7 +31,7 @@ try: - import weblogolib + import weblogo IS_WEBLOGO = True except ImportError: IS_WEBLOGO = False From 6c6b0872031c0df943ed1b1a3cbe738c92531572 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 May 2020 00:39:31 +0200 Subject: [PATCH 02/12] Fix None type comparison by pytest --- pbxplore/tests/test_functions.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pbxplore/tests/test_functions.py b/pbxplore/tests/test_functions.py index 25c080a..1df3e3e 100644 --- a/pbxplore/tests/test_functions.py +++ b/pbxplore/tests/test_functions.py @@ -252,7 +252,7 @@ def test_get_phi_psi_angles(self, chain, resid, angles): Tests for get_phi_psi_angles() """ phi_psi = chain.get_phi_psi_angles() - assert angles["phi"] == pytest.approx(phi_psi[resid]["phi"]) + assert (angles["phi"] is None and phi_psi[resid]["phi"] is None) or angles["phi"] == pytest.approx(phi_psi[resid]["phi"]) def test_set_coordinates(self, chain): """ From 3833a95f2bd63d75510910f57da9f88c611227ff Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 May 2020 01:30:10 +0200 Subject: [PATCH 03/12] Convert code from python 2 to python 3 --- doc/source/conf.py | 14 +++++++------- pbxplore/PB.py | 2 +- pbxplore/__init__.py | 2 +- pbxplore/analysis/compare.py | 2 +- pbxplore/analysis/count.py | 2 +- pbxplore/analysis/neq.py | 2 +- pbxplore/analysis/utils.py | 4 ++-- pbxplore/analysis/visualization.py | 4 ++-- pbxplore/assignment.py | 2 +- pbxplore/io/fasta.py | 2 +- pbxplore/io/write.py | 2 +- pbxplore/scripts/PBassign.py | 2 +- pbxplore/scripts/PBcount.py | 2 +- pbxplore/scripts/PBstat.py | 2 +- pbxplore/structure/PDB.py | 2 +- pbxplore/structure/loader.py | 2 +- pbxplore/structure/structure.py | 4 ++-- pbxplore/tests/__init__.py | 10 +++++----- pbxplore/tests/test_regression.py | 2 +- setup.py | 2 +- 20 files changed, 33 insertions(+), 33 deletions(-) diff --git a/doc/source/conf.py b/doc/source/conf.py index ed66ed9..e512841 100644 --- a/doc/source/conf.py +++ b/doc/source/conf.py @@ -15,8 +15,8 @@ import sys import os -AUTHORS = [u'Jonathan Barnoud', u'Hubert Santuz', - u'Alexandre G. de Brevern', u'Pierre Poulain'] +AUTHORS = ['Jonathan Barnoud', 'Hubert Santuz', + 'Alexandre G. de Brevern', 'Pierre Poulain'] # If extensions (or modules to document with autodoc) are in another directory, # add these directories to sys.path here. If the directory is relative to the @@ -52,8 +52,8 @@ master_doc = 'index' # General information about the project. -project = u'PBxplore' -copyright = u'2017, Jonathan Barnoud, Hubert Santuz, Alexandre G. de Brevern, and Pierre Poulain' +project = 'PBxplore' +copyright = '2017, Jonathan Barnoud, Hubert Santuz, Alexandre G. de Brevern, and Pierre Poulain' # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the @@ -209,7 +209,7 @@ # (source start file, target name, title, # author, documentclass [howto, manual, or own class]). latex_documents = [ - ('ind', 'PBxploreAPI.tex', u'PBxplore API Documentation', + ('ind', 'PBxploreAPI.tex', 'PBxplore API Documentation', ' '.join(AUTHORS), 'manual'), ] @@ -239,7 +239,7 @@ # One entry per manual page. List of tuples # (source start file, name, description, authors, manual section). man_pages = [ - ('ind', 'pbxploreapi', u'PBxplore API Documentation', + ('ind', 'pbxploreapi', 'PBxplore API Documentation', AUTHORS, 1) ] @@ -253,7 +253,7 @@ # (source start file, target name, title, author, # dir menu entry, description, category) texinfo_documents = [ - ('ind', 'PBxploreAPI', u'PBxplore API Documentation', + ('ind', 'PBxploreAPI', 'PBxplore API Documentation', ' '.join(AUTHORS), 'PBxploreAPI', 'One line description of project.', 'Miscellaneous'), ] diff --git a/pbxplore/PB.py b/pbxplore/PB.py index e565c8e..cd92668 100644 --- a/pbxplore/PB.py +++ b/pbxplore/PB.py @@ -31,7 +31,7 @@ .. autoexception:: InvalidBlockError """ -from __future__ import print_function, absolute_import + # Standard modules import os diff --git a/pbxplore/__init__.py b/pbxplore/__init__.py index eb40ff1..7f4c68e 100644 --- a/pbxplore/__init__.py +++ b/pbxplore/__init__.py @@ -40,7 +40,7 @@ def test(): #Get informations about system tests.system_info() - print("pytest version {}".format(pytest.__version__)) + print(("pytest version {}".format(pytest.__version__))) # run pytest try: diff --git a/pbxplore/analysis/compare.py b/pbxplore/analysis/compare.py index 119b980..4399b4d 100644 --- a/pbxplore/analysis/compare.py +++ b/pbxplore/analysis/compare.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Third-party module import numpy diff --git a/pbxplore/analysis/count.py b/pbxplore/analysis/count.py index 0aad760..7c2024b 100644 --- a/pbxplore/analysis/count.py +++ b/pbxplore/analysis/count.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Third-party module diff --git a/pbxplore/analysis/neq.py b/pbxplore/analysis/neq.py index 2133f58..e7f9aa7 100644 --- a/pbxplore/analysis/neq.py +++ b/pbxplore/analysis/neq.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard modules import math diff --git a/pbxplore/analysis/utils.py b/pbxplore/analysis/utils.py index a18f8df..6b8e598 100644 --- a/pbxplore/analysis/utils.py +++ b/pbxplore/analysis/utils.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Local module @@ -60,7 +60,7 @@ def _slice_matrix(mat, idx_first_residue=1, residue_min=1, residue_max=None): # Take in account the optional offset (idx_first_residue) # range of indexes of the matrix - residues_idx = range(idx_first_residue, mat.shape[0] + idx_first_residue) + residues_idx = list(range(idx_first_residue, mat.shape[0] + idx_first_residue)) if residue_min not in residues_idx or residue_max not in residues_idx: raise IndexError("Index out of range") diff --git a/pbxplore/analysis/visualization.py b/pbxplore/analysis/visualization.py index 2a92986..b0c076a 100644 --- a/pbxplore/analysis/visualization.py +++ b/pbxplore/analysis/visualization.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard modules import os @@ -162,7 +162,7 @@ def plot_map(fname, count_mat, idx_first_residue=1, residue_min=1, residue_max=N # add ticks and labels ax2.set_xticks(xticks - numpy.min(xticks)) ax2.set_xticklabels(xticks) - ax2.set_yticks(range(len(yticks))) + ax2.set_yticks(list(range(len(yticks)))) ax2.set_yticklabels(yticks, style='italic', weight='bold') ax2.set_xlabel("Residue number", weight="bold") diff --git a/pbxplore/assignment.py b/pbxplore/assignment.py index 24f3b93..56f1eba 100644 --- a/pbxplore/assignment.py +++ b/pbxplore/assignment.py @@ -8,7 +8,7 @@ .. autofunction:: assign """ -from __future__ import print_function, absolute_import + # Third-party module import numpy diff --git a/pbxplore/io/fasta.py b/pbxplore/io/fasta.py index 8167981..4aa6039 100644 --- a/pbxplore/io/fasta.py +++ b/pbxplore/io/fasta.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard modules import os diff --git a/pbxplore/io/write.py b/pbxplore/io/write.py index 7d9fe3c..ca9f0ad 100644 --- a/pbxplore/io/write.py +++ b/pbxplore/io/write.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard modules # import os diff --git a/pbxplore/scripts/PBassign.py b/pbxplore/scripts/PBassign.py index dcdc551..cf69830 100755 --- a/pbxplore/scripts/PBassign.py +++ b/pbxplore/scripts/PBassign.py @@ -8,7 +8,7 @@ """ # Use print as a function for python 3 compatibility -from __future__ import print_function + # Standard modules import os diff --git a/pbxplore/scripts/PBcount.py b/pbxplore/scripts/PBcount.py index aacc3b4..89b69db 100755 --- a/pbxplore/scripts/PBcount.py +++ b/pbxplore/scripts/PBcount.py @@ -9,7 +9,7 @@ # Use print as a function for python 3 compatibility -from __future__ import print_function + # Standard modules import os diff --git a/pbxplore/scripts/PBstat.py b/pbxplore/scripts/PBstat.py index 12ae894..64c5a64 100755 --- a/pbxplore/scripts/PBstat.py +++ b/pbxplore/scripts/PBstat.py @@ -13,7 +13,7 @@ # Modules # ============================================================================ # Use print as a function for python 3 compatibility -from __future__ import print_function + # Standard modules import os diff --git a/pbxplore/structure/PDB.py b/pbxplore/structure/PDB.py index 64f20b2..94e1543 100644 --- a/pbxplore/structure/PDB.py +++ b/pbxplore/structure/PDB.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard modules import os diff --git a/pbxplore/structure/loader.py b/pbxplore/structure/loader.py index 1d3b43f..148c5e4 100644 --- a/pbxplore/structure/loader.py +++ b/pbxplore/structure/loader.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import absolute_import, print_function + import sys # Local module diff --git a/pbxplore/structure/structure.py b/pbxplore/structure/structure.py index a7bd1d3..ca377f6 100644 --- a/pbxplore/structure/structure.py +++ b/pbxplore/structure/structure.py @@ -1,7 +1,7 @@ #! /usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + # Standard module import math @@ -96,7 +96,7 @@ def read_from_PDBx(cls, line, fields): http://mmcif.wwpdb.org/docs/tutorials/content/atomic-description.html """ try: - dic = dict(zip(fields, line.split())) + dic = dict(list(zip(fields, line.split()))) except: raise AtomError("Something went wrong in reading\n{0}".format(line)) try: diff --git a/pbxplore/tests/__init__.py b/pbxplore/tests/__init__.py index 1f02bd9..cd5f83e 100644 --- a/pbxplore/tests/__init__.py +++ b/pbxplore/tests/__init__.py @@ -20,11 +20,11 @@ def module_info(module_name): try: module = importlib.import_module(module_name) if hasattr(module, '__version__'): - print("{0} version {1}".format(module_name, module.__version__)) + print(("{0} version {1}".format(module_name, module.__version__))) module_dir = os.path.dirname(module.__file__) - print("{0} is installed in {1}".format(module_name, module_dir)) + print(("{0} is installed in {1}".format(module_name, module_dir))) except: - print("{0} is not installed".format(module_name)) + print(("{0} is not installed".format(module_name))) def system_info(): @@ -32,7 +32,7 @@ def system_info(): Print information regarding the dependencies of PBxplore and Python version """ - print("PBxplore version {}".format(__version__)) + print(("PBxplore version {}".format(__version__))) module_info("numpy") module_info("MDAnalysis") @@ -40,4 +40,4 @@ def system_info(): module_info("weblogolib") py_version = sys.version.replace('\n', '') - print("Python version {0}".format(py_version)) + print(("Python version {0}".format(py_version))) diff --git a/pbxplore/tests/test_regression.py b/pbxplore/tests/test_regression.py index 3b44c22..caf6860 100644 --- a/pbxplore/tests/test_regression.py +++ b/pbxplore/tests/test_regression.py @@ -13,7 +13,7 @@ """ # Use print as a function like in python 3 -from __future__ import print_function + from os import path from uuid import uuid1 diff --git a/setup.py b/setup.py index 0b8e2d2..032e140 100644 --- a/setup.py +++ b/setup.py @@ -1,7 +1,7 @@ #!/usr/bin/env python # -*- coding: utf-8 -*- -from __future__ import print_function, absolute_import + from setuptools import setup, find_packages import os From c1acef8169b0020af7cdba2fd4041e6a7df1942a Mon Sep 17 00:00:00 2001 From: "Alexandre G. de Brevern" Date: Tue, 26 May 2020 12:06:49 +0200 Subject: [PATCH 04/12] Update README.rst --- README.rst | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.rst b/README.rst index 8e0f770..969a8cc 100644 --- a/README.rst +++ b/README.rst @@ -1,7 +1,7 @@ PBxplore ======== -.. image:: https://img.shields.io/badge/Python-2.7%203.4%203.5%203.6-brightgreen.svg +.. image:: https://img.shields.io/badge/Python-3.4%203.5%203.6%203.8-brightgreen.svg :alt: Python version :target: https://pypi.python.org/pypi/pbxplore @@ -44,7 +44,7 @@ Requirements PBxplore requires: -* Python 2.7 or Python 3.x (>= 3.4) +* Python 3.x (>= 3.4) * Python modules: `NumPy `_, `Matplotlib `_, `MDAnalysis `_ (version >= 0.11). Optionally, PBxplore can use: @@ -90,10 +90,10 @@ Contact & Support PBxplore is a research software and has been developped by: -* Pierre Poulain, "Mitochondria, Metals and Oxidative Stress" group, Institut Jacques Monod, UMR 7592, Univ. Paris Diderot, CNRS, Sorbonne Paris Cité, France. +* Pierre Poulain, "Mitochondria, Metals and Oxidative Stress" group, Institut Jacques Monod, UMR 7592, Univ. Paris, CNRS, France. * Jonathan Barnoud, University of Groningen, Groningen, The Netherlands. * Hubert Santuz, Laboratoire de Biochimie Théorique, CNRS UPR 9080, Institut de Biologie Physico-Chimique, Paris, France. -* Alexandre G. de Brevern, DSIMB, INSERM, U 1134, INTS, Paris, France. +* Alexandre G. de Brevern & Gabriel Cretin, DSIMB, INSERM, UMR_S 1134, INTS, Univ Paris, Paris, France. If you want to report a bug, request a feature, use the `GitHub issue system `_. From 4c58a06aed18e22b4598b3b2db3ec8e312b1fa01 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Wed, 10 Jun 2020 11:53:30 +0200 Subject: [PATCH 05/12] Bum version 1.3.8 -> 1.3.9 --- .zenodo.json | 2 +- CHANGELOG | 6 ++++++ devtools/bumpversion.cfg | 2 +- devtools/conda/pbxplore/meta.yaml | 4 ++-- pbxplore/__init__.py | 2 +- setup.py | 2 +- 6 files changed, 12 insertions(+), 6 deletions(-) diff --git a/.zenodo.json b/.zenodo.json index 458d128..cb6646f 100644 --- a/.zenodo.json +++ b/.zenodo.json @@ -1,5 +1,5 @@ { - "title": "PBxplore (v1.3.8): A program to explore protein structures with Protein Blocks", + "title": "PBxplore (v1.3.9): A program to explore protein structures with Protein Blocks", "creators": [{ "name": "Barnoud, Jonathan", "orcid": "0000-0003-0343-7796" diff --git a/CHANGELOG b/CHANGELOG index 86adad3..28e080e 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,4 +1,10 @@ **Dev** + +**1.3.9** +- Convert python2 to python3 +- Fix weblogo dependancy (package changed name) +- Fix pytest + **1.3.8** - Add and update version number in zenodo config file - Update authors affiliations in README diff --git a/devtools/bumpversion.cfg b/devtools/bumpversion.cfg index 356922d..1a67f6b 100644 --- a/devtools/bumpversion.cfg +++ b/devtools/bumpversion.cfg @@ -1,7 +1,7 @@ [bumpversion] commit = True tag = True -current_version = 1.3.8 +current_version = 1.3.9 parse = (?P\d+)\.(?P\d+)\.(?P\d+) serialize = {major}.{minor}.{patch} diff --git a/devtools/conda/pbxplore/meta.yaml b/devtools/conda/pbxplore/meta.yaml index d3953d4..6ab43ba 100644 --- a/devtools/conda/pbxplore/meta.yaml +++ b/devtools/conda/pbxplore/meta.yaml @@ -1,10 +1,10 @@ package: name: pbxplore - version: "1.3.8" + version: "1.3.9" source: git_url: https://github.com/pierrepo/PBxplore.git - git_rev: v1.3.8 + git_rev: v1.3.9 build: entry_points: diff --git a/pbxplore/__init__.py b/pbxplore/__init__.py index 7f4c68e..c95b14f 100644 --- a/pbxplore/__init__.py +++ b/pbxplore/__init__.py @@ -15,7 +15,7 @@ See :func:`pbxplore.assignment.assign` """ -__version__ = "1.3.8" +__version__ = "1.3.9" from .structure.loader import * from .assignment import assign diff --git a/setup.py b/setup.py index 032e140..7253a6a 100644 --- a/setup.py +++ b/setup.py @@ -20,7 +20,7 @@ # Version number must be in sync with the one in pbxplore/__init__.py setup( name='pbxplore', - version='1.3.8', + version='1.3.9', description="PBxplore is a suite of tools dedicated to Protein Block analysis.", long_description=readme, From e752be9c375b1c55e4fdb696d91b32c2c939e885 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 11:57:59 +0100 Subject: [PATCH 06/12] Revert automatically applied 2to3 changes --- pbxplore/analysis/utils.py | 2 +- pbxplore/structure/structure.py | 2 +- pbxplore/tests/__init__.py | 10 +++++----- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/pbxplore/analysis/utils.py b/pbxplore/analysis/utils.py index 6b8e598..dab5d31 100644 --- a/pbxplore/analysis/utils.py +++ b/pbxplore/analysis/utils.py @@ -60,7 +60,7 @@ def _slice_matrix(mat, idx_first_residue=1, residue_min=1, residue_max=None): # Take in account the optional offset (idx_first_residue) # range of indexes of the matrix - residues_idx = list(range(idx_first_residue, mat.shape[0] + idx_first_residue)) + residues_idx = range(idx_first_residue, mat.shape[0] + idx_first_residue) if residue_min not in residues_idx or residue_max not in residues_idx: raise IndexError("Index out of range") diff --git a/pbxplore/structure/structure.py b/pbxplore/structure/structure.py index ca377f6..eb52e00 100644 --- a/pbxplore/structure/structure.py +++ b/pbxplore/structure/structure.py @@ -96,7 +96,7 @@ def read_from_PDBx(cls, line, fields): http://mmcif.wwpdb.org/docs/tutorials/content/atomic-description.html """ try: - dic = dict(list(zip(fields, line.split()))) + dic = dict(zip(fields, line.split())) except: raise AtomError("Something went wrong in reading\n{0}".format(line)) try: diff --git a/pbxplore/tests/__init__.py b/pbxplore/tests/__init__.py index 08bc9a1..3a12468 100644 --- a/pbxplore/tests/__init__.py +++ b/pbxplore/tests/__init__.py @@ -20,11 +20,11 @@ def module_info(module_name): try: module = importlib.import_module(module_name) if hasattr(module, '__version__'): - print(("{0} version {1}".format(module_name, module.__version__))) + print("{0} version {1}".format(module_name, module.__version__)) module_dir = os.path.dirname(module.__file__) - print(("{0} is installed in {1}".format(module_name, module_dir))) + print("{0} is installed in {1}".format(module_name, module_dir)) except: - print(("{0} is not installed".format(module_name))) + print("{0} is not installed".format(module_name)) def system_info(): @@ -32,7 +32,7 @@ def system_info(): Print information regarding the dependencies of PBxplore and Python version """ - print(("PBxplore version {}".format(__version__))) + print("PBxplore version {}".format(__version__)) module_info("numpy") module_info("MDAnalysis") @@ -40,4 +40,4 @@ def system_info(): module_info("weblogo") py_version = sys.version.replace('\n', '') - print(("Python version {0}".format(py_version))) + print("Python version {0}".format(py_version)) From bb53f4205bfdace89673c84be6ecb814715d3ff4 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 12:01:34 +0100 Subject: [PATCH 07/12] One more revert --- pbxplore/analysis/visualization.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pbxplore/analysis/visualization.py b/pbxplore/analysis/visualization.py index 909169f..093a849 100644 --- a/pbxplore/analysis/visualization.py +++ b/pbxplore/analysis/visualization.py @@ -162,7 +162,7 @@ def plot_map(fname, count_mat, idx_first_residue=1, residue_min=1, residue_max=N # add ticks and labels ax2.set_xticks(xticks - numpy.min(xticks)) ax2.set_xticklabels(xticks) - ax2.set_yticks(list(range(len(yticks)))) + ax2.set_yticks(range(len(yticks))) ax2.set_yticklabels(yticks, style='italic', weight='bold') ax2.set_xlabel("Residue number", weight="bold") From 06c4be0ac9c0bb620ec9fc9de92f7284c029a876 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 17:00:02 +0100 Subject: [PATCH 08/12] Set the version of Weblogo --- setup.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/setup.py b/setup.py index 7253a6a..595a346 100644 --- a/setup.py +++ b/setup.py @@ -13,8 +13,8 @@ # Extras requirements for optional dependencies extras = { - 'analysis': ['weblogo'], - 'all': ['weblogo'] + 'analysis': ['weblogo>=3.7'], + 'all': ['weblogo>=3.7'] } # Version number must be in sync with the one in pbxplore/__init__.py From 887f4a23ad0ee82d745540942322be23b37693c2 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 17:32:50 +0100 Subject: [PATCH 09/12] Drop support for python <3.6 --- README.rst | 4 ++-- doc/source/installation.rst | 4 ++-- setup.cfg | 4 ---- setup.py | 8 +++----- 4 files changed, 7 insertions(+), 13 deletions(-) diff --git a/README.rst b/README.rst index 969a8cc..31b05fd 100644 --- a/README.rst +++ b/README.rst @@ -1,7 +1,7 @@ PBxplore ======== -.. image:: https://img.shields.io/badge/Python-3.4%203.5%203.6%203.8-brightgreen.svg +.. image:: https://img.shields.io/badge/Python-3.6%203.8-brightgreen.svg :alt: Python version :target: https://pypi.python.org/pypi/pbxplore @@ -44,7 +44,7 @@ Requirements PBxplore requires: -* Python 3.x (>= 3.4) +* Python 3.x (>= 3.6) * Python modules: `NumPy `_, `Matplotlib `_, `MDAnalysis `_ (version >= 0.11). Optionally, PBxplore can use: diff --git a/doc/source/installation.rst b/doc/source/installation.rst index ae58fea..de39287 100644 --- a/doc/source/installation.rst +++ b/doc/source/installation.rst @@ -7,7 +7,7 @@ we try in this document to provide few guidelines regarding PBxplore setup. Supported Platforms ------------------- -Currently, `PBxplore` run with Python 2.7, 3.4, 3.5 and 3.6 on Linux and Mac OS X. +Currently, `PBxplore` run with Python >=3.6 on Linux and Mac OS X. Dependencies @@ -50,7 +50,7 @@ If none of the dependencies were previously installed, the installation process The former command will install the PBxplore command-line scripts in: - ``$HOME/.local/bin`` on Linux. - - ``~/Library/Python/X.Y/bin`` on Mac OSX, where ``X.Y`` stands for the Python version (for instance ``2.7`` for Python 2.7 and ``3.5`` for Python 3.5). + - ``~/Library/Python/X.Y/bin`` on Mac OSX, where ``X.Y`` stands for the Python version (for instance ``3.8`` for Python 3.8). Do not forget to update your ``$PATH`` environment variable to make all PBxplore tools accessible. As an example, with the Bash shell, this gives: diff --git a/setup.cfg b/setup.cfg index 8d48abf..c0b054a 100644 --- a/setup.cfg +++ b/setup.cfg @@ -1,7 +1,3 @@ -[bdist_wheel] -# Compatible Python 2 and Python 3. -universal=1 - [aliases] test=pytest diff --git a/setup.py b/setup.py index 595a346..7fdf51b 100644 --- a/setup.py +++ b/setup.py @@ -45,15 +45,13 @@ 'License :: OSI Approved :: MIT License', - 'Programming Language :: Python :: 2', - 'Programming Language :: Python :: 2.7', - 'Programming Language :: Python :: 3', - 'Programming Language :: Python :: 3.4', - 'Programming Language :: Python :: 3.5', 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', + 'Programming Language :: Python :: 3.8', ], setup_requires=['pytest-runner'], + python_requires=['>=3.6'], install_requires=['numpy', 'MDAnalysis>=0.11', 'matplotlib'], tests_require=['pytest', 'pytest-raises', 'coverage'], # List additional groups of dependencies here From bf73104416ad75b32b0e28e453b72784d9a7b671 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 17:40:43 +0100 Subject: [PATCH 10/12] Bump to v1.4.0 --- .zenodo.json | 6 +++--- CHANGELOG | 7 ++----- devtools/bumpversion.cfg | 5 ++--- devtools/conda/pbxplore/meta.yaml | 4 ++-- pbxplore/__init__.py | 2 +- setup.py | 2 +- 6 files changed, 11 insertions(+), 15 deletions(-) diff --git a/.zenodo.json b/.zenodo.json index cb6646f..8b640a7 100644 --- a/.zenodo.json +++ b/.zenodo.json @@ -1,13 +1,13 @@ { - "title": "PBxplore (v1.3.9): A program to explore protein structures with Protein Blocks", + "title": "PBxplore (v1.4.0): A program to explore protein structures with Protein Blocks", "creators": [{ "name": "Barnoud, Jonathan", "orcid": "0000-0003-0343-7796" - }, + }, { "name": "Santuz, Hubert", "orcid": "0000-0001-6149-9480" - }, + }, { "name": "de Brevern, Alexandre G.", "orcid": "0000-0001-7112-5626" diff --git a/CHANGELOG b/CHANGELOG index 28e080e..2c1b3d4 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,7 +1,7 @@ **Dev** -**1.3.9** -- Convert python2 to python3 +**1.4.0** +- Drop support for python2 - Fix weblogo dependancy (package changed name) - Fix pytest @@ -72,6 +72,3 @@ - PBxplore is installable via pypi - api documentation - PBXplore is installable with setup.py - - - diff --git a/devtools/bumpversion.cfg b/devtools/bumpversion.cfg index 1a67f6b..638e2e2 100644 --- a/devtools/bumpversion.cfg +++ b/devtools/bumpversion.cfg @@ -1,9 +1,9 @@ [bumpversion] commit = True tag = True -current_version = 1.3.9 +current_version = 1.4.0 parse = (?P\d+)\.(?P\d+)\.(?P\d+) -serialize = +serialize = {major}.{minor}.{patch} [bumpversion:file:setup.py] @@ -18,4 +18,3 @@ serialize = search = **Dev** replace = **Dev** **{new_version}** - diff --git a/devtools/conda/pbxplore/meta.yaml b/devtools/conda/pbxplore/meta.yaml index 6ab43ba..e47b2ad 100644 --- a/devtools/conda/pbxplore/meta.yaml +++ b/devtools/conda/pbxplore/meta.yaml @@ -1,10 +1,10 @@ package: name: pbxplore - version: "1.3.9" + version: "1.4.0" source: git_url: https://github.com/pierrepo/PBxplore.git - git_rev: v1.3.9 + git_rev: v1.4.0 build: entry_points: diff --git a/pbxplore/__init__.py b/pbxplore/__init__.py index c95b14f..be27c33 100644 --- a/pbxplore/__init__.py +++ b/pbxplore/__init__.py @@ -15,7 +15,7 @@ See :func:`pbxplore.assignment.assign` """ -__version__ = "1.3.9" +__version__ = "1.4.0" from .structure.loader import * from .assignment import assign diff --git a/setup.py b/setup.py index 7fdf51b..bb63714 100644 --- a/setup.py +++ b/setup.py @@ -20,7 +20,7 @@ # Version number must be in sync with the one in pbxplore/__init__.py setup( name='pbxplore', - version='1.3.9', + version='1.4.0', description="PBxplore is a suite of tools dedicated to Protein Block analysis.", long_description=readme, From 142b902831b2f45d0fc31d2a340a488e1600211f Mon Sep 17 00:00:00 2001 From: Gabriel Cretin Date: Tue, 26 Jan 2021 17:43:02 +0100 Subject: [PATCH 11/12] Prefer explicit test Co-authored-by: Jonathan Barnoud --- pbxplore/tests/test_functions.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/pbxplore/tests/test_functions.py b/pbxplore/tests/test_functions.py index 1df3e3e..097295d 100644 --- a/pbxplore/tests/test_functions.py +++ b/pbxplore/tests/test_functions.py @@ -252,7 +252,10 @@ def test_get_phi_psi_angles(self, chain, resid, angles): Tests for get_phi_psi_angles() """ phi_psi = chain.get_phi_psi_angles() - assert (angles["phi"] is None and phi_psi[resid]["phi"] is None) or angles["phi"] == pytest.approx(phi_psi[resid]["phi"]) + assert ( + (angles["phi"] is None and phi_psi[resid]["phi"] is None) + or angles["phi"] == pytest.approx(phi_psi[resid]["phi"]) + ) def test_set_coordinates(self, chain): """ From 10877bd5e54d9f40b4a0083c276ee1982c61b417 Mon Sep 17 00:00:00 2001 From: gabrielctn Date: Tue, 26 Jan 2021 17:45:57 +0100 Subject: [PATCH 12/12] Remove extra brackets --- setup.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/setup.py b/setup.py index bb63714..e42e073 100644 --- a/setup.py +++ b/setup.py @@ -51,7 +51,7 @@ ], setup_requires=['pytest-runner'], - python_requires=['>=3.6'], + python_requires='>=3.6', install_requires=['numpy', 'MDAnalysis>=0.11', 'matplotlib'], tests_require=['pytest', 'pytest-raises', 'coverage'], # List additional groups of dependencies here