From 1970208be6228ea2348594dc37234ba9d031743c Mon Sep 17 00:00:00 2001 From: joncrall Date: Thu, 13 Feb 2020 14:08:50 -0500 Subject: [PATCH 1/3] Add python setup script --- bdd_data/__init__.py | 1 + setup.py | 151 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 152 insertions(+) create mode 100755 setup.py diff --git a/bdd_data/__init__.py b/bdd_data/__init__.py index e69de29..b8023d8 100644 --- a/bdd_data/__init__.py +++ b/bdd_data/__init__.py @@ -0,0 +1 @@ +__version__ = '0.0.1' diff --git a/setup.py b/setup.py new file mode 100755 index 0000000..dff24a6 --- /dev/null +++ b/setup.py @@ -0,0 +1,151 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +""" +Installation: + pip install git+https://github.com/ucbdrive/bdd-data.git +""" +from setuptools import setup +from setuptools import find_packages +import sys +from os.path import exists + + +def parse_version(fpath): + """ + Statically parse the version number from a python file + """ + import ast + if not exists(fpath): + raise ValueError('fpath={!r} does not exist'.format(fpath)) + with open(fpath, 'r') as file_: + sourcecode = file_.read() + pt = ast.parse(sourcecode) + class VersionVisitor(ast.NodeVisitor): + def visit_Assign(self, node): + for target in node.targets: + if getattr(target, 'id', None) == '__version__': + self.version = node.value.s + visitor = VersionVisitor() + visitor.visit(pt) + return visitor.version + + +def parse_description(): + """ + Parse the description in the README file + + CommandLine: + pandoc --from=markdown --to=rst --output=README.rst README.md + python -c "import setup; print(setup.parse_description())" + """ + from os.path import dirname, join, exists + readme_fpath = join(dirname(__file__), 'README.rst') + # This breaks on pip install, so check that it exists. + if exists(readme_fpath): + with open(readme_fpath, 'r') as f: + text = f.read() + return text + return '' + + +def parse_requirements(fname='requirements.txt', with_version=False): + """ + Parse the package dependencies listed in a requirements file but strips + specific versioning information. + + Args: + fname (str): path to requirements file + with_version (bool, default=False): if true include version specs + + Returns: + List[str]: list of requirements items + + CommandLine: + python -c "import setup; print(setup.parse_requirements())" + python -c "import setup; print(chr(10).join(setup.parse_requirements(with_version=True)))" + """ + from os.path import exists + import re + require_fpath = fname + + def parse_line(line): + """ + Parse information from a line in a requirements text file + """ + if line.startswith('-r '): + # Allow specifying requirements in other files + target = line.split(' ')[1] + for info in parse_require_file(target): + yield info + else: + info = {'line': line} + if line.startswith('-e '): + info['package'] = line.split('#egg=')[1] + else: + # Remove versioning from the package + pat = '(' + '|'.join(['>=', '==', '>']) + ')' + parts = re.split(pat, line, maxsplit=1) + parts = [p.strip() for p in parts] + + info['package'] = parts[0] + if len(parts) > 1: + op, rest = parts[1:] + if ';' in rest: + # Handle platform specific dependencies + # http://setuptools.readthedocs.io/en/latest/setuptools.html#declaring-platform-specific-dependencies + version, platform_deps = map(str.strip, rest.split(';')) + info['platform_deps'] = platform_deps + else: + version = rest # NOQA + info['version'] = (op, version) + yield info + + def parse_require_file(fpath): + with open(fpath, 'r') as f: + for line in f.readlines(): + line = line.strip() + if line and not line.startswith('#'): + for info in parse_line(line): + yield info + + def gen_packages_items(): + if exists(require_fpath): + for info in parse_require_file(require_fpath): + parts = [info['package']] + if with_version and 'version' in info: + parts.extend(info['version']) + if not sys.version.startswith('3.4'): + # apparently package_deps are broken in 3.4 + platform_deps = info.get('platform_deps') + if platform_deps is not None: + parts.append(';' + platform_deps) + item = ''.join(parts) + yield item + + packages = list(gen_packages_items()) + return packages + + +NAME = 'bdd_data' +VERSION = parse_version('bdd_data/__init__.py') # must be global for git tags + + +if __name__ == '__main__': + setup( + name=NAME, + version=VERSION, + author='UCB', + description=('supporting code for BDD100K data and Scalabel.'), + long_description=parse_description(), + long_description_content_type='text/markdown', + install_requires=parse_requirements('requirements.txt'), + author_email='erotemic@gmail.com', + url='https://github.com/ucbdrive/bdd-data', + license='BSD', + packages=find_packages('bdd_data*'), + classifiers=[ + # List of classifiers available at: + # https://pypi.python.org/pypi?%3Aaction=list_classifiers + 'Development Status :: 4 - Beta', + ], + ) From b790f17eb90f2135f1ab3521ffb175db9cd52c84 Mon Sep 17 00:00:00 2001 From: joncrall Date: Fri, 14 Feb 2020 09:08:32 -0500 Subject: [PATCH 2/3] Fix travis --- setup.py | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/setup.py b/setup.py index dff24a6..44f0a57 100755 --- a/setup.py +++ b/setup.py @@ -59,10 +59,6 @@ def parse_requirements(fname='requirements.txt', with_version=False): Returns: List[str]: list of requirements items - - CommandLine: - python -c "import setup; print(setup.parse_requirements())" - python -c "import setup; print(chr(10).join(setup.parse_requirements(with_version=True)))" """ from os.path import exists import re @@ -92,9 +88,8 @@ def parse_line(line): op, rest = parts[1:] if ';' in rest: # Handle platform specific dependencies - # http://setuptools.readthedocs.io/en/latest/setuptools.html#declaring-platform-specific-dependencies - version, platform_deps = map(str.strip, rest.split(';')) - info['platform_deps'] = platform_deps + version, plat_deps = map(str.strip, rest.split(';')) + info['platform_deps'] = plat_deps else: version = rest # NOQA info['version'] = (op, version) @@ -116,9 +111,9 @@ def gen_packages_items(): parts.extend(info['version']) if not sys.version.startswith('3.4'): # apparently package_deps are broken in 3.4 - platform_deps = info.get('platform_deps') - if platform_deps is not None: - parts.append(';' + platform_deps) + plat_deps = info.get('platform_deps') + if plat_deps is not None: + parts.append(';' + plat_deps) item = ''.join(parts) yield item @@ -127,7 +122,7 @@ def gen_packages_items(): NAME = 'bdd_data' -VERSION = parse_version('bdd_data/__init__.py') # must be global for git tags +VERSION = parse_version('bdd_data/__init__.py') if __name__ == '__main__': From 45176344ff949555ae3d9a5b74c731c79223009d Mon Sep 17 00:00:00 2001 From: joncrall Date: Fri, 14 Feb 2020 09:58:56 -0500 Subject: [PATCH 3/3] fix travis again --- setup.py | 1 + 1 file changed, 1 insertion(+) diff --git a/setup.py b/setup.py index 44f0a57..9283345 100755 --- a/setup.py +++ b/setup.py @@ -20,6 +20,7 @@ def parse_version(fpath): with open(fpath, 'r') as file_: sourcecode = file_.read() pt = ast.parse(sourcecode) + class VersionVisitor(ast.NodeVisitor): def visit_Assign(self, node): for target in node.targets: