mirror of
https://github.com/matrix-construct/construct
synced 2024-11-17 23:40:57 +01:00
232 lines
5.7 KiB
Makefile
232 lines
5.7 KiB
Makefile
AUTOMAKE_OPTIONS = foreign
|
|
|
|
DEFS += \
|
|
-DIRCD_UNIT \
|
|
###
|
|
|
|
AM_CXXFLAGS = \
|
|
-ftls-model=initial-exec \
|
|
@EXTRA_CXXFLAGS@ \
|
|
###
|
|
|
|
if DEBUG
|
|
if GCC
|
|
AM_CXXFLAGS += -fmax-errors=2
|
|
endif
|
|
endif
|
|
|
|
AM_CPPFLAGS = \
|
|
-I$(top_srcdir)/include \
|
|
@ROCKSDB_CPPFLAGS@ \
|
|
@JS_CPPFLAGS@ \
|
|
@BOOST_CPPFLAGS@ \
|
|
@SSL_CPPFLAGS@ \
|
|
@CRYPTO_CPPFLAGS@ \
|
|
@SODIUM_CPPFLAGS@ \
|
|
@MAGIC_CPPFLAGS@ \
|
|
@SNAPPY_CPPFLAGS@ \
|
|
@LZ4_CPPFLAGS@ \
|
|
@Z_CPPFLAGS@ \
|
|
@MALLOC_CPPFLAGS@ \
|
|
-include ircd/ircd.pic.h \
|
|
@EXTRA_CPPFLAGS@ \
|
|
###
|
|
|
|
AM_LDFLAGS = \
|
|
-version-info 3:1:0 \
|
|
-Wl,--warn-common \
|
|
-Wl,--warn-execstack \
|
|
-Wl,--detect-odr-violations \
|
|
-Wl,--unresolved-symbols=report-all \
|
|
-Wl,--no-undefined-version \
|
|
-Wl,--weak-unresolved-symbols \
|
|
-Wl,--icf=all \
|
|
-Wl,--rosegment \
|
|
-Wl,--gdb-index \
|
|
-Wl,-z,lazy \
|
|
-Wl,-z,nodelete \
|
|
-Wl,-z,nodlopen \
|
|
-Wl,-z,noexecstack \
|
|
-Wl,-z,combreloc \
|
|
-Wl,-z,text-unlikely-segment \
|
|
$(PLATFORM_LDFLAGS) \
|
|
@EXTRA_LDFLAGS@ \
|
|
###
|
|
|
|
if GCC
|
|
AM_LDFLAGS += \
|
|
-Wl,-fuse-ld=gold \
|
|
###
|
|
endif
|
|
|
|
if CLANG
|
|
AM_LDFLAGS += \
|
|
-fuse-ld=gold \
|
|
###
|
|
endif
|
|
|
|
if MINGW
|
|
AM_LDFLAGS += \
|
|
-Wl,--enable-runtime-pseudo-reloc \
|
|
-export-symbols-regex '*' \
|
|
###
|
|
endif
|
|
|
|
libircddir = @libdir@
|
|
libircd_LTLIBRARIES = libircd.la
|
|
|
|
libircd_la_LDFLAGS = \
|
|
$(AM_LDFLAGS) \
|
|
@ROCKSDB_LDFLAGS@ \
|
|
@JS_LDFLAGS@ \
|
|
@BOOST_LDFLAGS@ \
|
|
@SSL_LDFLAGS@ \
|
|
@CRYPTO_LDFLAGS@ \
|
|
@SODIUM_LDFLAGS@ \
|
|
@MAGIC_LDFLAGS@ \
|
|
@SNAPPY_LDFLAGS@ \
|
|
@LZ4_LDFLAGS@ \
|
|
@Z_LDFLAGS@ \
|
|
@MALLOC_LDFLAGS@ \
|
|
###
|
|
|
|
libircd_la_LIBADD = \
|
|
@ROCKSDB_LIBS@ \
|
|
@JS_LIBS@ \
|
|
@BOOST_LIBS@ \
|
|
@SSL_LIBS@ \
|
|
@CRYPTO_LIBS@ \
|
|
@SODIUM_LIBS@ \
|
|
@MAGIC_LIBS@ \
|
|
@SNAPPY_LIBS@ \
|
|
@LZ4_LIBS@ \
|
|
@Z_LIBS@ \
|
|
@MALLOC_LIBS@ \
|
|
@EXTRA_LIBS@ \
|
|
###
|
|
|
|
# Since this is a GNU C++ project we assume the non-standard respect for
|
|
# the order of this sources list. Static initialization will occur in
|
|
# the same order as this list, and destruction in the reverse order.
|
|
#
|
|
# Add the most dependent units at the end and the least dependent units
|
|
# at the beginning.
|
|
#
|
|
libircd_la_SOURCES =#
|
|
libircd_la_SOURCES += assert.cc
|
|
libircd_la_SOURCES += info.cc
|
|
libircd_la_SOURCES += allocator.cc
|
|
libircd_la_SOURCES += allocator_gnu.cc
|
|
libircd_la_SOURCES += allocator_je.cc
|
|
libircd_la_SOURCES += vg.cc
|
|
libircd_la_SOURCES += exception.cc
|
|
libircd_la_SOURCES += util.cc
|
|
libircd_la_SOURCES += demangle.cc
|
|
libircd_la_SOURCES += backtrace.cc
|
|
libircd_la_SOURCES += locale.cc
|
|
libircd_la_SOURCES += timedate.cc
|
|
libircd_la_SOURCES += lex_cast.cc
|
|
libircd_la_SOURCES += stringops.cc
|
|
libircd_la_SOURCES += globular.cc
|
|
libircd_la_SOURCES += tokens.cc
|
|
libircd_la_SOURCES += parse.cc
|
|
libircd_la_SOURCES += rand.cc
|
|
libircd_la_SOURCES += base.cc
|
|
libircd_la_SOURCES += crh.cc
|
|
libircd_la_SOURCES += fmt.cc
|
|
libircd_la_SOURCES += json.cc
|
|
libircd_la_SOURCES += conf.cc
|
|
libircd_la_SOURCES += stats.cc
|
|
libircd_la_SOURCES += logger.cc
|
|
libircd_la_SOURCES += magic.cc
|
|
libircd_la_SOURCES += sodium.cc
|
|
libircd_la_SOURCES += openssl.cc
|
|
libircd_la_SOURCES += rfc1459.cc
|
|
libircd_la_SOURCES += rfc3986.cc
|
|
libircd_la_SOURCES += rfc1035.cc
|
|
libircd_la_SOURCES += http.cc
|
|
libircd_la_SOURCES += http2.cc
|
|
libircd_la_SOURCES += prof.cc
|
|
if LINUX
|
|
libircd_la_SOURCES += prof_linux.cc
|
|
endif
|
|
libircd_la_SOURCES += fs.cc
|
|
libircd_la_SOURCES += ios.cc
|
|
libircd_la_SOURCES += ctx.cc
|
|
libircd_la_SOURCES += ctx_eh.cc
|
|
libircd_la_SOURCES += ctx_ole.cc
|
|
if AIO
|
|
libircd_la_SOURCES += fs_aio.cc
|
|
endif
|
|
if IOU
|
|
libircd_la_SOURCES += fs_iou.cc
|
|
endif
|
|
libircd_la_SOURCES += mods.cc
|
|
if LINUX
|
|
libircd_la_SOURCES += mods_ldso.cc
|
|
endif
|
|
libircd_la_SOURCES += db_write_thread.cc
|
|
libircd_la_SOURCES += db_port.cc
|
|
libircd_la_SOURCES += db_env.cc
|
|
libircd_la_SOURCES += db.cc
|
|
libircd_la_SOURCES += net.cc
|
|
libircd_la_SOURCES += server.cc
|
|
libircd_la_SOURCES += client.cc
|
|
libircd_la_SOURCES += resource.cc
|
|
if JS
|
|
libircd_la_SOURCES += js.cc
|
|
endif
|
|
libircd_la_SOURCES += m_name.cc
|
|
libircd_la_SOURCES += m_id.cc
|
|
libircd_la_SOURCES += m_dbs.cc
|
|
libircd_la_SOURCES += m_room.cc
|
|
libircd_la_SOURCES += m_fed.cc
|
|
libircd_la_SOURCES += m.cc
|
|
libircd_la_SOURCES += m_event.cc
|
|
libircd_la_SOURCES += ircd.cc
|
|
|
|
db_write_thread.lo: AM_CPPFLAGS += -I$(top_srcdir)/deps/rocksdb/include
|
|
db_write_thread.lo: AM_CPPFLAGS += -I$(top_srcdir)/deps/rocksdb
|
|
|
|
# Units containing a spirit grammar have some special needs to mitigate
|
|
# larger-than-normal compile time, compile memory, and output objects.
|
|
# A composite of CXXFLAGS is used specifically on units with grammars.
|
|
GUNIT_CXXFLAGS = ###
|
|
|
|
# Grammar templates can generate a huge number of individual debug symbols
|
|
# for each template instantiation deep within spirit; we try to reduce...
|
|
GUNIT_CXXFLAGS += -fno-var-tracking
|
|
if GCC
|
|
GUNIT_CXXFLAGS += -fno-var-tracking-assignments
|
|
GUNIT_CXXFLAGS += -femit-struct-debug-baseonly
|
|
endif
|
|
|
|
# The recursive grammars can consume a large amount of RAM when compiling
|
|
# (>= 2 GiB) which can thrash small systems and even sometimes crash GCC.
|
|
# This option reduces memory consumption at the cost of compilation speed.
|
|
if GCC
|
|
if LOWMEM_COMPILE
|
|
GUNIT_CXXFLAGS += --param ggc-min-expand=1
|
|
endif
|
|
endif
|
|
|
|
parse.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
parse.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
json.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
json.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
http.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
http.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
fmt.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
fmt.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
rfc3986.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
rfc3986.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
rfc1459.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
rfc1459.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|
|
|
|
m_id.lo: AM_CPPFLAGS := -include ircd/spirit.h ${AM_CPPFLAGS}
|
|
m_id.lo: CXXFLAGS += ${GUNIT_CXXFLAGS}
|