-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathsetup.py
70 lines (58 loc) · 2.12 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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import re
from setuptools import setup
def get_version(package):
"""
Return package version as listed in `__version__` in `init.py`.
"""
init_py = open(os.path.join(package, '__init__.py')).read()
return re.search("__version__ = ['\"]([^'\"]+)['\"]", init_py).group(1)
def get_packages(package):
"""
Return root package and all sub-packages.
"""
return [
dirpath for dirpath, dirnames, filenames in os.walk(package)
if os.path.exists(os.path.join(dirpath, '__init__.py'))
]
def get_package_data(package):
"""
Return all files under the root package, that are not in a
package themselves.
"""
walk = [(dirpath.replace(package + os.sep, '', 1), filenames)
for dirpath, dirnames, filenames in os.walk(package)
if os.path.exists(os.path.join(dirpath, '__init__.py'))]
filepaths = []
for base, filenames in walk:
filepaths.extend(
[os.path.join(base, filename) for filename in filenames])
return {package: filepaths}
version = get_version('ifparser')
with open('README.rst') as f:
long_description = '\n\n'.join(f.read().split('\n\n')[1:])
setup(
name='ifparser',
version=version,
url='http://github.com/ssudake21/ifconfig-parser',
download_url='http://github.com/ssudake21/ifconfig-parser',
license='BSD',
description='Parse ifconfig output and retrieve values with goodies',
long_description=long_description,
author='Sanket Sudake',
author_email='[email protected]',
packages=get_packages('ifparser'),
package_data=get_package_data('ifparser'),
classifiers=[
"Development Status :: 5 - Production/Stable",
"License :: OSI Approved :: BSD License",
"Programming Language :: Python :: 2.7",
"Operating System :: POSIX :: Linux",
"Topic :: Internet",
"Topic :: Software Development :: Libraries :: Python Modules",
"Intended Audience :: Developers",
"Intended Audience :: System Administrators",
"Topic :: Software Development :: Libraries"
], )