]> sigrok.org Git - libsigrok.git/blobdiff - Makefile.am
Build: Set local include directories in Makefile.am
[libsigrok.git] / Makefile.am
index 39423f54ab0d8b6a1ce47c5db376ef0487250667..c0a228656e2f2a1c190ea2808e64d7465c125163 100644 (file)
 
 ACLOCAL_AMFLAGS = -I autostuff
 
-AM_CPPFLAGS = -DFIRMWARE_DIR='"$(FIRMWARE_DIR)"'
+local_includes = -Iinclude -I$(srcdir)/include -I$(srcdir)/src
+local_includes += -Ibindings/cxx/include -I${srcdir}/bindings/cxx/include -Ibindings/cxx
+
+AM_CPPFLAGS = $(local_includes) -DFIRMWARE_DIR='"$(FIRMWARE_DIR)"'
 
 lib_LTLIBRARIES = libsigrok.la
 
 # Backend files
 libsigrok_la_SOURCES = \
-       backend.c \
-       device.c \
-       session.c \
-       session_file.c \
-       session_driver.c \
-       hwdriver.c \
-       trigger.c \
-       strutil.c \
-       log.c \
-       version.c \
-       error.c \
-       std.c
-
-# Input formats
-libsigrok_la_SOURCES += \
-       input/binary.c \
-       input/chronovu_la8.c \
-       input/csv.c \
-       input/input.c \
-       input/vcd.c \
-       input/wav.c
-
-# Output formats
-libsigrok_la_SOURCES += \
-       output/output.c \
-       output/analog.c \
-       output/ascii.c \
-       output/bits.c \
-       output/binary.c \
-       output/csv.c \
-       output/chronovu_la8.c \
-       output/gnuplot.c \
-       output/hex.c \
-       output/ols.c \
-       output/vcd.c
-
-# Hardware (common files)
-libsigrok_la_SOURCES += \
-       hardware/common/scpi.c \
-       hardware/common/scpi_tcp.c
+       src/backend.c \
+       src/device.c \
+       src/session.c \
+       src/session_file.c \
+       src/session_driver.c \
+       src/drivers.c \
+       src/hwdriver.c \
+       src/trigger.c \
+       src/soft-trigger.c \
+       src/analog.c \
+       src/fallback.c \
+       src/strutil.c \
+       src/log.c \
+       src/version.c \
+       src/error.c \
+       src/std.c
+
+# Input modules
+libsigrok_la_SOURCES += \
+       src/input/input.c \
+       src/input/binary.c \
+       src/input/chronovu_la8.c \
+       src/input/csv.c \
+       src/input/vcd.c \
+       src/input/wav.c
+
+# Output modules
+libsigrok_la_SOURCES += \
+       src/output/output.c \
+       src/output/analog.c \
+       src/output/ascii.c \
+       src/output/bits.c \
+       src/output/binary.c \
+       src/output/csv.c \
+       src/output/chronovu_la8.c \
+       src/output/wav.c \
+       src/output/gnuplot.c \
+       src/output/hex.c \
+       src/output/ols.c \
+       src/output/srzip.c \
+       src/output/vcd.c
+
+# Transform modules
+libsigrok_la_SOURCES += \
+       src/transform/transform.c \
+       src/transform/nop.c \
+       src/transform/scale.c \
+       src/transform/invert.c
+
+# SCPI support
+libsigrok_la_SOURCES += \
+       src/scpi/scpi.c \
+       src/scpi/scpi_tcp.c
 if NEED_RPC
 libsigrok_la_SOURCES += \
-       hardware/common/scpi_vxi.c \
-       hardware/common/vxi_clnt.c \
-       hardware/common/vxi_xdr.c \
-       hardware/common/vxi.h
+       src/scpi/scpi_vxi.c \
+       src/scpi/vxi_clnt.c \
+       src/scpi/vxi_xdr.c \
+       src/scpi/vxi.h
 endif
 if NEED_SERIAL
 libsigrok_la_SOURCES += \
-       hardware/common/serial.c \
-       hardware/common/scpi_serial.c
+       src/serial.c \
+       src/scpi/scpi_serial.c
 endif
 if NEED_USB
 libsigrok_la_SOURCES += \
-       hardware/common/ezusb.c \
-       hardware/common/usb.c \
-       hardware/common/scpi_usbtmc_libusb.c
+       src/ezusb.c \
+       src/usb.c \
+       src/scpi/scpi_usbtmc_libusb.c
 endif
 if NEED_VISA
 libsigrok_la_SOURCES += \
-       hardware/common/scpi_visa.c
+       src/scpi/scpi_visa.c
+endif
+if NEED_GPIB
+libsigrok_la_SOURCES += \
+       src/scpi/scpi_libgpib.c
 endif
 
-# Hardware (DMM parsers)
+# Modbus support
+libsigrok_la_SOURCES += \
+       src/modbus/modbus.c
+if NEED_SERIAL
 libsigrok_la_SOURCES += \
-       hardware/common/dmm/es519xx.c \
-       hardware/common/dmm/fs9721.c \
-       hardware/common/dmm/fs9922.c \
-       hardware/common/dmm/m2110.c \
-       hardware/common/dmm/metex14.c \
-       hardware/common/dmm/rs9lcd.c
+       src/modbus/modbus_serial_rtu.c
+endif
+
+# Hardware (DMM chip parsers)
+libsigrok_la_SOURCES += \
+       src/dmm/es519xx.c \
+       src/dmm/fs9721.c \
+       src/dmm/fs9922.c \
+       src/dmm/m2110.c \
+       src/dmm/metex14.c \
+       src/dmm/rs9lcd.c \
+       src/dmm/bm25x.c \
+       src/dmm/ut71x.c \
+       src/dmm/ut372.c \
+       src/dmm/vc870.c
+
+# Hardware (LCR chip parsers)
+if NEED_SERIAL
+libsigrok_la_SOURCES += \
+       src/lcr/es51919.c
+endif
 
 # Hardware drivers
 if HW_AGILENT_DMM
 libsigrok_la_SOURCES += \
-       hardware/agilent-dmm/api.c \
-       hardware/agilent-dmm/agilent-dmm.h \
-       hardware/agilent-dmm/sched.c
+       src/hardware/agilent-dmm/api.c \
+       src/hardware/agilent-dmm/agilent-dmm.h \
+       src/hardware/agilent-dmm/sched.c
 endif
 if HW_APPA_55II
 libsigrok_la_SOURCES += \
-       hardware/appa-55ii/protocol.h \
-       hardware/appa-55ii/protocol.c \
-       hardware/appa-55ii/api.c
+       src/hardware/appa-55ii/protocol.h \
+       src/hardware/appa-55ii/protocol.c \
+       src/hardware/appa-55ii/api.c
 endif
 if HW_ASIX_SIGMA
 libsigrok_la_SOURCES += \
-       hardware/asix-sigma/asix-sigma.h \
-       hardware/asix-sigma/asix-sigma.c
+       src/hardware/asix-sigma/asix-sigma.h \
+       src/hardware/asix-sigma/asix-sigma.c
 endif
 if HW_ATTEN_PPS3XXX
 libsigrok_la_SOURCES += \
-       hardware/atten-pps3xxx/protocol.h \
-       hardware/atten-pps3xxx/protocol.c \
-       hardware/atten-pps3xxx/api.c
+       src/hardware/atten-pps3xxx/protocol.h \
+       src/hardware/atten-pps3xxx/protocol.c \
+       src/hardware/atten-pps3xxx/api.c
+endif
+if HW_BAYLIBRE_ACME
+libsigrok_la_SOURCES += \
+       src/hardware/baylibre-acme/protocol.h \
+       src/hardware/baylibre-acme/protocol.c \
+       src/hardware/baylibre-acme/api.c \
+       src/hardware/baylibre-acme/gpio.h \
+       src/hardware/baylibre-acme/gpio.c
+endif
+if HW_BEAGLELOGIC
+libsigrok_la_SOURCES += \
+       src/hardware/beaglelogic/beaglelogic.h \
+       src/hardware/beaglelogic/protocol.h \
+       src/hardware/beaglelogic/protocol.c \
+       src/hardware/beaglelogic/api.c
 endif
 if HW_BRYMEN_BM86X
 libsigrok_la_SOURCES += \
-       hardware/brymen-bm86x/protocol.h \
-       hardware/brymen-bm86x/protocol.c \
-       hardware/brymen-bm86x/api.c
+       src/hardware/brymen-bm86x/protocol.h \
+       src/hardware/brymen-bm86x/protocol.c \
+       src/hardware/brymen-bm86x/api.c
 endif
 if HW_BRYMEN_DMM
 libsigrok_la_SOURCES += \
-       hardware/brymen-dmm/parser.c \
-       hardware/brymen-dmm/protocol.h \
-       hardware/brymen-dmm/protocol.c \
-       hardware/brymen-dmm/api.c
+       src/hardware/brymen-dmm/parser.c \
+       src/hardware/brymen-dmm/protocol.h \
+       src/hardware/brymen-dmm/protocol.c \
+       src/hardware/brymen-dmm/api.c
 endif
 if HW_CEM_DT_885X
 libsigrok_la_SOURCES += \
-       hardware/cem-dt-885x/protocol.h \
-       hardware/cem-dt-885x/protocol.c \
-       hardware/cem-dt-885x/api.c
+       src/hardware/cem-dt-885x/protocol.h \
+       src/hardware/cem-dt-885x/protocol.c \
+       src/hardware/cem-dt-885x/api.c
 endif
 if HW_CENTER_3XX
 libsigrok_la_SOURCES += \
-       hardware/center-3xx/protocol.h \
-       hardware/center-3xx/protocol.c \
-       hardware/center-3xx/api.c
+       src/hardware/center-3xx/protocol.h \
+       src/hardware/center-3xx/protocol.c \
+       src/hardware/center-3xx/api.c
 endif
 if HW_CHRONOVU_LA
 libsigrok_la_SOURCES += \
-       hardware/chronovu-la/protocol.h \
-       hardware/chronovu-la/protocol.c \
-       hardware/chronovu-la/api.c
+       src/hardware/chronovu-la/protocol.h \
+       src/hardware/chronovu-la/protocol.c \
+       src/hardware/chronovu-la/api.c
 endif
 if HW_COLEAD_SLM
 libsigrok_la_SOURCES += \
-       hardware/colead-slm/protocol.h \
-       hardware/colead-slm/protocol.c \
-       hardware/colead-slm/api.c
+       src/hardware/colead-slm/protocol.h \
+       src/hardware/colead-slm/protocol.c \
+       src/hardware/colead-slm/api.c
 endif
 if HW_CONRAD_DIGI_35_CPU
 libsigrok_la_SOURCES += \
-       hardware/conrad-digi-35-cpu/protocol.h \
-       hardware/conrad-digi-35-cpu/protocol.c \
-       hardware/conrad-digi-35-cpu/api.c
+       src/hardware/conrad-digi-35-cpu/protocol.h \
+       src/hardware/conrad-digi-35-cpu/protocol.c \
+       src/hardware/conrad-digi-35-cpu/api.c
 endif
 if HW_DEMO
 libsigrok_la_SOURCES += \
-       hardware/demo/demo.c
+       src/hardware/demo/demo.c
+endif
+if HW_DEREE_DE5000
+libsigrok_la_SOURCES += \
+       src/hardware/deree-de5000/api.c
 endif
 if HW_FLUKE_DMM
 libsigrok_la_SOURCES += \
-       hardware/fluke-dmm/fluke-dmm.h \
-       hardware/fluke-dmm/fluke.c \
-       hardware/fluke-dmm/api.c
+       src/hardware/fluke-dmm/fluke-dmm.h \
+       src/hardware/fluke-dmm/fluke.c \
+       src/hardware/fluke-dmm/api.c
 endif
 if HW_FX2LAFW
 libsigrok_la_SOURCES += \
-       hardware/fx2lafw/protocol.h \
-       hardware/fx2lafw/protocol.c \
-       hardware/fx2lafw/api.c
+       src/hardware/fx2lafw/protocol.h \
+       src/hardware/fx2lafw/protocol.c \
+       src/hardware/fx2lafw/api.c \
+       src/hardware/fx2lafw/dslogic.c \
+       src/hardware/fx2lafw/dslogic.h
 endif
 if HW_GMC_MH_1X_2X
 libsigrok_la_SOURCES += \
-       hardware/gmc-mh-1x-2x/protocol.h \
-       hardware/gmc-mh-1x-2x/protocol.c \
-       hardware/gmc-mh-1x-2x/api.c
+       src/hardware/gmc-mh-1x-2x/protocol.h \
+       src/hardware/gmc-mh-1x-2x/protocol.c \
+       src/hardware/gmc-mh-1x-2x/api.c
 endif
 if HW_HAMEG_HMO
 libsigrok_la_SOURCES += \
-       hardware/hameg-hmo/protocol.h \
-       hardware/hameg-hmo/protocol.c \
-       hardware/hameg-hmo/api.c
+       src/hardware/hameg-hmo/protocol.h \
+       src/hardware/hameg-hmo/protocol.c \
+       src/hardware/hameg-hmo/api.c
 endif
 if HW_HANTEK_DSO
 libsigrok_la_SOURCES += \
-       hardware/hantek-dso/dso.h \
-       hardware/hantek-dso/dso.c \
-       hardware/hantek-dso/api.c
+       src/hardware/hantek-dso/dso.h \
+       src/hardware/hantek-dso/dso.c \
+       src/hardware/hantek-dso/api.c
 endif
 if HW_IKALOGIC_SCANALOGIC2
 libsigrok_la_SOURCES += \
-       hardware/ikalogic-scanalogic2/protocol.h \
-       hardware/ikalogic-scanalogic2/protocol.c \
-       hardware/ikalogic-scanalogic2/api.c
+       src/hardware/ikalogic-scanalogic2/protocol.h \
+       src/hardware/ikalogic-scanalogic2/protocol.c \
+       src/hardware/ikalogic-scanalogic2/api.c
 endif
 if HW_IKALOGIC_SCANAPLUS
 libsigrok_la_SOURCES += \
-       hardware/ikalogic-scanaplus/protocol.h \
-       hardware/ikalogic-scanaplus/protocol.c \
-       hardware/ikalogic-scanaplus/api.c
+       src/hardware/ikalogic-scanaplus/protocol.h \
+       src/hardware/ikalogic-scanaplus/protocol.c \
+       src/hardware/ikalogic-scanaplus/api.c
 endif
 if HW_KECHENG_KC_330B
 libsigrok_la_SOURCES += \
-       hardware/kecheng-kc-330b/protocol.h \
-       hardware/kecheng-kc-330b/protocol.c \
-       hardware/kecheng-kc-330b/api.c
+       src/hardware/kecheng-kc-330b/protocol.h \
+       src/hardware/kecheng-kc-330b/protocol.c \
+       src/hardware/kecheng-kc-330b/api.c
 endif
 if HW_LASCAR_EL_USB
 libsigrok_la_SOURCES += \
-       hardware/lascar-el-usb/protocol.h \
-       hardware/lascar-el-usb/protocol.c \
-       hardware/lascar-el-usb/api.c
+       src/hardware/lascar-el-usb/protocol.h \
+       src/hardware/lascar-el-usb/protocol.c \
+       src/hardware/lascar-el-usb/api.c
+endif
+if HW_MANSON_HCS_3XXX
+libsigrok_la_SOURCES += \
+       src/hardware/manson-hcs-3xxx/protocol.h \
+       src/hardware/manson-hcs-3xxx/protocol.c \
+       src/hardware/manson-hcs-3xxx/api.c
+endif
+if HW_MAYNUO_M97
+libsigrok_la_SOURCES += \
+       src/hardware/maynuo-m97/protocol.h \
+       src/hardware/maynuo-m97/protocol.c \
+       src/hardware/maynuo-m97/api.c
 endif
 if HW_MIC_985XX
 libsigrok_la_SOURCES += \
-       hardware/mic-985xx/protocol.h \
-       hardware/mic-985xx/protocol.c \
-       hardware/mic-985xx/api.c
+       src/hardware/mic-985xx/protocol.h \
+       src/hardware/mic-985xx/protocol.c \
+       src/hardware/mic-985xx/api.c
 endif
 if HW_MOTECH_LPS_30X
 libsigrok_la_SOURCES += \
-       hardware/motech-lps-30x/protocol.h \
-       hardware/motech-lps-30x/protocol.c \
-       hardware/motech-lps-30x/api.c
+       src/hardware/motech-lps-30x/protocol.h \
+       src/hardware/motech-lps-30x/protocol.c \
+       src/hardware/motech-lps-30x/api.c
 endif
 if HW_NORMA_DMM
 libsigrok_la_SOURCES += \
-       hardware/norma-dmm/protocol.h \
-       hardware/norma-dmm/protocol.c \
-       hardware/norma-dmm/api.c
+       src/hardware/norma-dmm/protocol.h \
+       src/hardware/norma-dmm/protocol.c \
+       src/hardware/norma-dmm/api.c
 endif
-if HW_OLS
+if HW_OPENBENCH_LOGIC_SNIFFER
 libsigrok_la_SOURCES += \
-       hardware/openbench-logic-sniffer/protocol.h \
-       hardware/openbench-logic-sniffer/protocol.c \
-       hardware/openbench-logic-sniffer/api.c
+       src/hardware/openbench-logic-sniffer/protocol.h \
+       src/hardware/openbench-logic-sniffer/protocol.c \
+       src/hardware/openbench-logic-sniffer/api.c
+endif
+if HW_PIPISTRELLO_OLS
+libsigrok_la_SOURCES += \
+       src/hardware/pipistrello-ols/protocol.h \
+       src/hardware/pipistrello-ols/protocol.c \
+       src/hardware/pipistrello-ols/api.c
 endif
 if HW_RIGOL_DS
 libsigrok_la_SOURCES += \
-       hardware/rigol-ds/protocol.h \
-       hardware/rigol-ds/protocol.c \
-       hardware/rigol-ds/api.c
+       src/hardware/rigol-ds/protocol.h \
+       src/hardware/rigol-ds/protocol.c \
+       src/hardware/rigol-ds/api.c
 endif
 if HW_SALEAE_LOGIC16
 libsigrok_la_SOURCES += \
-       hardware/saleae-logic16/protocol.h \
-       hardware/saleae-logic16/protocol.c \
-       hardware/saleae-logic16/api.c
+       src/hardware/saleae-logic16/protocol.h \
+       src/hardware/saleae-logic16/protocol.c \
+       src/hardware/saleae-logic16/api.c
+endif
+if HW_SCPI_PPS
+libsigrok_la_SOURCES += \
+       src/hardware/scpi-pps/protocol.h \
+       src/hardware/scpi-pps/protocol.c \
+       src/hardware/scpi-pps/profiles.c \
+       src/hardware/scpi-pps/api.c
 endif
 if HW_SERIAL_DMM
 libsigrok_la_SOURCES += \
-       hardware/serial-dmm/protocol.h \
-       hardware/serial-dmm/protocol.c \
-       hardware/serial-dmm/api.c
+       src/hardware/serial-dmm/protocol.h \
+       src/hardware/serial-dmm/protocol.c \
+       src/hardware/serial-dmm/api.c
 endif
 if HW_SYSCLK_LWLA
 libsigrok_la_SOURCES += \
-       hardware/sysclk-lwla/lwla.h \
-       hardware/sysclk-lwla/lwla.c \
-       hardware/sysclk-lwla/protocol.h \
-       hardware/sysclk-lwla/protocol.c \
-       hardware/sysclk-lwla/api.c
+       src/hardware/sysclk-lwla/lwla.h \
+       src/hardware/sysclk-lwla/lwla.c \
+       src/hardware/sysclk-lwla/protocol.h \
+       src/hardware/sysclk-lwla/protocol.c \
+       src/hardware/sysclk-lwla/api.c
 endif
 if HW_TELEINFO
 libsigrok_la_SOURCES += \
-       hardware/teleinfo/protocol.h \
-       hardware/teleinfo/protocol.c \
-       hardware/teleinfo/api.c
+       src/hardware/teleinfo/protocol.h \
+       src/hardware/teleinfo/protocol.c \
+       src/hardware/teleinfo/api.c
+endif
+if HW_TESTO
+libsigrok_la_SOURCES += \
+       src/hardware/testo/protocol.h \
+       src/hardware/testo/protocol.c \
+       src/hardware/testo/api.c
 endif
 if HW_TONDAJ_SL_814
 libsigrok_la_SOURCES += \
-       hardware/tondaj-sl-814/protocol.h \
-       hardware/tondaj-sl-814/protocol.c \
-       hardware/tondaj-sl-814/api.c
+       src/hardware/tondaj-sl-814/protocol.h \
+       src/hardware/tondaj-sl-814/protocol.c \
+       src/hardware/tondaj-sl-814/api.c
 endif
 if HW_UNI_T_DMM
 libsigrok_la_SOURCES += \
-       hardware/uni-t-dmm/protocol.h \
-       hardware/uni-t-dmm/protocol.c \
-       hardware/uni-t-dmm/api.c
+       src/hardware/uni-t-dmm/protocol.h \
+       src/hardware/uni-t-dmm/protocol.c \
+       src/hardware/uni-t-dmm/api.c
 endif
 if HW_UNI_T_UT32X
 libsigrok_la_SOURCES += \
-       hardware/uni-t-ut32x/protocol.h \
-       hardware/uni-t-ut32x/protocol.c \
-       hardware/uni-t-ut32x/api.c
+       src/hardware/uni-t-ut32x/protocol.h \
+       src/hardware/uni-t-ut32x/protocol.c \
+       src/hardware/uni-t-ut32x/api.c
 endif
 if HW_VICTOR_DMM
 libsigrok_la_SOURCES += \
-       hardware/victor-dmm/protocol.h \
-       hardware/victor-dmm/protocol.c \
-       hardware/victor-dmm/api.c
+       src/hardware/victor-dmm/protocol.h \
+       src/hardware/victor-dmm/protocol.c \
+       src/hardware/victor-dmm/api.c
+endif
+if HW_YOKOGAWA_DLM
+libsigrok_la_SOURCES += \
+       src/hardware/yokogawa-dlm/protocol.h \
+       src/hardware/yokogawa-dlm/protocol.c \
+       src/hardware/yokogawa-dlm/protocol_wrappers.h \
+       src/hardware/yokogawa-dlm/protocol_wrappers.c \
+       src/hardware/yokogawa-dlm/api.c
 endif
 if HW_ZEROPLUS_LOGIC_CUBE
 libsigrok_la_SOURCES += \
-       hardware/zeroplus-logic-cube/analyzer.c \
-       hardware/zeroplus-logic-cube/analyzer.h \
-       hardware/zeroplus-logic-cube/gl_usb.h \
-       hardware/zeroplus-logic-cube/gl_usb.c \
-       hardware/zeroplus-logic-cube/protocol.h \
-       hardware/zeroplus-logic-cube/protocol.c \
-       hardware/zeroplus-logic-cube/api.c
+       src/hardware/zeroplus-logic-cube/analyzer.c \
+       src/hardware/zeroplus-logic-cube/analyzer.h \
+       src/hardware/zeroplus-logic-cube/gl_usb.h \
+       src/hardware/zeroplus-logic-cube/gl_usb.c \
+       src/hardware/zeroplus-logic-cube/protocol.h \
+       src/hardware/zeroplus-logic-cube/protocol.c \
+       src/hardware/zeroplus-logic-cube/api.c
 endif
 
 libsigrok_la_LIBADD = $(LIBOBJS)
 
 libsigrok_la_LDFLAGS = $(SR_LIB_LDFLAGS)
 
+libsigrok_la_LDFLAGS += -no-undefined
+
 library_includedir = $(includedir)/libsigrok
-library_include_HEADERS = libsigrok.h proto.h version.h
-noinst_HEADERS = libsigrok-internal.h
+library_include_HEADERS = \
+       include/libsigrok/libsigrok.h \
+       include/libsigrok/proto.h \
+       include/libsigrok/version.h
+noinst_HEADERS = src/libsigrok-internal.h
 
 pkgconfigdir = $(libdir)/pkgconfig
 pkgconfig_DATA = libsigrok.pc
@@ -339,29 +442,191 @@ EXTRA_DIST = \
 
 if HAVE_CHECK
 
-TESTS = tests/check_main
+TESTS = tests/main
 
 check_PROGRAMS = ${TESTS}
 
-tests_check_main_SOURCES = \
-       libsigrok.h \
+tests_main_SOURCES = \
+       include/libsigrok/libsigrok.h \
        tests/lib.c \
        tests/lib.h \
-       tests/check_main.c \
-       tests/check_core.c \
-       tests/check_input_all.c \
-       tests/check_input_binary.c \
-       tests/check_output_all.c \
-       tests/check_strutil.c \
-       tests/check_version.c \
-       tests/check_driver_all.c
+       tests/main.c \
+       tests/core.c \
+       tests/input_all.c \
+       tests/input_binary.c \
+       tests/output_all.c \
+       tests/transform_all.c \
+       tests/session.c \
+       tests/strutil.c \
+       tests/version.c \
+       tests/driver_all.c \
+       tests/device.c \
+       tests/trigger.c
 
-tests_check_main_CFLAGS = @check_CFLAGS@
+tests_main_CFLAGS = @check_CFLAGS@
 
-tests_check_main_LDADD = $(top_builddir)/libsigrok.la @check_LIBS@
+tests_main_LDADD = $(top_builddir)/libsigrok.la @check_LIBS@
 
 endif
 
+BUILD_EXTRA =
+INSTALL_EXTRA =
+CLEAN_EXTRA =
+
+if BINDINGS_CXX
+
+lib_LTLIBRARIES += bindings/cxx/libsigrokcxx.la
+
+bindings_cxx_libsigrokcxx_la_SOURCES = bindings/cxx/classes.cpp
+
+bindings_cxx_libsigrokcxx_la_LIBADD = libsigrok.la $(glibmm_LIBS)
+
+bindings_cxx_libsigrokcxx_la_LDFLAGS = $(SR_LIB_LDFLAGS)
+
+bindings_cxx_libsigrokcxx_la_LDFLAGS += -no-undefined
+
+bindings_cxx_libsigrokcxx_la_includedir = $(includedir)/libsigrokcxx
+bindings_cxx_libsigrokcxx_la_include_HEADERS = \
+       bindings/cxx/include/libsigrokcxx/libsigrokcxx.hpp \
+       bindings/cxx/include/libsigrokcxx/enums.hpp
+
+pkgconfig_DATA += bindings/cxx/libsigrokcxx.pc
+
+doxy/xml/index.xml: include/libsigrok/libsigrok.h
+       $(AM_V_GEN)cd $(srcdir) && BUILDDIR=$(abs_builddir)/ doxygen Doxyfile 2>/dev/null
+
+bindings/cxx/enums.cpp: bindings/cxx/enums.timestamp
+
+bindings/cxx/include/libsigrokcxx/enums.hpp: bindings/cxx/enums.timestamp
+
+bindings/cxx/enums.timestamp: $(srcdir)/bindings/cxx/enums.py doxy/xml/index.xml \
+               bindings/cxx/ConfigKey_methods.cpp bindings/cxx/QuantityFlag_methods.cpp
+       $(AM_V_GEN)$(PYTHON) $(srcdir)/bindings/cxx/enums.py doxy/xml/index.xml
+       $(AM_V_at)touch $@
+
+bindings/cxx/classes.lo: bindings/cxx/classes.cpp bindings/cxx/enums.cpp \
+               $(library_include_HEADERS)
+
+cxx-clean:
+       rm -rf doxy/
+       rm -rf bindings/cxx/doxy/
+       rm -f bindings/cxx/enums.cpp
+       rm -f bindings/cxx/include/libsigrokcxx/enums.hpp
+       rm -f bindings/cxx/enums.timestamp
+
+CLEAN_EXTRA += cxx-clean
+
+endif
+
+CPPXMLDOC = bindings/cxx/doxy/xml/index.xml
+
+$(CPPXMLDOC): bindings/cxx/include/libsigrokcxx/libsigrokcxx.hpp \
+               bindings/cxx/enums.timestamp
+       $(AM_V_GEN)cd $(srcdir)/bindings/cxx && BUILDDIR=$(abs_builddir)/bindings/cxx/ doxygen Doxyfile 2>/dev/null
+
+if BINDINGS_PYTHON
+
+PDIR = bindings/python
+PDOC = bindings/python/sigrok/core/doc.i
+
+$(PDOC): bindings/swig/doc.py $(CPPXMLDOC)
+       $(AM_V_at)test -d $(PDIR)/sigrok/core || $(MKDIR_P) $(PDIR)/sigrok/core
+       $(AM_V_GEN)$(PYTHON) $< python $(CPPXMLDOC) > $@
+
+python-build: $(PDIR)/timestamp
+
+python-quietclean:
+       $(AM_V_at)cd $(PDIR) && $(PYTHON) $(abs_srcdir)/$(PDIR)/setup.py --quiet clean --all 3>&1 1>&2 2>&3 \
+               | grep -v "can.t clean it"; true
+
+$(PDIR)/timestamp: bindings/cxx/libsigrokcxx.la $(PDIR)/sigrok/core/classes.i \
+               bindings/swig/classes.i $(PDOC) $(library_include_HEADERS)
+       $(AM_V_at)$(MAKE) python-quietclean
+       $(AM_V_GEN)cd $(PDIR) && $(PYTHON) $(abs_srcdir)/$(PDIR)/setup.py --quiet build 3>&1 1>&2 2>&3 \
+               | grep -v "command line option.*Wstrict-prototypes"; true
+       $(AM_V_at)touch $(PDIR)/timestamp
+
+$(DESTDIR)$(prefix):
+       $(MKDIR_P) $@
+
+python-install: $(DESTDIR)$(prefix)
+       cd $(PDIR) && $(PYTHON) $(abs_srcdir)/$(PDIR)/setup.py --quiet install --prefix $(prefix) `test "$(DESTDIR)" && echo --root=$(DESTDIR)`
+
+python-clean:
+       $(AM_V_at)$(MAKE) python-quietclean
+       $(AM_V_at)rm -f $(PDIR)/timestamp
+       $(AM_V_at)rm -rf $(PDIR)/doxy/
+
+python-doc:
+       $(AM_V_at)cd $(srcdir)/$(PDIR) && BUILDDIR=$(abs_builddir)/$(PDIR)/ doxygen Doxyfile 2>/dev/null
+
+BUILD_EXTRA += python-build
+INSTALL_EXTRA += python-install
+CLEAN_EXTRA += python-clean
+
+endif
+
+if BINDINGS_JAVA
+
+JDIR = bindings/java
+JPKG = org/sigrok/core
+JCLS = $(JDIR)/$(JPKG)/classes
+JINT = $(JDIR)/$(JPKG)/interfaces
+JSRC = $(JCLS)/*.java $(srcdir)/$(JINT)/*.java
+JSWG = $(JCLS)/classes.i
+JDOC = $(JCLS)/doc.i
+JCXX = $(JCLS)/classes_wrap.cxx
+JLIB = $(JDIR)/libsigrok_java_core_classes.so
+JJAR = $(JDIR)/sigrok-core.jar
+
+java-build: $(JJAR) $(JLIB)
+
+$(JDOC): bindings/swig/doc.py $(CPPXMLDOC)
+       $(AM_V_at)test -d $(JCLS) || $(MKDIR_P) $(JCLS)
+       $(AM_V_GEN)python $< java $(CPPXMLDOC) > $@
+
+$(JCXX): $(JSWG) $(JDOC) bindings/swig/classes.i $(library_include_HEADERS)
+       $(AM_V_at)make java-clean
+       $(AM_V_GEN)swig -c++ -java -package org.sigrok.core.classes \
+               $(local_includes) -I$(JCLS) -I. -I$(srcdir) -outdir $(JCLS) -o $@ $<
+
+$(JJAR): $(JCXX)
+       $(AM_V_GEN)$(JAVAC) -sourcepath $(JDIR) -d $(JDIR) $(JSRC)
+       $(AM_V_at)jar cf $(JJAR) -C $(JDIR) $(JPKG)
+
+$(JLIB): $(JCXX) bindings/cxx/libsigrokcxx.la $(library_include_HEADERS)
+       $(AM_V_GEN)$(CXXCOMPILE) -L.libs -Lbindings/cxx/.libs \
+               -fno-strict-aliasing -fPIC -shared $(JCLS)/classes_wrap.cxx \
+               -lsigrokcxx -o $(JLIB)
+
+java-install:
+       $(INSTALL) -d $(DESTDIR)$(libdir)/jni
+       $(INSTALL) $(JLIB) -t $(DESTDIR)$(libdir)/jni
+       $(INSTALL) -d $(DESTDIR)$(datadir)/java
+       $(INSTALL) $(JJAR) -t $(DESTDIR)$(datadir)/java
+
+java-clean:
+       $(AM_V_at)rm -f $(JCXX)
+       $(AM_V_at)rm -f $(JCLS)/*.java
+       $(AM_V_at)rm -f $(JCLS)/*.class
+       $(AM_V_at)rm -f $(JINT)/*.class
+       $(AM_V_at)rm -f $(JJAR)
+       $(AM_V_at)rm -f $(JLIB)
+       $(AM_V_at)rm -rf $(JDIR)/doxy/
+
+java-doc:
+       $(AM_V_at)cd $(srcdir)/$(JDIR) && BUILDDIR=$(abs_builddir)/$(JDIR)/ doxygen Doxyfile 2>/dev/null
+
+BUILD_EXTRA += java-build
+INSTALL_EXTRA += java-install
+CLEAN_EXTRA += java-clean
+
+endif
+
+all-local: $(BUILD_EXTRA)
+install-exec-local: $(INSTALL_EXTRA)
+clean-local: $(CLEAN_EXTRA)
+
 MAINTAINERCLEANFILES = ChangeLog
 
 .PHONY: ChangeLog