forked from ibis-project/ibis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
110 lines (98 loc) · 3.13 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#!/usr/bin/env python
import os
from setuptools import setup, find_packages
import versioneer
LONG_DESCRIPTION = """
Ibis is a productivity-centric Python big data framework.
See http://ibis-project.org
"""
impala_requires = [
'hdfs>=2.0.16',
'impyla>=0.14.0',
'sqlalchemy',
'requests',
]
sqlite_requires = ['sqlalchemy']
postgres_requires = sqlite_requires + ['psycopg2']
mysql_requires = sqlite_requires + ['pymysql']
mapd_requires = ['pymapd']
kerberos_requires = ['requests-kerberos']
visualization_requires = ['graphviz']
clickhouse_requires = ['clickhouse-driver>=0.0.8']
bigquery_requires = ['google-cloud-bigquery>=1.0.0']
hdf5_requires = ['tables>=3.0.0']
parquet_requires = ['pyarrow>=0.6.0']
all_requires = (
impala_requires +
postgres_requires +
mapd_requires +
mysql_requires +
kerberos_requires +
visualization_requires +
clickhouse_requires +
bigquery_requires +
hdf5_requires +
parquet_requires
)
develop_requires = all_requires + [
'click',
'flake8',
'pytest>=3',
]
with open(
os.path.join(os.path.dirname(__file__), 'requirements.txt'), 'rt'
) as f:
install_requires = list(map(str.strip, f))
setup(
name='ibis-framework',
url='https://github.com/ibis-project/ibis',
packages=find_packages(),
version=versioneer.get_version(),
cmdclass=versioneer.get_cmdclass(),
install_requires=install_requires,
extras_require={
'all': all_requires,
'develop:python_version < "3"': develop_requires + [
'thriftpy<=0.3.9',
'thrift<=0.9.3',
'mock',
],
'develop:python_version >= "3"': develop_requires,
'impala:python_version < "3"': impala_requires + [
'thriftpy<=0.3.9',
'thrift<=0.9.3',
],
'impala:python_version >= "3"': impala_requires,
'kerberos': kerberos_requires,
'postgres': postgres_requires,
'mapd': mapd_requires,
'mysql': mysql_requires,
'sqlite': sqlite_requires,
'visualization': visualization_requires,
'clickhouse:python_version != "3.4"': clickhouse_requires + [
'clickhouse-cityhash'
],
'clickhouse:python_version == "3.4"': clickhouse_requires,
'bigquery': bigquery_requires,
'csv:python_version < "3"': ['pathlib2'],
'hdf5': hdf5_requires,
'hdf5:python_version < "3"': hdf5_requires + ['pathlib2'],
'parquet': parquet_requires,
'parquet:python_version < "3"': parquet_requires + ['pathlib2'],
},
description="Productivity-centric Python Big Data Framework",
long_description=LONG_DESCRIPTION,
classifiers=[
'Development Status :: 4 - Beta',
'Operating System :: OS Independent',
'Intended Audience :: Science/Research',
'Programming Language :: Python',
'Programming Language :: Python :: 2',
'Programming Language :: Python :: 3',
'Programming Language :: Python :: 2.7',
'Topic :: Scientific/Engineering',
],
license='Apache License, Version 2.0',
maintainer="Phillip Cloud",
maintainer_email="phillip.cloud@twosigma.com"
)