#! /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" 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 = "=" _metadata[line.split(delim)[0].strip().strip("__")] = ( line.split(delim)[1].strip().strip("'\"") ) 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 ) ) # 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 package_path = os.path.abspath(PACKAGE_NAME) for path in ['__main__.py', PACKAGE_NAME + '.py']: package_file = os.path.join(package_path, "__main__.py") if os.path.isfile(package_file): break metadata = get_metadata(package_file) requirements = parse_requirements(os.path.join(package_path, "requirements.txt")) long_description = _read_file("README.md") 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, ] 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, package_data=package_data, 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", "Intended Audience :: Science/Research", "Topic :: System :: Archiving :: Backup", "Topic :: System", "Topic :: System :: Monitoring", "Topic :: Utilities", "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 :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: Implementation :: CPython", "Programming Language :: Python :: Implementation :: PyPy", "Operating System :: POSIX :: Linux", "Operating System :: Microsoft :: Windows", "License :: OSI Approved :: GNU General Public License v3 (GPLv3)", ], 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", 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, )