forked from sqlfluff/sqlfluff
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup.py
129 lines (117 loc) · 4.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
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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#!/usr/bin/env python
"""The script for setting up sqlfluff."""
import sys
if sys.version_info[0] < 3:
raise Exception("SQLFluff does not support Python 2. Please upgrade to Python 3.")
import configparser
from os.path import dirname
from os.path import join
from setuptools import find_packages, setup
# Get the global config info as currently stated
# (we use the config file to avoid actually loading any python here)
config = configparser.ConfigParser()
config.read(["src/sqlfluff/config.ini"])
version = config.get("sqlfluff", "version")
def read(*names, **kwargs):
"""Read a file and return the contents as a string."""
return open(
join(dirname(__file__), *names), encoding=kwargs.get("encoding", "utf8")
).read()
setup(
name="sqlfluff",
version=version,
license="MIT License",
description="The SQL Linter for Humans",
long_description=read("README.md"),
# Make sure pypi is expecting markdown!
long_description_content_type="text/markdown",
author="Alan Cruickshank",
author_email="[email protected]",
url="https://github.com/sqlfluff/sqlfluff",
python_requires=">=3.6",
keywords=[
"sqlfluff",
"sql",
"linter",
"formatter",
"bigquery",
"exasol",
"mysql",
"postgres",
"snowflake",
"teradata",
"dbt",
],
project_urls={
"Homepage": "https://www.sqlfluff.com",
"Documentation": "https://docs.sqlfluff.com",
"Changes": "https://github.com/sqlfluff/sqlfluff/blob/main/CHANGELOG.md",
"Source": "https://github.com/sqlfluff/sqlfluff",
"Issue Tracker": "https://github.com/sqlfluff/sqlfluff/issues",
"Twitter": "https://twitter.com/SQLFLuff",
"Chat": "https://github.com/sqlfluff/sqlfluff#sqlfluff-on-slack",
},
packages=find_packages(where="src"),
package_dir={"": "src"},
include_package_data=True,
classifiers=[
# complete classifier list: http://pypi.python.org/pypi?%3Aaction=list_classifiers
"Development Status :: 4 - Beta",
# 'Development Status :: 5 - Production/Stable',
"Environment :: Console",
"Intended Audience :: Developers",
"License :: OSI Approved :: MIT License",
"Operating System :: Unix",
"Operating System :: POSIX",
"Operating System :: Microsoft :: Windows",
"Programming Language :: Python",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: Implementation :: CPython",
"Programming Language :: Python :: Implementation :: PyPy",
"Topic :: Utilities",
"Topic :: Software Development :: Quality Assurance",
],
install_requires=[
# Core
"click>=7.1",
"colorama>=0.3",
"configparser",
"oyaml",
"Jinja2",
# Used for diffcover plugin
"diff-cover>=2.5.0",
# Used for .sqlfluffignore
"pathspec",
# Used for finding os-specific application config dirs
"appdirs",
# Cached property for performance gains
"cached-property",
# dataclasses backport for python 3.6
"dataclasses; python_version < '3.7'",
# better type hints for older python versions
"typing_extensions",
# We provide a testing library for plugins in sqlfluff.testing
"pytest",
# For parsing pyproject.toml
"toml",
# For returning exceptions from multiprocessing.Pool.map()
"tblib",
],
extras_require={
"dbt": ["dbt>=0.17"],
# eg:
# 'rst': ['docutils>=0.11'],
# ':python_version=="2.6"': ['argparse'],
},
entry_points={
"console_scripts": [
"sqlfluff = sqlfluff.cli.commands:cli",
],
"diff_cover": ["sqlfluff = sqlfluff.diff_quality_plugin"],
"sqlfluff": ["sqlfluff = sqlfluff.core.plugin.lib"],
},
)