spaCy/setup.py

109 lines
3.9 KiB
Python
Raw Normal View History

2014-07-05 22:49:34 +04:00
#!/usr/bin/env python
import Cython.Distutils
from Cython.Distutils import Extension
2014-07-05 22:49:34 +04:00
import distutils.core
import sys
import os
import os.path
2014-10-22 03:17:26 +04:00
2014-07-05 22:49:34 +04:00
from os import path
from glob import glob
2014-07-05 22:49:34 +04:00
import numpy
2014-07-05 22:49:34 +04:00
def clean(ext):
for pyx in ext.sources:
if pyx.endswith('.pyx'):
c = pyx[:-4] + '.c'
cpp = pyx[:-4] + '.cpp'
so = pyx[:-4] + '.so'
html = pyx[:-4] + '.html'
if os.path.exists(so):
os.unlink(so)
if os.path.exists(c):
os.unlink(c)
elif os.path.exists(cpp):
os.unlink(cpp)
if os.path.exists(html):
os.unlink(html)
2015-01-02 17:59:43 +03:00
def files_in(directory):
filenames = []
for fn in os.listdir(directory):
filenames.append(path.join(directory, fn))
return [f for f in filenames if not path.isdir(f)]
2014-07-05 22:49:34 +04:00
HERE = os.path.dirname(__file__)
virtual_env = os.environ.get('VIRTUAL_ENV', '')
compile_args = []
link_args = []
libs = []
includes = ['.', numpy.get_include()]
cython_includes = ['.']
2014-07-05 22:49:34 +04:00
if 'VIRTUAL_ENV' in os.environ:
includes += glob(path.join(os.environ['VIRTUAL_ENV'], 'include', 'site', '*'))
else:
# If you're not using virtualenv, set your include dir here.
pass
ext_args = {'language': "c++", "include_dirs": includes}
2014-07-05 22:49:34 +04:00
exts = [
2014-12-30 13:20:55 +03:00
Extension("spacy.typedefs", ["spacy/typedefs.pyx"], **ext_args),
Extension("spacy.strings", ["spacy/strings.pyx"], **ext_args),
Extension("spacy.lexeme", ["spacy/lexeme.pyx"], **ext_args),
Extension("spacy.vocab", ["spacy/vocab.pyx"], **ext_args),
Extension("spacy.tokens", ["spacy/tokens.pyx"], **ext_args),
Extension("spacy.morphology", ["spacy/morphology.pyx"], **ext_args),
2014-12-30 13:20:55 +03:00
Extension("spacy._ml", ["spacy/_ml.pyx"], **ext_args),
Extension("spacy.tokenizer", ["spacy/tokenizer.pyx"], **ext_args),
2014-12-23 07:18:20 +03:00
Extension("spacy.en.attrs", ["spacy/en/attrs.pyx"], **ext_args),
Extension("spacy.en.pos", ["spacy/en/pos.pyx"], **ext_args),
2014-12-23 07:18:20 +03:00
Extension("spacy.syntax.parser", ["spacy/syntax/parser.pyx"], **ext_args),
Extension("spacy.syntax._state", ["spacy/syntax/_state.pyx"], **ext_args),
Extension("spacy.syntax.arc_eager", ["spacy/syntax/arc_eager.pyx"], **ext_args),
2014-12-23 07:18:20 +03:00
Extension("spacy.syntax._parse_features", ["spacy/syntax/_parse_features.pyx"],
**ext_args)
2014-12-17 13:10:12 +03:00
#Extension("spacy.pos_feats", ["spacy/pos_feats.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner._state", ["spacy/ner/_state.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.bilou_moves", ["spacy/ner/bilou_moves.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.io_moves", ["spacy/ner/io_moves.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.greedy_parser", ["spacy/ner/greedy_parser.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.pystate", ["spacy/ner/pystate.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.context", ["spacy/ner/context.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.feats", ["spacy/ner/feats.pyx"], language="c++", include_dirs=includes),
#Extension("spacy.ner.annot", ["spacy/ner/annot.pyx"], language="c++", include_dirs=includes),
2014-07-05 22:49:34 +04:00
]
if sys.argv[1] == 'clean':
print >> sys.stderr, "cleaning .c, .c++ and .so files matching sources"
map(clean, exts)
distutils.core.setup(
2014-10-22 03:17:26 +04:00
name='spacy',
2015-01-02 13:56:43 +03:00
packages=['spacy', 'spacy.en', 'spacy.syntax'],
description="Industrial-strength NLP",
2014-07-05 22:49:34 +04:00
author='Matthew Honnibal',
author_email='honnibal@gmail.com',
2015-01-02 17:59:43 +03:00
version='0.1',
2015-01-02 13:56:43 +03:00
url="http://honnibal.github.io/spaCy/",
2015-01-02 17:59:43 +03:00
package_data={"spacy": ["*.pxd"], "spacy.en": ["*.pxd", "data/pos/*",
"data/wordnet/*", "data/tokenizer/*",
"data/vocab/*"],
2015-01-02 13:56:43 +03:00
"spacy.syntax": ["*.pxd"]},
2014-07-05 22:49:34 +04:00
cmdclass={'build_ext': Cython.Distutils.build_ext},
ext_modules=exts,
2015-01-02 17:59:43 +03:00
license="Dual: Commercial or AGPL"
2014-07-05 22:49:34 +04:00
)