aboutsummaryrefslogtreecommitdiff
path: root/src/Makefile.univalue.include
diff options
context:
space:
mode:
authorCory Fields <cory-nospam-@coryfields.com>2021-07-15 18:42:17 +0000
committerfanquake <fanquake@gmail.com>2021-10-11 20:46:25 +0800
commit0f95247246344510c9a51810c14c633abb382e95 (patch)
tree2a358d0f78162cb6a2b1bb36a1df5a7acdc5a431 /src/Makefile.univalue.include
parent304319367595b51abfd69f1c4abddeef0acca3a9 (diff)
Integrate univalue into our buildsystem
This addresses issues like the one in #12467, where some of our compiler flags end up being dropped during the subconfigure of Univalue. Specifically, we're still using the compiler-default c++ version rather than forcing c++17. We can drop the need subconfigure completely in favor of a tighter build integration, where the sources are listed separately from the build recipes, so that they may be included directly by upstream projects. This is similar to the way leveldb build integration works in Core. Core benefits of this approach include: - Better caching (for ex. ccache and autoconf) - No need for a slow subconfigure - Faster autoconf - No more missing compile flags - Compile only the objects needed There are no benefits to Univalue itself that I can think of. These changes should be a no-op there, and to downstreams as well until they take advantage of the new sources.mk. This also removes the option to use an external univalue to avoid similar ABI issues with mystery binaries. Co-authored-by: fanquake <fanquake@gmail.com>
Diffstat (limited to 'src/Makefile.univalue.include')
-rw-r--r--src/Makefile.univalue.include6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/Makefile.univalue.include b/src/Makefile.univalue.include
new file mode 100644
index 0000000000..3644e36368
--- /dev/null
+++ b/src/Makefile.univalue.include
@@ -0,0 +1,6 @@
+include univalue/sources.mk
+
+LIBUNIVALUE = libunivalue.la
+noinst_LTLIBRARIES += $(LIBUNIVALUE)
+libunivalue_la_SOURCES = $(UNIVALUE_LIB_SOURCES_INT) $(UNIVALUE_DIST_HEADERS_INT) $(UNIVALUE_LIB_HEADERS_INT) $(UNIVALUE_TEST_FILES_INT)
+libunivalue_la_CPPFLAGS = $(AM_CPPFLAGS) -I$(srcdir)/$(UNIVALUE_INCLUDE_DIR_INT)