import sys
import os.path
-import numpy
+import glob
from setuptools import setup, Extension
-from python.lib.moresetuptools import CleanGenerated, GenerateCommand
+
+# add ./python/lib to current path
+sys.path.append(os.path.join('python', 'lib')) # noqa
+from moresetuptools import build_ext, CleanGenerated
+
# function to generate gen/*.{c,h}
-from python.lib.gen_external import generate_external, header, output_path
+from this_version import get_aubio_version, get_aubio_pyversion
-# read from VERSION
-for l in open('VERSION').readlines(): exec (l.strip())
-__version__ = '.'.join \
- ([str(x) for x in [AUBIO_MAJOR_VERSION, AUBIO_MINOR_VERSION, AUBIO_PATCH_VERSION]]) \
- + AUBIO_VERSION_STATUS
+__version__ = get_aubio_pyversion()
+__aubio_version__ = get_aubio_version()
include_dirs = []
library_dirs = []
-define_macros = []
+define_macros = [('AUBIO_VERSION', '%s' % __aubio_version__)]
extra_link_args = []
-include_dirs += [ 'python/ext' ]
-include_dirs += [ output_path ] # aubio-generated.h
-include_dirs += [ numpy.get_include() ]
+include_dirs += ['python/ext']
+try:
+ import numpy
+ include_dirs += [numpy.get_include()]
+except ImportError:
+ pass
if sys.platform.startswith('darwin'):
- extra_link_args += ['-framework','CoreFoundation', '-framework','AudioToolbox']
+ extra_link_args += ['-framework', 'CoreFoundation',
+ '-framework', 'AudioToolbox']
-if os.path.isfile('src/aubio.h'):
- define_macros += [('USE_LOCAL_AUBIO', 1)]
- include_dirs += ['src'] # aubio.h
- library_dirs += ['build/src']
+sources = sorted(glob.glob(os.path.join('python', 'ext', '*.c')))
-aubio_extension = Extension("aubio._aubio", [
- "python/ext/aubiomodule.c",
- "python/ext/aubioproxy.c",
- "python/ext/ufuncs.c",
- "python/ext/py-musicutils.c",
- "python/ext/py-cvec.c",
- "python/ext/py-filter.c",
- "python/ext/py-filterbank.c",
- "python/ext/py-fft.c",
- "python/ext/py-phasevoc.c",
- "python/ext/py-source.c",
- "python/ext/py-sink.c",
- # generate files if they don't exit
- ] + generate_external(header, output_path, overwrite = False),
+aubio_extension = Extension("aubio._aubio",
+ sources,
include_dirs = include_dirs,
library_dirs = library_dirs,
extra_link_args = extra_link_args,
- define_macros = define_macros,
- libraries=['aubio'])
+ define_macros = define_macros)
+
+# TODO: find a way to track if package is built against libaubio
+# if os.path.isfile('src/aubio.h'):
+# if not os.path.isdir(os.path.join('build','src')):
+# pass
+# #__version__ += 'a2' # python only version
classifiers = [
'Development Status :: 4 - Beta',
'Operating System :: Microsoft :: Windows',
'Programming Language :: C',
'Programming Language :: Python',
- 'License :: OSI Approved :: GNU General Public License v3 or later (GPLv3+)',
+ 'License :: OSI Approved :: '
+ 'GNU General Public License v3 or later (GPLv3+)',
]
+thisdir = os.path.abspath(os.path.dirname(__file__))
+py_readme_file = os.path.join(thisdir, 'python', 'README.md')
+with open(py_readme_file, 'r') as fp:
+ long_description = ''.join(fp.readlines()[3:])
+
distrib = setup(name='aubio',
version = __version__,
packages = ['aubio'],
- package_dir = {'aubio':'python/lib/aubio'},
- scripts = ['python/scripts/aubiocut'],
+ package_dir = {'aubio': 'python/lib/aubio'},
ext_modules = [aubio_extension],
- description = 'interface to the aubio library',
- long_description = 'interface to the aubio library',
+ description = 'a collection of tools for music analysis',
+ long_description = long_description,
+ long_description_content_type = 'text/markdown',
license = 'GNU/GPL version 3',
author = 'Paul Brossier',
author_email = 'piem@aubio.org',
maintainer = 'Paul Brossier',
maintainer_email = 'piem@aubio.org',
- url = 'http://aubio.org/',
+ url = 'https://aubio.org/',
platforms = 'any',
classifiers = classifiers,
install_requires = ['numpy'],
+ setup_requires = ['numpy'],
cmdclass = {
'clean': CleanGenerated,
- 'generate': GenerateCommand,
+ 'build_ext': build_ext,
},
+ entry_points = {
+ 'console_scripts': [
+ 'aubio = aubio.cmd:main',
+ 'aubiocut = aubio.cut:main',
+ ],
+ },
test_suite = 'nose2.collector.collector',
+ extras_require = {
+ 'tests': ['numpy'],
+ },
)