2007-03-29 14:01:28 -07:00
|
|
|
#! /usr/bin/env python
|
2009-09-20 11:03:43 -07:00
|
|
|
# -*- coding: utf-8 -*-
|
2016-03-22 22:22:53 -07:00
|
|
|
import sys
|
2006-12-05 01:29:26 -07:00
|
|
|
|
2010-05-04 02:43:40 -07:00
|
|
|
# Tahoe-LAFS -- secure, distributed storage grid
|
2008-07-14 14:53:25 -07:00
|
|
|
#
|
2012-03-13 20:50:57 +00:00
|
|
|
# Copyright © 2006-2012 The Tahoe-LAFS Software Foundation
|
2008-07-14 14:53:25 -07:00
|
|
|
#
|
2009-08-01 19:57:10 -07:00
|
|
|
# This file is part of Tahoe-LAFS.
|
2008-07-14 14:53:25 -07:00
|
|
|
#
|
2011-05-10 12:16:50 -07:00
|
|
|
# See the docs/about.rst file for licensing information.
|
2006-12-05 01:29:26 -07:00
|
|
|
|
2016-02-16 10:59:02 -08:00
|
|
|
import os, subprocess, re
|
2008-09-11 18:03:21 -07:00
|
|
|
|
|
|
|
basedir = os.path.dirname(os.path.abspath(__file__))
|
2008-12-05 17:30:54 -07:00
|
|
|
|
2009-08-17 18:00:57 -07:00
|
|
|
# locate our version number
|
|
|
|
|
|
|
|
def read_version_py(infname):
|
|
|
|
try:
|
|
|
|
verstrline = open(infname, "rt").read()
|
|
|
|
except EnvironmentError:
|
|
|
|
return None
|
|
|
|
else:
|
|
|
|
VSRE = r"^verstr = ['\"]([^'\"]*)['\"]"
|
|
|
|
mo = re.search(VSRE, verstrline, re.M)
|
|
|
|
if mo:
|
|
|
|
return mo.group(1)
|
|
|
|
|
2014-11-21 07:56:21 +00:00
|
|
|
VERSION_PY_FILENAME = 'src/allmydata/_version.py'
|
|
|
|
version = read_version_py(VERSION_PY_FILENAME)
|
2009-08-17 18:00:57 -07:00
|
|
|
|
2010-10-29 15:28:25 -07:00
|
|
|
# Tahoe's dependencies are managed by the find_links= entry in setup.cfg and
|
|
|
|
# the _auto_deps.install_requires list, which is used in the call to setup()
|
|
|
|
# below.
|
|
|
|
adglobals = {}
|
2016-03-22 22:22:53 -07:00
|
|
|
auto_deps_fn = "src/allmydata/_auto_deps.py"
|
|
|
|
if sys.version_info[0] >= 3:
|
|
|
|
exec(compile(open(auto_deps_fn, 'rb').read(), auto_deps_fn, "exec"),
|
|
|
|
adglobals, adglobals)
|
|
|
|
else:
|
|
|
|
execfile(auto_deps_fn, adglobals)
|
2010-10-29 15:28:25 -07:00
|
|
|
install_requires = adglobals['install_requires']
|
2015-05-02 22:26:39 +01:00
|
|
|
setup_requires = adglobals['setup_requires']
|
2010-10-29 15:28:25 -07:00
|
|
|
|
2011-01-14 18:26:51 -08:00
|
|
|
if len(sys.argv) > 1 and sys.argv[1] == '--fakedependency':
|
|
|
|
del sys.argv[1]
|
|
|
|
install_requires += ["fakedependency >= 1.0.0"]
|
|
|
|
|
2017-08-07 19:49:28 -04:00
|
|
|
from setuptools import find_packages, setup
|
2009-01-29 07:00:58 -07:00
|
|
|
from setuptools import Command
|
2016-02-23 18:25:35 +00:00
|
|
|
from setuptools.command import install
|
|
|
|
|
2008-12-01 11:48:04 -07:00
|
|
|
|
2007-04-27 13:47:15 -07:00
|
|
|
trove_classifiers=[
|
2008-04-14 11:08:23 -07:00
|
|
|
"Development Status :: 5 - Production/Stable",
|
2007-04-27 13:47:15 -07:00
|
|
|
"Environment :: Console",
|
|
|
|
"Environment :: Web Environment",
|
2008-07-14 14:53:25 -07:00
|
|
|
"License :: OSI Approved :: GNU General Public License (GPL)",
|
2008-01-08 11:45:00 -07:00
|
|
|
"License :: DFSG approved",
|
|
|
|
"License :: Other/Proprietary License",
|
2008-07-14 14:53:25 -07:00
|
|
|
"Intended Audience :: Developers",
|
2007-04-27 13:47:15 -07:00
|
|
|
"Intended Audience :: End Users/Desktop",
|
|
|
|
"Intended Audience :: System Administrators",
|
|
|
|
"Operating System :: Microsoft",
|
|
|
|
"Operating System :: Microsoft :: Windows",
|
|
|
|
"Operating System :: Unix",
|
|
|
|
"Operating System :: POSIX :: Linux",
|
|
|
|
"Operating System :: POSIX",
|
|
|
|
"Operating System :: MacOS :: MacOS X",
|
2008-07-14 14:53:25 -07:00
|
|
|
"Operating System :: OS Independent",
|
|
|
|
"Natural Language :: English",
|
|
|
|
"Programming Language :: C",
|
|
|
|
"Programming Language :: Python",
|
2008-10-21 09:32:00 -07:00
|
|
|
"Programming Language :: Python :: 2",
|
2011-01-08 13:12:12 -08:00
|
|
|
"Programming Language :: Python :: 2.7",
|
2007-04-27 13:47:15 -07:00
|
|
|
"Topic :: Utilities",
|
|
|
|
"Topic :: System :: Systems Administration",
|
|
|
|
"Topic :: System :: Filesystems",
|
|
|
|
"Topic :: System :: Distributed Computing",
|
|
|
|
"Topic :: Software Development :: Libraries",
|
2008-07-14 14:53:25 -07:00
|
|
|
"Topic :: System :: Archiving :: Backup",
|
|
|
|
"Topic :: System :: Archiving :: Mirroring",
|
|
|
|
"Topic :: System :: Archiving",
|
2007-04-27 13:47:15 -07:00
|
|
|
]
|
2006-12-14 03:25:30 -07:00
|
|
|
|
2007-05-03 20:14:07 -07:00
|
|
|
|
2011-12-04 20:40:01 -08:00
|
|
|
GIT_VERSION_BODY = '''
|
|
|
|
# This _version.py is generated from git metadata by the tahoe setup.py.
|
|
|
|
|
2016-03-22 22:22:53 -07:00
|
|
|
__pkgname__ = "%(pkgname)s"
|
|
|
|
real_version = "%(version)s"
|
|
|
|
full_version = "%(full)s"
|
|
|
|
branch = "%(branch)s"
|
|
|
|
verstr = "%(normalized)s"
|
2011-12-04 21:49:16 -08:00
|
|
|
__version__ = verstr
|
2011-12-04 20:40:01 -08:00
|
|
|
'''
|
|
|
|
|
2014-11-21 05:14:18 +00:00
|
|
|
def run_command(args, cwd=None):
|
2015-02-17 19:10:54 +00:00
|
|
|
use_shell = sys.platform == "win32"
|
2011-12-04 20:40:01 -08:00
|
|
|
try:
|
2015-02-17 19:10:54 +00:00
|
|
|
p = subprocess.Popen(args, stdout=subprocess.PIPE, cwd=cwd, shell=use_shell)
|
2015-12-02 19:55:59 +00:00
|
|
|
except EnvironmentError as e: # if this gives a SyntaxError, note that Tahoe-LAFS requires Python 2.7+
|
2014-11-21 05:14:18 +00:00
|
|
|
print("Warning: unable to run %r." % (" ".join(args),))
|
|
|
|
print(e)
|
2011-12-04 20:40:01 -08:00
|
|
|
return None
|
|
|
|
stdout = p.communicate()[0].strip()
|
|
|
|
if p.returncode != 0:
|
2014-11-21 05:14:18 +00:00
|
|
|
print("Warning: %r returned error code %r." % (" ".join(args), p.returncode))
|
2011-12-04 20:40:01 -08:00
|
|
|
return None
|
|
|
|
return stdout
|
|
|
|
|
|
|
|
|
2014-11-21 05:14:18 +00:00
|
|
|
def versions_from_git(tag_prefix):
|
|
|
|
# This runs 'git' from the directory that contains this file. That either
|
2011-12-04 20:40:01 -08:00
|
|
|
# means someone ran a setup.py command (and this code is in
|
|
|
|
# versioneer.py, thus the containing directory is the root of the source
|
|
|
|
# tree), or someone ran a project-specific entry point (and this code is
|
|
|
|
# in _version.py, thus the containing directory is somewhere deeper in
|
|
|
|
# the source tree). This only gets called if the git-archive 'subst'
|
|
|
|
# variables were *not* expanded, and _version.py hasn't already been
|
|
|
|
# rewritten with a short version string, meaning we're inside a checked
|
|
|
|
# out source tree.
|
|
|
|
|
|
|
|
# versions_from_git (as copied from python-versioneer) returns strings
|
|
|
|
# like "1.9.0-25-gb73aba9-dirty", which means we're in a tree with
|
|
|
|
# uncommited changes (-dirty), the latest checkin is revision b73aba9,
|
|
|
|
# the most recent tag was 1.9.0, and b73aba9 has 25 commits that weren't
|
|
|
|
# in 1.9.0 . The narrow-minded NormalizedVersion parser that takes our
|
|
|
|
# output (meant to enable sorting of version strings) refuses most of
|
|
|
|
# that. Tahoe uses a function named suggest_normalized_version() that can
|
|
|
|
# handle "1.9.0.post25", so dumb down our output to match.
|
|
|
|
|
|
|
|
try:
|
|
|
|
source_dir = os.path.dirname(os.path.abspath(__file__))
|
2014-11-21 05:14:18 +00:00
|
|
|
except NameError as e:
|
2011-12-04 20:40:01 -08:00
|
|
|
# some py2exe/bbfreeze/non-CPython implementations don't do __file__
|
2014-11-21 05:14:18 +00:00
|
|
|
print("Warning: unable to find version because we could not obtain the source directory.")
|
|
|
|
print(e)
|
|
|
|
return {}
|
2015-02-17 19:10:54 +00:00
|
|
|
stdout = run_command(["git", "describe", "--tags", "--dirty", "--always"],
|
2011-12-04 20:40:01 -08:00
|
|
|
cwd=source_dir)
|
|
|
|
if stdout is None:
|
2014-11-21 05:14:18 +00:00
|
|
|
# run_command already complained.
|
2011-12-04 20:40:01 -08:00
|
|
|
return {}
|
2016-03-22 22:22:53 -07:00
|
|
|
stdout = stdout.decode("ascii")
|
2011-12-04 20:40:01 -08:00
|
|
|
if not stdout.startswith(tag_prefix):
|
2014-11-21 05:14:18 +00:00
|
|
|
print("Warning: tag %r doesn't start with prefix %r." % (stdout, tag_prefix))
|
2011-12-04 20:40:01 -08:00
|
|
|
return {}
|
|
|
|
version = stdout[len(tag_prefix):]
|
|
|
|
pieces = version.split("-")
|
|
|
|
if len(pieces) == 1:
|
|
|
|
normalized_version = pieces[0]
|
|
|
|
else:
|
|
|
|
normalized_version = "%s.post%s" % (pieces[0], pieces[1])
|
2013-04-25 02:14:50 +01:00
|
|
|
|
2015-02-17 19:10:54 +00:00
|
|
|
stdout = run_command(["git", "rev-parse", "HEAD"], cwd=source_dir)
|
2011-12-04 20:40:01 -08:00
|
|
|
if stdout is None:
|
2014-11-21 05:14:18 +00:00
|
|
|
# run_command already complained.
|
2011-12-04 20:40:01 -08:00
|
|
|
return {}
|
2016-03-22 22:22:53 -07:00
|
|
|
full = stdout.decode("ascii").strip()
|
2011-12-04 20:40:01 -08:00
|
|
|
if version.endswith("-dirty"):
|
|
|
|
full += "-dirty"
|
2011-12-04 21:49:16 -08:00
|
|
|
normalized_version += ".dev0"
|
2013-04-25 02:14:50 +01:00
|
|
|
|
|
|
|
# Thanks to Jistanidiot at <http://stackoverflow.com/questions/6245570/get-current-branch-name>.
|
2015-02-17 19:10:54 +00:00
|
|
|
stdout = run_command(["git", "rev-parse", "--abbrev-ref", "HEAD"], cwd=source_dir)
|
2016-03-22 22:22:53 -07:00
|
|
|
branch = (stdout or b"unknown").decode("ascii").strip()
|
2013-04-25 02:14:50 +01:00
|
|
|
|
2016-03-22 22:22:53 -07:00
|
|
|
# this returns native strings (bytes on py2, unicode on py3)
|
|
|
|
return {"version": version, "normalized": normalized_version,
|
|
|
|
"full": full, "branch": branch}
|
2011-12-04 20:40:01 -08:00
|
|
|
|
2013-03-19 15:26:21 -07:00
|
|
|
# setup.cfg has an [aliases] section which runs "update_version" before many
|
|
|
|
# commands (like "build" and "sdist") that need to know our package version
|
|
|
|
# ahead of time. If you add different commands (or if we forgot some), you
|
|
|
|
# may need to add it to setup.cfg and configure it to run update_version
|
|
|
|
# before your command.
|
2011-12-04 20:40:01 -08:00
|
|
|
|
|
|
|
class UpdateVersion(Command):
|
|
|
|
description = "update _version.py from revision-control metadata"
|
2016-02-23 18:25:35 +00:00
|
|
|
user_options = install.install.user_options
|
2011-12-04 20:40:01 -08:00
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
pass
|
|
|
|
def finalize_options(self):
|
|
|
|
pass
|
|
|
|
def run(self):
|
2014-11-21 08:38:37 +00:00
|
|
|
global version
|
|
|
|
verstr = version
|
2013-03-19 15:26:21 -07:00
|
|
|
if os.path.isdir(os.path.join(basedir, ".git")):
|
|
|
|
verstr = self.try_from_git()
|
2014-11-21 08:38:37 +00:00
|
|
|
|
2011-12-04 20:40:01 -08:00
|
|
|
if verstr:
|
|
|
|
self.distribution.metadata.version = verstr
|
2014-11-21 08:38:37 +00:00
|
|
|
else:
|
|
|
|
print("""\
|
|
|
|
********************************************************************
|
|
|
|
Warning: no version information found. This may cause tests to fail.
|
|
|
|
********************************************************************
|
|
|
|
""")
|
2011-12-04 20:40:01 -08:00
|
|
|
|
2013-03-19 15:26:21 -07:00
|
|
|
def try_from_git(self):
|
2016-08-07 21:46:59 -04:00
|
|
|
# If we change the release tag names, we must change this too
|
|
|
|
versions = versions_from_git("tahoe-lafs-")
|
2016-03-22 22:22:53 -07:00
|
|
|
|
|
|
|
# setup.py might be run by either py2 or py3 (when run by tox, which
|
|
|
|
# uses py3 on modern debian/ubuntu distros). We want this generated
|
|
|
|
# file to contain native strings on both (str=bytes in py2,
|
|
|
|
# str=unicode in py3)
|
2011-12-04 20:40:01 -08:00
|
|
|
if versions:
|
2016-03-22 22:22:53 -07:00
|
|
|
body = GIT_VERSION_BODY % {
|
|
|
|
"pkgname": self.distribution.get_name(),
|
|
|
|
"version": versions["version"],
|
|
|
|
"normalized": versions["normalized"],
|
|
|
|
"full": versions["full"],
|
|
|
|
"branch": versions["branch"],
|
|
|
|
}
|
2014-11-21 07:56:21 +00:00
|
|
|
f = open(VERSION_PY_FILENAME, "wb")
|
2016-03-22 22:22:53 -07:00
|
|
|
f.write(body.encode("ascii"))
|
2013-03-19 15:26:21 -07:00
|
|
|
f.close()
|
2014-11-21 08:38:37 +00:00
|
|
|
print("Wrote normalized version %r into '%s'" % (versions["normalized"], VERSION_PY_FILENAME))
|
2014-11-21 07:56:21 +00:00
|
|
|
|
2011-12-04 20:40:01 -08:00
|
|
|
return versions.get("normalized", None)
|
|
|
|
|
2016-09-09 16:43:58 -07:00
|
|
|
class PleaseUseTox(Command):
|
|
|
|
user_options = []
|
|
|
|
def initialize_options(self):
|
|
|
|
pass
|
|
|
|
def finalize_options(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def run(self):
|
2016-09-09 17:09:42 -07:00
|
|
|
print("ERROR: Please use 'tox' to run the test suite.")
|
2016-09-09 16:43:58 -07:00
|
|
|
sys.exit(1)
|
2011-12-04 20:40:01 -08:00
|
|
|
|
2009-08-17 18:00:57 -07:00
|
|
|
setup_args = {}
|
|
|
|
if version:
|
|
|
|
setup_args["version"] = version
|
|
|
|
|
2016-08-07 21:46:59 -04:00
|
|
|
setup(name="tahoe-lafs", # also set in __init__.py
|
2015-07-31 18:21:47 +01:00
|
|
|
description='secure, decentralized, fault-tolerant file store',
|
2014-09-09 18:51:44 +01:00
|
|
|
long_description=open('README.rst', 'rU').read(),
|
2010-05-04 02:43:40 -07:00
|
|
|
author='the Tahoe-LAFS project',
|
2010-09-30 08:37:08 -07:00
|
|
|
author_email='tahoe-dev@tahoe-lafs.org',
|
2011-10-29 18:39:46 +00:00
|
|
|
url='https://tahoe-lafs.org/',
|
2014-09-09 18:51:44 +01:00
|
|
|
license='GNU GPL', # see README.rst -- there is an alternative licence
|
2016-03-22 13:59:10 -07:00
|
|
|
cmdclass={"update_version": UpdateVersion,
|
2016-09-09 16:43:58 -07:00
|
|
|
"test": PleaseUseTox,
|
2008-09-11 18:03:21 -07:00
|
|
|
},
|
2007-11-09 18:04:19 -07:00
|
|
|
package_dir = {'':'src'},
|
2017-08-07 19:49:28 -04:00
|
|
|
packages=find_packages('src'),
|
2007-04-27 13:47:15 -07:00
|
|
|
classifiers=trove_classifiers,
|
2017-08-15 18:37:39 -07:00
|
|
|
python_requires="<3.0",
|
2008-09-11 18:03:21 -07:00
|
|
|
install_requires=install_requires,
|
2016-08-08 12:35:54 -06:00
|
|
|
extras_require={
|
2018-03-30 11:46:15 -07:00
|
|
|
':sys_platform=="win32"': ["pypiwin32"],
|
2016-08-08 12:35:54 -06:00
|
|
|
"test": [
|
2019-01-24 10:23:26 -05:00
|
|
|
# Pin a specific pyflakes so we don't have different folks
|
|
|
|
# disagreeing on what is or is not a lint issue. We can bump
|
|
|
|
# this version from time to time, but we will do it
|
|
|
|
# intentionally.
|
|
|
|
"pyflakes == 2.1.0",
|
2016-08-08 12:35:54 -06:00
|
|
|
"coverage",
|
|
|
|
"mock",
|
|
|
|
"tox",
|
2016-12-07 21:42:00 -08:00
|
|
|
"foolscap[tor] >= 0.12.5",
|
2016-10-05 18:24:25 -07:00
|
|
|
"txtorcon >= 0.17.0", # in case pip's resolver doesn't work
|
2017-04-03 18:18:27 +12:00
|
|
|
"foolscap[i2p] >= 0.12.6",
|
2017-04-03 18:22:04 +12:00
|
|
|
"txi2p >= 0.3.2", # in case pip's resolver doesn't work
|
2016-08-22 17:36:56 -06:00
|
|
|
"pytest",
|
|
|
|
"pytest-twisted",
|
2017-01-26 03:58:20 +00:00
|
|
|
"hypothesis >= 3.6.1",
|
2017-02-21 13:15:23 -08:00
|
|
|
"treq",
|
2018-08-06 11:40:44 -04:00
|
|
|
"towncrier",
|
2016-08-27 19:57:01 -07:00
|
|
|
],
|
|
|
|
"tor": [
|
2016-12-07 21:42:00 -08:00
|
|
|
"foolscap[tor] >= 0.12.5",
|
2016-10-05 18:24:25 -07:00
|
|
|
"txtorcon >= 0.17.0", # in case pip's resolver doesn't work
|
2016-08-27 19:57:01 -07:00
|
|
|
],
|
|
|
|
"i2p": [
|
2017-04-03 18:18:27 +12:00
|
|
|
"foolscap[i2p] >= 0.12.6",
|
2017-04-03 18:22:04 +12:00
|
|
|
"txi2p >= 0.3.2", # in case pip's resolver doesn't work
|
2016-08-08 12:35:54 -06:00
|
|
|
],
|
|
|
|
},
|
2014-03-29 00:41:33 +00:00
|
|
|
package_data={"allmydata.web": ["*.xhtml",
|
|
|
|
"static/*.js", "static/*.png", "static/*.css",
|
|
|
|
"static/img/*.png",
|
|
|
|
"static/css/*.css",
|
|
|
|
]
|
2012-01-08 10:16:54 -08:00
|
|
|
},
|
2007-12-31 23:28:31 -07:00
|
|
|
setup_requires=setup_requires,
|
2007-10-11 03:38:24 -07:00
|
|
|
entry_points = { 'console_scripts': [ 'tahoe = allmydata.scripts.runner:run' ] },
|
2009-08-17 18:00:57 -07:00
|
|
|
**setup_args
|
2007-04-27 13:47:15 -07:00
|
|
|
)
|