npbackup/setup.py

173 lines
5.3 KiB
Python
Raw Normal View History

2023-01-26 08:13:07 +08:00
#! /usr/bin/env python
# -*- coding: utf-8 -*-
#
# This file is part of npbackup package
__intname__ = "npbackup.setup"
__author__ = "Orsiris de Jong"
__copyright__ = "Copyright (C) 2022-2023 NetInvent"
__license__ = "GPL-3.0-only"
__build__ = "2023012901"
__setup_ver__ = "1.1.0"
2023-01-26 08:13:07 +08:00
PACKAGE_NAME = "npbackup"
DESCRIPTION = "One fits all solution for deduplicated and compressed backups on servers and laptops"
import sys
import os
import pkg_resources
import setuptools
def _read_file(filename):
here = os.path.abspath(os.path.dirname(__file__))
if sys.version_info[0] < 3:
# With python 2.7, open has no encoding parameter, resulting in TypeError
# Fix with io.open (slow but works)
from io import open as io_open
try:
with io_open(
os.path.join(here, filename), "r", encoding="utf-8"
) as file_handle:
return file_handle.read()
except IOError:
# Ugly fix for missing requirements.txt file when installing via pip under Python 2
return ""
else:
with open(os.path.join(here, filename), "r", encoding="utf-8") as file_handle:
return file_handle.read()
def get_metadata(package_file):
"""
Read metadata from package file
"""
_metadata = {}
for line in _read_file(package_file).splitlines():
if line.startswith("__version__") or line.startswith("__description__"):
delim = "="
2023-01-30 19:01:19 +08:00
_metadata[line.split(delim)[0].strip().strip("__")] = (
line.split(delim)[1].strip().strip("'\"")
2023-01-26 08:13:07 +08:00
)
return _metadata
def parse_requirements(filename):
"""
There is a parse_requirements function in pip but it keeps changing import path
Let's build a simple one
"""
try:
requirements_txt = _read_file(filename)
install_requires = [
str(requirement)
for requirement in pkg_resources.parse_requirements(requirements_txt)
]
return install_requires
except OSError:
print(
'WARNING: No requirements.txt file found as "{}". Please check path or create an empty one'.format(
filename
)
)
2023-01-30 19:01:19 +08:00
# With this, we can enforce a binary package.
class BinaryDistribution(setuptools.Distribution):
"""Distribution which always forces a binary package with platform name"""
@staticmethod
def has_ext_modules():
return True
2023-01-26 08:13:07 +08:00
package_path = os.path.abspath(PACKAGE_NAME)
2023-01-30 19:35:03 +08:00
for path in ['__main__.py', PACKAGE_NAME + '.py']:
package_file = os.path.join(package_path, "__main__.py")
if os.path.isfile(package_file):
break
2023-01-26 08:13:07 +08:00
metadata = get_metadata(package_file)
requirements = parse_requirements(os.path.join(package_path, "requirements.txt"))
long_description = _read_file("README.md")
2023-01-30 19:01:19 +08:00
package_data = {
'': ['translations/*.yml']
}
binary_suffix = "%d" % sys.version_info[0]
if os.name == "nt":
scripts = ["misc/npbackup.cmd"]
console_scripts = []
else:
scripts = []
console_scripts = [
"npbackup%s = npbackup.npbackup:main" % binary_suffix,
]
2023-01-26 08:13:07 +08:00
setuptools.setup(
name=PACKAGE_NAME,
# We may use find_packages in order to not specify each package manually
# packages = ['command_runner'],
packages=setuptools.find_packages(),
version=metadata["version"],
install_requires=requirements,
2023-01-30 19:01:19 +08:00
package_data=package_data,
2023-01-26 08:13:07 +08:00
classifiers=[
# command_runner is mature
"Development Status :: 5 - Production/Stable",
"Intended Audience :: End Users/Desktop",
"Intended Audience :: System Administrators",
"Intended Audience :: Information Technology",
"Intended Audience :: Developers",
2023-01-30 19:01:19 +08:00
"Intended Audience :: Science/Research",
"Topic :: System :: Archiving :: Backup",
2023-01-26 08:13:07 +08:00
"Topic :: System",
"Topic :: System :: Monitoring",
"Topic :: Utilities",
"Programming Language :: Python",
"Programming Language :: Python :: 3",
2023-01-30 19:01:19 +08:00
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
2023-01-26 08:13:07 +08:00
"Programming Language :: Python :: Implementation :: CPython",
"Programming Language :: Python :: Implementation :: PyPy",
"Operating System :: POSIX :: Linux",
2023-01-30 19:01:19 +08:00
"Operating System :: Microsoft :: Windows",
"License :: OSI Approved :: GNU General Public License v3 (GPLv3)",
2023-01-26 08:13:07 +08:00
],
description=DESCRIPTION,
license="GPLv3",
author="NetInvent - Orsiris de Jong",
author_email="contact@netinvent.fr",
url="https://github.com/netinvent/npbackup",
keywords=[
"shell",
"backup",
"deduplication",
"compression",
"prometheus",
"windows",
"linux",
"gui",
"cli",
],
long_description=long_description,
long_description_content_type="text/markdown",
python_requires=">=3.6",
2023-01-30 19:01:19 +08:00
scripts=scripts,
entry_points={
"console_scripts": console_scripts,
},
# As we do version specific hacks for installed inline copies, make the
# wheel version and platform specific.
#distclass=BinaryDistribution,
2023-01-26 08:13:07 +08:00
)