notebook/setup.py

200 lines
6.1 KiB
Python
Raw Normal View History

#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""Setup script for Jupyter Notebook"""
#-----------------------------------------------------------------------------
# Copyright (c) 2015-, Jupyter Development Team.
# Copyright (c) 2008-2015, IPython Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file COPYING.md, distributed with this software.
#-----------------------------------------------------------------------------
from __future__ import print_function
2015-05-14 01:56:32 +08:00
name = "notebook"
#-----------------------------------------------------------------------------
# Minimal Python version sanity check
#-----------------------------------------------------------------------------
import sys
v = sys.version_info
if v[:2] < (2,7) or (v[0] >= 3 and v[:2] < (3,3)):
error = "ERROR: %s requires Python version 2.7 or 3.3 or above." % name
print(error, file=sys.stderr)
sys.exit(1)
PY3 = (sys.version_info[0] >= 3)
# At least we're on the python version we need, move on.
#-------------------------------------------------------------------------------
# Imports
#-------------------------------------------------------------------------------
import os
from glob import glob
# BEFORE importing distutils, remove MANIFEST. distutils doesn't properly
# update it when the contents of directories change.
if os.path.exists('MANIFEST'): os.remove('MANIFEST')
from distutils.core import setup
# Our own imports
from setupbase import (
version,
find_packages,
find_package_data,
check_package_data_first,
CompileCSS,
CompileJS,
JavascriptDependencies,
JavascriptVersion,
css_js_prerelease,
)
isfile = os.path.isfile
pjoin = os.path.join
setup_args = dict(
name = name,
2015-09-09 06:41:33 +08:00
description = "A web-based notebook environment for interactive computing",
2015-09-10 07:49:29 +08:00
long_description = """
2015-09-23 02:16:06 +08:00
The Jupyter Notebook is a web application that allows you to create and
share documents that contain live code, equations, visualizations, and
explanatory text. The Notebook has support for multiple programming
languages, sharing, and interactive widgets.
2015-09-10 07:49:29 +08:00
Read `the documentation <https://jupyter-notebook.readthedocs.io>`_
2015-09-23 02:16:06 +08:00
for more information.
2015-09-10 07:49:29 +08:00
""",
version = version,
scripts = glob(pjoin('scripts', '*')),
packages = find_packages(),
2016-06-11 04:57:55 +08:00
package_data = find_package_data(),
author = 'Jupyter Development Team',
author_email = 'jupyter@googlegroups.com',
url = 'http://jupyter.org',
license = 'BSD',
platforms = "Linux, Mac OS X, Windows",
keywords = ['Interactive', 'Interpreter', 'Shell', 'Web'],
classifiers = [
'Intended Audience :: Developers',
'Intended Audience :: System Administrators',
'Intended Audience :: Science/Research',
'License :: OSI Approved :: BSD License',
'Programming Language :: Python',
'Programming Language :: Python :: 2.7',
'Programming Language :: Python :: 3',
],
)
#---------------------------------------------------------------------------
# Find all the packages, package data, and data_files
#---------------------------------------------------------------------------
packages = find_packages()
package_data = find_package_data()
#---------------------------------------------------------------------------
2012-07-01 06:17:46 +08:00
# custom distutils commands
#---------------------------------------------------------------------------
2012-07-01 06:17:46 +08:00
# imports here, so they are after setuptools import if there was one
from distutils.command.build_py import build_py
2012-07-01 06:17:46 +08:00
from distutils.command.sdist import sdist
2012-07-01 06:17:46 +08:00
setup_args['cmdclass'] = {
'build_py': css_js_prerelease(
check_package_data_first(build_py)),
'sdist' : css_js_prerelease(sdist, strict=True),
'css' : CompileCSS,
'js' : CompileJS,
'jsdeps' : JavascriptDependencies,
'jsversion' : JavascriptVersion,
2012-07-01 06:17:46 +08:00
}
#---------------------------------------------------------------------------
# Handle scripts, dependencies, and setuptools specific things
#---------------------------------------------------------------------------
if any(arg.startswith('bdist') for arg in sys.argv):
import setuptools
# This dict is used for passing extra arguments that are setuptools
# specific to setup
setuptools_extra_args = {}
2014-01-31 10:46:23 +08:00
# setuptools requirements
pyzmq = 'pyzmq>=13'
setup_args['scripts'] = glob(pjoin('scripts', '*'))
2014-10-08 06:55:45 +08:00
install_requires = [
'jinja2',
'tornado>=4',
'ipython_genutils',
2016-06-11 04:57:55 +08:00
'traitlets>=4.2.1',
'jupyter_core',
'jupyter_client',
'nbformat',
2015-05-09 01:36:45 +08:00
'nbconvert',
2015-05-09 03:35:02 +08:00
'ipykernel', # bless IPython kernel for now
2014-10-08 06:55:45 +08:00
]
extras_require = {
':sys_platform != "win32"': ['terminado>=0.3.3'],
'test:python_version == "2.7"': ['mock'],
'test': ['nose', 'coverage', 'requests', 'nose_warnings_filters'],
2016-09-13 21:03:43 +08:00
'test:sys_platform == "win32"': ['nose-exclude'],
}
2014-01-31 10:46:23 +08:00
if 'setuptools' in sys.modules:
# setup.py develop should check for submodules
from setuptools.command.develop import develop
setup_args['cmdclass']['develop'] = css_js_prerelease(develop)
2015-04-14 00:40:49 +08:00
try:
from wheel.bdist_wheel import bdist_wheel
except ImportError:
pass
else:
setup_args['cmdclass']['bdist_wheel'] = css_js_prerelease(bdist_wheel)
2015-04-14 00:40:49 +08:00
setuptools_extra_args['zip_safe'] = False
2014-01-31 10:46:23 +08:00
setup_args['extras_require'] = extras_require
requires = setup_args['install_requires'] = install_requires
setup_args['entry_points'] = {
'console_scripts': [
'jupyter-notebook = notebook.notebookapp:main',
'jupyter-nbextension = notebook.nbextensions:main',
'jupyter-serverextension = notebook.serverextensions:main',
'jupyter-bundlerextension = notebook.bundler.bundlerextensions:main',
]
}
setup_args.pop('scripts', None)
#---------------------------------------------------------------------------
# Do the actual setup now
#---------------------------------------------------------------------------
setup_args.update(setuptools_extra_args)
def main():
setup(**setup_args)
if __name__ == '__main__':
main()