X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=src%2Fbindings%2Fpython%2Fbt2%2FMakefile.am;h=4be841442aa4134eea3979c21367e796ea09f5bd;hb=dd420a9b3f83cda6f77e8813165a061856d9d618;hp=54df1e5f18bc3250c427629e7d2dc3da333c0967;hpb=07041dafaae18146e189a70c33a8a0695cbdd813;p=babeltrace.git diff --git a/src/bindings/python/bt2/Makefile.am b/src/bindings/python/bt2/Makefile.am index 54df1e5f..4be84144 100644 --- a/src/bindings/python/bt2/Makefile.am +++ b/src/bindings/python/bt2/Makefile.am @@ -1,38 +1,55 @@ +# SPDX-License-Identifier: MIT + # Since the shared object used by the python bindings is not built with # libtool, we need to add the directory containing libbabeltrace2 to the # linker path. -AM_LDFLAGS=-L$(top_builddir)/src/lib/.libs +AM_LDFLAGS += -L$(top_builddir)/src/lib/.libs INSTALLED_FILES=$(builddir)/installed_files.txt SWIG_INTERFACE_FILES = \ bt2/native_bt.i \ + bt2/native_bt_autodisc.i \ + bt2/native_bt_autodisc.i.h \ + bt2/native_bt_bt2_objects.h \ bt2/native_bt_clock_class.i \ bt2/native_bt_clock_snapshot.i \ bt2/native_bt_component.i \ bt2/native_bt_component_class.i \ + bt2/native_bt_component_class.i.h \ bt2/native_bt_connection.i \ bt2/native_bt_error.i \ + bt2/native_bt_error.i.h \ bt2/native_bt_event.i \ bt2/native_bt_event_class.i \ bt2/native_bt_field.i \ bt2/native_bt_field_class.i \ bt2/native_bt_field_path.i \ bt2/native_bt_graph.i \ + bt2/native_bt_graph.i.h \ bt2/native_bt_integer_range_set.i \ bt2/native_bt_interrupter.i \ + bt2/native_bt_log_and_append_error.h \ bt2/native_bt_logging.i \ bt2/native_bt_message.i \ bt2/native_bt_message_iterator.i \ + bt2/native_bt_message_iterator.i.h \ + bt2/native_bt_mip.i \ + bt2/native_bt_mip.i.h \ bt2/native_bt_packet.i \ bt2/native_bt_plugin.i \ + bt2/native_bt_plugin.i.h \ bt2/native_bt_port.i \ bt2/native_bt_query_exec.i \ + bt2/native_bt_query_exec.i.h \ bt2/native_bt_stream.i \ bt2/native_bt_stream_class.i \ bt2/native_bt_trace.i \ + bt2/native_bt_trace.i.h \ bt2/native_bt_trace_class.i \ + bt2/native_bt_trace_class.i.h \ bt2/native_bt_value.i \ + bt2/native_bt_value.i.h \ bt2/native_bt_version.i # Non-generated files built into the native library. @@ -45,6 +62,7 @@ STATIC_BINDINGS_DEPS = \ bt2/clock_class.py \ bt2/clock_snapshot.py \ bt2/component.py \ + bt2/component_descriptor.py \ bt2/connection.py \ bt2/error.py \ bt2/event.py \ @@ -58,6 +76,7 @@ STATIC_BINDINGS_DEPS = \ bt2/logging.py \ bt2/message.py \ bt2/message_iterator.py \ + bt2/mip.py \ bt2/object.py \ bt2/packet.py \ bt2/plugin.py \ @@ -75,19 +94,41 @@ STATIC_BINDINGS_DEPS = \ # Convenience static libraries on which the Python bindings library depends. # These are listed in the setup.py(.in) file. STATIC_LIBRARIES_DEPS = \ - $(top_builddir)/src/logging/libbabeltrace2-logging.la \ + $(top_builddir)/src/autodisc/libautodisc.la \ + $(top_builddir)/src/logging/liblogging.la \ $(top_builddir)/src/common/libbabeltrace2-common.la \ - $(top_builddir)/src/py-common/libbabeltrace2-py-common.la + $(top_builddir)/src/py-common/libpy-common.la \ + $(top_builddir)/src/string-format/libstring-format.la GENERATED_BINDINGS_DEPS = \ bt2/native_bt.c \ bt2/version.py \ setup.py +# Some versions of SWIG (like 3.0.12) generate code where a parameter called +# `swig_this` shadows a global of the same name. Later versions (like 4.0.1) +# have renamed this global to `Swig_This_global`. +# +# Disable -Wshadow for that file. +WARN_CFLAGS = -Wno-shadow + +WARN_CFLAGS += -Wno-null-dereference + +# Python 3.8 with SWIG 4.0.2 generates a deprecated warning for 'tp_print' +# and in general there is not much we can do about deprecations in generated +# code. +WARN_CFLAGS += -Wno-deprecated-declarations + +# Python 3.11 + gcc 12.2.0 gave warnings of this kind in Python.h. +WARN_CFLAGS += -Wno-redundant-decls + +# For SWIG generated code +WARN_CFLAGS += -Wno-missing-field-initializers + BUILD_FLAGS=CC="$(CC)" \ - CFLAGS="$(GLIB_CFLAGS) $(AM_CFLAGS) $(CFLAGS)" \ + CFLAGS="$(GLIB_CFLAGS) $(AM_CFLAGS) $(CFLAGS) $(WARN_CFLAGS)" \ CPPFLAGS="$(AM_CPPFLAGS) $(CPPFLAGS) -I$(srcdir)/bt2" \ - LDFLAGS="$(AM_LDFLAGS) $(LDFLAGS) $(GLIB_LIBS) $(LIBS)" + LDFLAGS="$(AM_LDFLAGS) $(LDFLAGS) $(GLIB_LIBS) $(PYTHON_LDFLAGS) $(LIBS)" all-local: build-python-bindings.stamp @@ -109,14 +150,29 @@ swig_verbose_ = $(swig_verbose_@AM_DEFAULT_V@) swig_verbose_0 = @echo " SWIG " $@; $(builddir)/bt2/native_bt.c: $(SWIG_INTERFACE_FILES) - $(swig_verbose)$(SWIG) -python -I"$(top_srcdir)/include" -o "$@" "$<" + $(swig_verbose)$(SWIG) -MD -python -I"$(top_srcdir)/include" -o "$@" "$<" + +-include bt2/native_bt.d + +pyinstall_verbose = $(pyinstall_verbose_@AM_V@) +pyinstall_verbose_ = $(pyinstall_verbose_@AM_DEFAULT_V@) +pyinstall_verbose_0 = @ + +# For Python < 3.12, force the use of distutils even if setuptools is +# installed. For Python >= 3.12, set the externally managed option to allow +# installation in a directory which isn't in the current PYTHONPATH. +if HAVE_PYTHON_312_OR_GREATER +PY_INSTALL_OPTS = --single-version-externally-managed +else +export SETUPTOOLS_USE_DISTUTILS=stdlib +endif install-exec-local: build-python-bindings.stamp - @opts="--prefix=$(prefix) --record $(INSTALLED_FILES) --verbose --no-compile $(DISTSETUPOPTS)"; \ + $(pyinstall_verbose)opts="--prefix=$(prefix) --exec-prefix=$(exec_prefix) --record $(INSTALLED_FILES) --verbose --no-compile $(DISTSETUPOPTS)"; \ if [ "$(DESTDIR)" != "" ]; then \ opts="$$opts --root=$(DESTDIR)"; \ fi; \ - $(PYTHON) $(builddir)/setup.py install $$opts; + $(PYTHON) $(builddir)/setup.py install $(PY_INSTALL_OPTS) $$opts; clean-local: rm -rf $(builddir)/build @@ -141,4 +197,9 @@ uninstall-local: EXTRA_DIST = $(STATIC_BINDINGS_DEPS) $(SWIG_INTERFACE_FILES) $(STATIC_NATIVE_LIB_SRCS) # clean: generated C and Python files (by SWIG) -CLEANFILES = bt2/native_bt.py bt2/native_bt.c build-python-bindings.stamp copy-static-deps.stamp +CLEANFILES = \ + build-python-bindings.stamp \ + bt2/native_bt.c \ + bt2/native_bt.d \ + bt2/native_bt.py \ + copy-static-deps.stamp