Skip to content

Commit

Permalink
Single source version and python dependencies, prevent people acciden…
Browse files Browse the repository at this point in the history
…tally installing with easy_install, use scripts rather than entry_points to install synctl
  • Loading branch information
Mark Haines committed Feb 10, 2015
1 parent c8e1da9 commit 7ed971d
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 44 deletions.
1 change: 0 additions & 1 deletion VERSION

This file was deleted.

80 changes: 40 additions & 40 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,52 +17,52 @@
import os
from setuptools import setup, find_packages

import setuptools.command.easy_install

# Utility function to read the README file.
# Used for the long_description. It's nice, because now 1) we have a top level
# README file and 2) it's easier to type in the README file than to put a raw
# string in below ...
def read(fname):
return open(os.path.join(os.path.dirname(__file__), fname)).read()

def no_easy_install(self, spec, *args, **kargs):
raise RuntimeError(
"Missing requirement %r. Please use pip to install this dependency."
" See README.rst for instructions."
% (spec,)
)

# Patch the easy_install command to prevent people accidentally installing
# depedencies using it.
setuptools.command.easy_install.easy_install.easy_install = no_easy_install


here = os.path.abspath(os.path.dirname(__file__))


def read_file(path):
"""Read a file from the package. Takes a list of strings to join to
make the path"""
file_path = os.path.join(here, *path)
with open(file_path) as f:
return f.read()


def exec_file(path):
"""Execute a single python file to get the variables defined in it"""
result = {}
code = read_file(path)
exec(code, result)
return result

version = exec_file(("synapse", "__init__.py"))["__version__"]
dependencies = exec_file(("synapse", "python_dependencies.py"))
long_description = read_file(("README.rst",))

setup(
name="matrix-synapse",
version=read("VERSION").strip(),
version=version,
packages=find_packages(exclude=["tests", "tests.*"]),
description="Reference Synapse Home Server",
install_requires=[
"syutil==0.0.2",
"matrix_angular_sdk>=0.6.1",
"Twisted==14.0.2",
"service_identity>=1.0.0",
"pyopenssl>=0.14",
"pyyaml",
"pyasn1",
"pynacl",
"daemonize",
"py-bcrypt",
"frozendict>=0.4",
"pillow",
"pydenticon",
],
dependency_links=[
"https://github.com/matrix-org/syutil/tarball/v0.0.2#egg=syutil-0.0.2",
"https://github.com/pyca/pynacl/tarball/d4d3175589b892f6ea7c22f466e0e223853516fa#egg=pynacl-0.3.0",
"https://github.com/matrix-org/matrix-angular-sdk/tarball/v0.6.1/#egg=matrix_angular_sdk-0.6.1",
],
setup_requires=[
"Twisted==14.0.2", # Here to override setuptools_trial's dependency on Twisted>=2.4.0
"setuptools_trial",
"setuptools>=1.0.0", # Needs setuptools that supports git+ssh.
# TODO: Do we need this now? we don't use git+ssh.
"mock"
],
install_requires=dependencies["REQUIREMENTS"].keys(),
dependency_links=dependencies["DEPENDENCY_LINKS"],
include_package_data=True,
zip_safe=False,
long_description=read("README.rst"),
entry_points="""
[console_scripts]
synctl=synapse.app.synctl:main
synapse-homeserver=synapse.app.homeserver:main
"""
long_description=long_description,
scripts=["synctl"],
)
6 changes: 3 additions & 3 deletions synapse/python_dependencies.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

REQUIREMENTS = {
"syutil==0.0.2": ["syutil"],
"matrix_angular_sdk==0.6.0": ["syweb>=0.6.0"],
"matrix_angular_sdk>=0.6.1": ["syweb>=0.6.1"],
"Twisted==14.0.2": ["twisted==14.0.2"],
"service_identity>=1.0.0": ["service_identity>=1.0.0"],
"pyopenssl>=0.14": ["OpenSSL>=0.14"],
Expand All @@ -31,8 +31,8 @@ def github_link(project, version, egg):
),
github_link(
project="matrix-org/matrix-angular-sdk",
version="v0.6.0",
egg="matrix_angular_sdk-0.6.0",
version="v0.6.1",
egg="matrix_angular_sdk-0.6.1",
),
github_link(
project="pyca/pynacl",
Expand Down

0 comments on commit 7ed971d

Please sign in to comment.