Metadata-Version: 2.1
Name: wardoff
Version: 0.5.0
Summary: Find deprecations in your requirements and underlying libraries
Home-page: https://github.com/4383/wardoff/
Author: Hervé Beraud
Author-email: herveberaud.pro@gmail.com
License: MIT
Description: # Wardoff
        
        [![Build Status](https://travis-ci.org/4383/wardoff.svg?branch=master)](https://travis-ci.org/4383/wardoff)
        ![PyPI](https://img.shields.io/pypi/v/wardoff.svg)
        ![PyPI - Python Version](https://img.shields.io/pypi/pyversions/wardoff.svg)
        ![PyPI - Status](https://img.shields.io/pypi/status/wardoff.svg)
        [![Downloads](https://img.shields.io/pypi/dm/wardoff.svg)](https://pypi.python.org/pypi/wardoff/)
        
        Wardoff (pronounced `ward off`) aim to help you to maintain your code base
        clean and up-to-date by reducing the pain of collect informations about all
        your underlaying libraries in your stack in a proactively manner.
        
        Wardoff grab for you many informations about your stacks, it can be used to:
        - looking for deprecated stuffs in project requirements and underlying
        - grab requirements infos (detailed or not) (cf. following examples)
        - convert source code into python token
        
        For each analyze a dedicated python virtual environment is built and project's
        requirements are installed within. Then installed source code files of
        project's requirement are analyzed one by one.
        
        Code analyze of the requirements is based on
        [AST](https://docs.python.org/3/library/ast.html) and
        [python tokens](https://docs.python.org/3/library/tokenize.html). Each
        source code file of each underlaying library is analyzed in this way.
        
        You can pass a list of constraints to apply to your analyze to be sure
        to match the right versions of your underlaying libraries.
        
        Traditionally projects maintainers are informed that functions will become
        deprecated or removed by reading documentation or by
        observing deprecation warning at the runtime in logs. When your stack
        grow and the number of requirements in your stack increase it could be
        painful to stay up-to-date, wardoff aim to collect for you all these infos
        by using only 1 command without needing any runtime environment setup.
        
        ## Install
        
        Still in development and really unstable, however you can install unstable
        development versions by using:
        
        ```shell
        $ python3 -m pip install --user wardoff
        ```
        
        ## Requirements
        
        - python3.8+
        - git
        
        ## Usages
        
        ### Looking for deprecated things in stacks
        
        The main goal here is to analyze all requirements of a given project
        to extract deprecated things from their codes.
        
        #### From a named package
        
        Found deprecated things from a named package (directly from pypi):
        
        ```sh
        $ wardoff niet # will list all deprecations founds in niet is requirements
        $ wardoff oslo.messaging # will list all deprecations founds in oslo.messaging is requirements
        $ wardoff oslo.messaging==12.2.2 # will list all deprecations founds in oslo.messaging 12.2.2 is requirements
        $ wardoff oslo.messaging==1.3.0 # will list all deprecations founds in oslo.messaging 1.3.0 is requirements
        ```
        
        #### From the current directory
        
        (Coming soon - not yet implemented)
        Retrieve deprecated things from the current working directory.
        Retrieve requirements from:
        - `requirements.txt`
        - `test-requirements.txt`
        - `*-requirements.txt`
        
        Example:
        
        ```sh
        $ wardoff # will list all deprecations founds in requirements founds in current directory
        ```
        
        #### From a distant repository
        
        (Coming soon - not yet implemented)
        Retrieve deprecated things from a distgit repo.
        
        Example:
        
        ```sh
        $ wardoff https://opendev.org/openstack/nova/ # from opendev.org
        $ wardoff https://github.com/openstack/nova # from github.com
        $ wardoff git@github.com:openstack/nova # by using git format
        ```
        
        #### From a local repository
        
        (Coming soon - not yet implemented)
        Retrieve deprecated things from a distgit repo.
        
        Example:
        
        ```sh
        $ wardoff ~/dev/nova # from a local clone of openstack/nova
        ```
        
        ### tokenizer
        
        Wardoff provide a CLI tokenizer which can be used against code passed through
        the CLI or by passing a file path and a specific line to read.
        
        Example with raw code passed through the CLI:
        
        ```sh
        $ wardoff-tokenizer "def person(name, age):"
        TokenInfo(type=62 (ENCODING), string='utf-8', start=(0, 0), end=(0, 0), line='')
        TokenInfo(type=1 (NAME), string='def', start=(1, 0), end=(1, 3), line='def person(name, age):')
        TokenInfo(type=1 (NAME), string='person', start=(1, 4), end=(1, 10), line='def person(name, age):')
        TokenInfo(type=54 (OP), string='(', start=(1, 10), end=(1, 11), line='def person(name, age):')
        TokenInfo(type=1 (NAME), string='name', start=(1, 11), end=(1, 15), line='def person(name, age):')
        TokenInfo(type=54 (OP), string=',', start=(1, 15), end=(1, 16), line='def person(name, age):')
        TokenInfo(type=1 (NAME), string='age', start=(1, 17), end=(1, 20), line='def person(name, age):')
        TokenInfo(type=54 (OP), string=')', start=(1, 20), end=(1, 21), line='def person(name, age):')
        TokenInfo(type=54 (OP), string=':', start=(1, 21), end=(1, 22), line='def person(name, age):')
        TokenInfo(type=4 (NEWLINE), string='', start=(1, 22), end=(1, 23), line='')
        TokenInfo(type=0 (ENDMARKER), string='', start=(2, 0), end=(2, 0), line='')
        ```
        
        Another example by passing a file line to tokenize:
        
        ```sh
        wardoff-tokenizer ~/dev/wardoff/wardoff/tokenizer.py+12
        ```
        
        It will tokenize the line number 12 of the file
        `~/dev/wardoff/wardoff/tokenizer.py`
        
        For further options with this command:
        
        ```sh
        $ wardoff-tokenizer -h
        ```
        
        ### freeze
        
        Wardoff allow you to freeze installed requirements. It will provide a similar
        output than `pip freeze` but it will only print requirements related the given
        package.
        
        Example:
        
        ```
        $ wardoff-freeze oslo.messaging==1.3.0
        amqp==2.6.0
        Babel==2.8.0
        certifi==2020.6.20
        chardet==3.0.4
        debtcollector==2.2.0
        dnspython==2.0.0
        eventlet==0.25.2
        greenlet==0.4.16
        idna==2.10
        iso8601==0.1.12
        kombu==4.6.11
        monotonic==1.5
        netaddr==0.8.0
        oslo.config==8.3.1
        oslo.i18n==5.0.0
        pbr==5.4.5
        pytz==2020.1
        PyYAML==5.3.1
        requests==2.24.0
        rfc3986==1.4.0
        six==1.15.0
        stevedore==3.2.0
        urllib3==1.25.10
        vine==1.3.0
        wrapt==1.12.1
        ```
        
        Also you can retrieve all the packages informations by passing the `--details`
        option:
        
        ```sh
        $ wardoff-freeze oslo.cache --details
        -----
        name: certifi
        version: 2020.6.20
        sources_path: /tmp/wardoff-17942/lib/python3.8/site-packages/certifi
        summary: Python package for providing Mozilla's CA Bundle.
        home-page: https//certifiio.readthedocs.io/en/latest/
        author: Kenneth Reitz
        author-email: me@kennethreitz.com
        license: MPL-2.0
        location: /tmp/wardoff-17942/lib/python3.8/site-packages
        requires:
        required-by: requests
        -----
        name: chardet
        version: 3.0.4
        sources_path: /tmp/wardoff-17942/lib/python3.8/site-packages/chardet
        summary: Universal encoding detector for Python 2 and 3
        home-page: https//github.com/chardet/chardet
        author: Daniel Blanchard
        author-email: dan.blanchard@gmail.com
        license: LGPL
        location: /tmp/wardoff-17942/lib/python3.8/site-packages
        requires:
        required-by: requests
        ...
        ```
        
        Moreover you can use `wardoff-freeze` to grab more informations than that,
        by example you can retrieve all the projects home pages of your stack:
        
        ```sh
        $ wardoff-freeze oslo.cache --details --keep-env --filter home-page --no-separator --no-key
        https//certifiio.readthedocs.io/en/latest/
        https//github.com/chardet/chardet
        https//docs.openstack.org/debtcollector/latest
        https//github.com/micheles/decorator
        https//github.com/sqlalchemy/dogpile.cache
        https//github.com/kjd/idna
        https//bitbucket.org/micktwomey/pyiso8601
        https//msgpack.org/
        https//github.com/drkjam/netaddr/
        https//github.com/al45tair/netifaces
        https//docs.openstack.org/oslo.config/latest/
        https//docs.openstack.org/oslo.context/latest/
        https//docs.openstack.org/oslo.i18n/latest
        https//docs.openstack.org/oslo.log/latest
        https//docs.openstack.org/oslo.serialization/latest/
        https//docs.openstack.org/oslo.utils/latest/
        https//github.com/pypa/packaging
        https//docs.openstack.org/pbr/latest/
        http//github.com/seb-m/pyinotify
        https//github.com/pyparsing/pyparsing/
        https//dateutil.readthedocs.io
        http//pythonhosted.org/pytz
        https//github.com/yaml/pyyaml
        https//requests.readthedocs.io
        http//rfc3986.readthedocs.io
        https//github.com/benjaminp/six
        https//docs.openstack.org/stevedore/latest/
        https//urllib3.readthedocs.io/
        https//github.com/GrahamDumpleton/wrapt
        ```
        
        Or retrieve who are the main maintainers of the analyzed stack
        (here in oslo.cache):
        
        ```sh
        wardoff-freeze oslo.cache --details --filter author --no-separator --no-key | sort | uniq
        Alastair Houghton
        Andrey Petrov
        Benjamin Peterson
        Daniel Blanchard
        David P. D. Moss, Stefan Nordhausen et al
        Donald Stufft and individual contributors
        Graham Dumpleton
        Gustavo Niemeyer
        Ian Stapleton Cordasco
        Inada Naoki
        Kenneth Reitz
        Kim Davies
        Kirill Simonov
        Michael Twomey
        Michele Simionato
        Mike Bayer
        OpenStack
        Paul McGuire
        Sebastien Martini
        Stuart Bishop
        ```
        
        ## The future of wardoff
        
        We plan to introduce more features like issues and pull requests or
        patches harvesting.
        
        
Platform: UNKNOWN
Classifier: Development Status :: 1 - Planning
Classifier: Intended Audience :: Information Technology
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: POSIX
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.8
Requires: pbr
Requires-Python: >=3.8
Description-Content-Type: text/markdown
