forked from delta-io/delta
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
75 lines (63 loc) · 2.09 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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import sys
from setuptools import setup
from setuptools.command.install import install
# delta.io version
def get_version_from_sbt():
with open("version.sbt") as fp:
version = fp.read().strip()
return version.split('"')[1]
VERSION = get_version_from_sbt()
class VerifyVersionCommand(install):
"""Custom command to verify that the git tag matches our version"""
description = 'verify that the git tag matches our version'
def run(self):
tag = os.getenv('CIRCLE_TAG')
if tag != VERSION:
info = "Git tag: {0} does not match the version of this app: {1}".format(
tag, VERSION
)
sys.exit(info)
with open("python/README.md", "r", encoding="utf-8") as fh:
long_description = fh.read()
setup(
name="delta-spark",
version=VERSION,
description="Python APIs for using Delta Lake with Apache Spark",
long_description=long_description,
long_description_content_type="text/markdown",
url="https://github.com/delta-io/delta/",
project_urls={
'Source': 'https://github.com/delta-io/delta',
'Documentation': 'https://docs.delta.io/latest/index.html',
'Issues': 'https://github.com/delta-io/delta/issues'
},
author="The Delta Lake Project Authors",
author_email="delta-users@googlegroups.com",
license="Apache-2.0",
classifiers=[
"Development Status :: 5 - Production/Stable",
"Intended Audience :: Developers",
"License :: OSI Approved :: Apache Software License",
"Operating System :: OS Independent",
"Topic :: Software Development :: Libraries :: Python Modules",
"Programming Language :: Python :: 3",
"Typing :: Typed",
],
keywords='delta.io',
package_dir={'': 'python'},
packages=['delta'],
package_data={
'delta': ['py.typed'],
},
install_requires=[
'pyspark>=3.2.0,<3.3.0',
'importlib_metadata>=1.0.0',
],
python_requires='>=3.6',
cmdclass={
'verify': VerifyVersionCommand,
}
)