forked from shield007/Flask-Store
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup.py
126 lines (103 loc) · 3.45 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
# -*- coding: utf-8 -*-
#!/usr/bin/env python
"""
Flask-Store
-----------
Flask-Store is a Flask Extenstion which provides easy Django-Storages style
file handling to various storage backends.
"""
# Temporary patch for issue reported here:
# https://groups.google.com/forum/#!topic/nose-users/fnJ-kAUbYHQ
import multiprocessing # noqa
import os
import sys
import warnings
from setuptools import find_packages, setup
def read_requirements(filename):
"""Read requirements file and process them into a list
for usage in the setup function.
Arguments
---------
filename : str
Path to the file to read line by line
Returns
--------
list
list of requirements::
['package==1.0', 'thing>=9.0']
"""
requirements = []
try:
if os.path.isfile(filename):
with open(filename, "rb") as f:
for line in f.readlines():
line = line.strip()
if not line or line.startswith(b"#") or line == "":
continue
requirements.append(line.decode("utf-8"))
else:
warnings.warn("{0} was not found".format(filename))
except IOError:
warnings.warn("{0} was not found".format(filename))
return requirements
# Get current working directory
try:
SETUP_DIRNAME = os.path.dirname(__file__)
except NameError:
SETUP_DIRNAME = os.path.dirname(sys.argv[0])
# Change to current working directory
if SETUP_DIRNAME != "":
os.chdir(SETUP_DIRNAME)
# Requirements
INSTALL_REQUIREMENTS = read_requirements("REQS.txt")
TESTING_REQUIREMENTS = read_requirements("REQS.TESTING.txt")
DEVELOP_REQUIREMENTS = read_requirements("REQS.DEVELOP.txt") + TESTING_REQUIREMENTS
# Include the Change Log on PyPi
long_description = open("README.rst").read()
changelog = open("CHANGELOG.rst").read()
long_description += "\n" + changelog
# Setup
setup(
name="Flask-Store",
version=open("VERSION").read().strip(),
author="SOON_",
author_email="dorks@thisissoon.com",
maintainer="Chris Reeves",
maintainer_email="hello@chris.reeves.io",
url="http://flask-store.soon.build",
description="Provides Django-Storages like file storage backends for "
"Flask Applications.",
long_description=long_description,
packages=find_packages(exclude=["tests"]),
include_package_data=True,
zip_safe=False,
# Dependencies
install_requires=INSTALL_REQUIREMENTS,
extras_require={"develop": DEVELOP_REQUIREMENTS},
# Testing
tests_require=TESTING_REQUIREMENTS,
# Dependencies not hosted on PyPi
dependency_links=[],
# Classifiers for Package Indexing
# Entry points, for example Flask-Script
entry_points={},
# Meta
classifiers=[
"Framework :: Flask",
"Environment :: Web Environment",
"Intended Audience :: Developers",
"License :: OSI Approved :: MIT License",
"Development Status :: 3 - Alpha",
"Operating System :: OS Independent",
"Programming Language :: Python",
"Programming Language :: Python :: 2",
"Programming Language :: Python :: 2.7",
"Programming Language :: Python :: 3",
"Programming Language :: Python :: 3.5",
"Topic :: Software Development",
"Topic :: Software Development :: Libraries :: Python Modules",
"Topic :: Internet :: WWW/HTTP :: Dynamic Content",
],
license="MIT",
keywords=["Flask", "Files", "Storage"],
)