-#
-# This file is part of the sigrok project.
-#
-# Copyright (C) 2013 Martin Ling <martin-sigrok@earth.li>
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+##
+## This file is part of the libsigrok project.
+##
+## Copyright (C) 2013 Martin Ling <martin-sigrok@earth.li>
+##
+## This program is free software: you can redistribute it and/or modify
+## it under the terms of the GNU General Public License as published by
+## the Free Software Foundation, either version 3 of the License, or
+## (at your option) any later version.
+##
+## This program is distributed in the hope that it will be useful,
+## but WITHOUT ANY WARRANTY; without even the implied warranty of
+## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+## GNU General Public License for more details.
+##
+## You should have received a copy of the GNU General Public License
+## along with this program. If not, see <http://www.gnu.org/licenses/>.
+##
-from distutils.core import setup, Extension
+from setuptools import setup, find_packages, Extension
import subprocess
+import os
-sr_includes = subprocess.check_output(
- ["pkg-config", "--cflags", "libsigrok"]).rstrip().split(' ')
+env = os.environ.copy()
-sr_libs = subprocess.check_output(
- ["pkg-config", "--libs", "libsigrok"]).rstrip().split(' ')
+sr_includes, sr_lib_dirs, sr_libs, (sr_version,) = [
+ subprocess.check_output(
+ ["pkg-config", option, "glib-2.0", "glibmm-2.4", "pygobject-3.0"]
+ ).decode().rstrip().split(' ')
+ for option in
+ ("--cflags-only-I", "--libs-only-L", "--libs-only-l", "--modversion")]
-sr_version = subprocess.check_output(
- ["pkg-config", "--version", "libsigrok"]).rstrip()
+includes = ['../../include', '../cxx/include'] + [i[2:] for i in sr_includes]
+libdirs = ['../../.libs', '../cxx/.libs'] + [l[2:] for l in sr_lib_dirs]
+libs = [l[2:] for l in sr_libs]
+
+extension_options = dict(
+ include_dirs = includes,
+ library_dirs = libdirs)
setup(
name = 'libsigrok',
+ namespace_packages = ['sigrok'],
+ packages = find_packages(),
version = sr_version,
description = "libsigrok API wrapper",
- py_modules = ['libsigrok'],
ext_modules = [
- Extension('_libsigrok',
- sources = ['libsigrok_python.i'],
- swig_opts = sr_includes,
- include_dirs = [i[2:] for i in sr_includes if i.startswith('-I')],
- library_dirs = [l[2:] for l in sr_libs if l.startswith('-L')],
- libraries = [l[2:] for l in sr_libs if l.startswith('-l')]
- )
+ Extension('sigrok.core._lowlevel',
+ sources = ['sigrok/core/lowlevel.i'],
+ swig_opts = ['-threads', '-I../../include'],
+ libraries = libs + ['sigrok'],
+ **extension_options),
+ Extension('sigrok.core._classes',
+ sources = ['sigrok/core/classes.i'],
+ swig_opts = ['-c++', '-threads'] +
+ ['-I%s' % i for i in includes],
+ extra_compile_args = ['-std=c++11'],
+ libraries = libs + ['sigrokxx'],
+ **extension_options)
],
)