ETAGS=ctags -e if ENABLE_MOBILEAPP if ENABLE_GTKAPP SUBDIRS = gtk loleaflet else if ENABLE_ANDROIDAPP SUBDIRS = loleaflet android else SUBDIRS = loleaflet endif endif else SUBDIRS = . test loleaflet export ENABLE_DEBUG bin_PROGRAMS = \ loolwsd loolforkit \ loolconvert loolconfig dist_bin_SCRIPTS = loolwsd-systemplate-setup man_MANS = man/loolwsd.1 \ man/loolforkit.1 \ man/loolconvert.1 \ man/loolconfig.1 \ man/loolwsd-systemplate-setup.1 dist_doc_DATA = wsd/README \ wsd/README.vars \ wsd/protocol.txt \ wsd/reference.md \ wsd/metrics.txt loolwsddatadir = @LOOLWSD_DATADIR@ loolwsddata_DATA = discovery.xml \ favicon.ico loolwsdconfigdir = @LOOLWSD_CONFIGDIR@ loolwsdconfig_DATA = loolwsd.xml \ loolkitconfig.xcu apache2configdir = ${sysconfdir}/apache2/conf-available apache2config_DATA = etc/apache2/loolwsd.conf nginxconfigdir = ${sysconfdir}/nginx/snippets nginxconfig_DATA = etc/nginx/loolwsd.conf ACLOCAL_AMFLAGS = -I m4 # quick and easy for now. include_paths = -I${top_srcdir}/common -I${top_srcdir}/net -I${top_srcdir}/wsd -I${top_srcdir}/kit ${ZLIB_CFLAGS} AM_CPPFLAGS = -pthread -DLOOLWSD_DATADIR='"@LOOLWSD_DATADIR@"' \ -DLOOLWSD_CONFIGDIR='"@LOOLWSD_CONFIGDIR@"' \ -DDEBUG_ABSSRCDIR='"@abs_srcdir@"' \ ${include_paths} if !ENABLE_DEBUG AM_CPPFLAGS += -DNDEBUG endif AM_LDFLAGS = -pthread -Wl,-E,-rpath,/snap/loolwsd/current/usr/lib -lpam $(ZLIB_LIBS) if ENABLE_SSL AM_LDFLAGS += -lssl -lcrypto else loolwsd_fuzzer_LDADD = -lssl -lcrypto loolwsd_LDADD = -lssl -lcrypto loolconfig_LDADD = -lssl -lcrypto endif loolwsd_fuzzer_CPPFLAGS = -DKIT_IN_PROCESS=1 -DFUZZER=1 -DTDOC=\"$(abs_top_srcdir)/test/data\" $(AM_CPPFLAGS) AM_ETAGSFLAGS = --c++-kinds=+p --fields=+iaS --extra=+q -R --totals=yes --exclude=loleaflet * AM_CTAGSFLAGS = $(AM_ETAGSFLAGS) shared_sources = common/FileUtil.cpp \ common/IoUtil.cpp \ common/Log.cpp \ common/Protocol.cpp \ common/Session.cpp \ common/Seccomp.cpp \ common/MessageQueue.cpp \ common/SigUtil.cpp \ common/SpookyV2.cpp \ common/Unit.cpp \ common/Util.cpp \ common/Authorization.cpp \ net/DelaySocket.cpp \ net/Socket.cpp if ENABLE_SSL shared_sources += net/Ssl.cpp endif loolwsd_sources = common/Crypto.cpp \ wsd/Admin.cpp \ wsd/AdminModel.cpp \ wsd/Auth.cpp \ wsd/DocumentBroker.cpp \ wsd/LOOLWSD.cpp \ wsd/ClientSession.cpp \ wsd/FileServer.cpp \ wsd/Storage.cpp \ wsd/TileCache.cpp \ wsd/ProofKey.cpp loolwsd_SOURCES = $(loolwsd_sources) \ $(shared_sources) noinst_PROGRAMS = clientnb \ connect \ lokitclient \ loolwsd_fuzzer \ loolmap \ loolstress \ loolmount \ loolsocketdump connect_SOURCES = tools/Connect.cpp \ common/Log.cpp \ common/Protocol.cpp \ common/Util.cpp lokitclient_SOURCES = common/IoUtil.cpp \ common/Log.cpp \ tools/KitClient.cpp \ common/Protocol.cpp \ common/Util.cpp loolforkit_sources = kit/ChildSession.cpp \ kit/ForKit.cpp \ kit/Kit.cpp loolforkit_SOURCES = $(loolforkit_sources) \ $(shared_sources) loolwsd_fuzzer_SOURCES = $(loolwsd_sources) \ $(loolforkit_sources) \ $(shared_sources) \ kit/DummyLibreOfficeKit.cpp clientnb_SOURCES = net/clientnb.cpp \ common/Log.cpp \ common/Util.cpp loolmount_SOURCES = tools/mount.cpp loolmap_SOURCES = tools/map.cpp loolconvert_SOURCES = tools/Tool.cpp loolstress_CPPFLAGS = -DTDOC=\"$(abs_top_srcdir)/test/data\" ${include_paths} loolstress_SOURCES = tools/Stress.cpp \ common/Protocol.cpp \ common/Log.cpp \ common/Util.cpp loolconfig_SOURCES = tools/Config.cpp \ common/Crypto.cpp \ common/Log.cpp \ common/Util.cpp loolsocketdump_SOURCES = tools/WebSocketDump.cpp \ $(shared_sources) wsd_headers = wsd/Admin.hpp \ wsd/AdminModel.hpp \ wsd/Auth.hpp \ wsd/ClientSession.hpp \ wsd/DocumentBroker.hpp \ wsd/Exceptions.hpp \ wsd/FileServer.hpp \ wsd/LOOLWSD.hpp \ wsd/ProofKey.hpp \ wsd/QueueHandler.hpp \ wsd/SenderQueue.hpp \ wsd/Storage.hpp \ wsd/TileCache.hpp \ wsd/TileDesc.hpp \ wsd/TraceFile.hpp \ wsd/UserMessages.hpp shared_headers = common/Common.hpp \ common/Clipboard.hpp \ common/Crypto.hpp \ common/JsonUtil.hpp \ common/IoUtil.hpp \ common/FileUtil.hpp \ common/Log.hpp \ common/LOOLWebSocket.hpp \ common/Protocol.hpp \ common/Seccomp.hpp \ common/Session.hpp \ common/Unit.hpp \ common/UnitHTTP.hpp \ common/Util.hpp \ common/Authorization.hpp \ common/MessageQueue.hpp \ common/Message.hpp \ common/Png.hpp \ common/Rectangle.hpp \ common/SigUtil.hpp \ common/security.h \ common/SpookyV2.h \ net/DelaySocket.hpp \ net/FakeSocket.hpp \ net/ServerSocket.hpp \ net/Socket.hpp \ net/WebSocketHandler.hpp \ tools/Replay.hpp if ENABLE_SSL shared_headers += net/Ssl.hpp \ net/SslSocket.hpp endif kit_headers = kit/ChildSession.hpp \ kit/Delta.hpp \ kit/DummyLibreOfficeKit.hpp \ kit/Kit.hpp \ kit/KitHelper.hpp \ kit/Watermark.hpp noinst_HEADERS = $(wsd_headers) $(shared_headers) $(kit_headers) \ test/WopiTestServer.hpp \ test/countloolkits.hpp \ test/test.hpp \ test/helpers.hpp dist-hook: git log -1 --format=%h > $(distdir)/dist_git_hash 2> /dev/null || rm $(distdir)/dist_git_hash mkdir -p $(distdir)/bundled/include/LibreOfficeKit/ cp @LOKIT_PATH@/LibreOfficeKit/LibreOfficeKit.h \ @LOKIT_PATH@/LibreOfficeKit/LibreOfficeKit.hxx \ @LOKIT_PATH@/LibreOfficeKit/LibreOfficeKitEnums.h \ @LOKIT_PATH@/LibreOfficeKit/LibreOfficeKitInit.h \ @LOKIT_PATH@/LibreOfficeKit/LibreOfficeKitTypes.h \ $(distdir)/bundled/include/LibreOfficeKit/ EXTRA_DIST = discovery.xml \ favicon.ico \ loolkitconfig.xcu \ loolwsd.init.rhel6 \ loolwsd.spec \ loolwsd.xml.in \ loolwsd.service \ sysconfig.loolwsd \ debian/compat \ debian/copyright \ debian/loolwsd.cron.d \ debian/loolwsd.preinst \ debian/loolwsd.service \ debian/rules \ debian/source/format \ debian/changelog \ debian/control \ debian/loolwsd.postinst \ debian/loolwsd.postrm \ etc/key.pem \ etc/cert.pem \ etc/ca-chain.cert.pem \ etc/apache2/loolwsd.conf \ etc/nginx/loolwsd.conf \ scripts/unocommands.py \ $(man_MANS) if HAVE_LO_PATH SYSTEM_STAMP = @SYSTEMPLATE_PATH@/system_stamp $(SYSTEM_STAMP) : ${top_srcdir}/loolwsd-systemplate-setup if test "z@SYSTEMPLATE_PATH@" != "z"; then rm -rf "@SYSTEMPLATE_PATH@"; fi ${top_srcdir}/loolwsd-systemplate-setup "@SYSTEMPLATE_PATH@" "@LO_PATH@" && touch $@ @JAILS_PATH@ : mkdir -p $@ clean-local: if test "z@JAILS_PATH@" != "z"; then rm -rf "@JAILS_PATH@"; fi if test "z@SYSTEMPLATE_PATH@" != "z"; then rm -rf "@SYSTEMPLATE_PATH@"; fi run: all @JAILS_PATH@ @echo "Launching loolwsd" @fc-cache "@LO_PATH@"/share/fonts/truetype @cp $(abs_top_srcdir)/test/data/hello.odt $(abs_top_srcdir)/test/data/hello-world.odt @cp $(abs_top_srcdir)/test/data/hello.ods $(abs_top_srcdir)/test/data/hello-world.ods @cp $(abs_top_srcdir)/test/data/hello.odp $(abs_top_srcdir)/test/data/hello-world.odp @echo ./loolwsd --o:sys_template_path="@SYSTEMPLATE_PATH@" \ --o:child_root_path="@JAILS_PATH@" --o:storage.filesystem[@allow]=true \ --o:ssl.cert_file_path="$(abs_top_srcdir)/etc/cert.pem" \ --o:ssl.key_file_path="$(abs_top_srcdir)/etc/key.pem" \ --o:ssl.ca_file_path="$(abs_top_srcdir)/etc/ca-chain.cert.pem" \ --o:admin_console.username=admin --o:admin_console.password=admin \ --o:logging.file[@enable]=true --o:logging.level=trace sync-writer: browser-sync start --config browsersync-config.js --startPath "loleaflet/96c23f663/loleaflet.html?file_path=file://$(abs_top_srcdir)/test/data/hello-world.odt" sync-calc: browser-sync start --config browsersync-config.js --startPath "loleaflet/96c23f663/loleaflet.html?file_path=file://$(abs_top_srcdir)/test/data/hello-world.ods" sync-impress: browser-sync start --config browsersync-config.js --startPath "loleaflet/96c23f663/loleaflet.html?file_path=file://$(abs_top_srcdir)/test/data/hello-world.odp" run-valgrind: all @JAILS_PATH@ @echo "Launching loolwsd under valgrind (but not forkit/loolkit, yet)" @fc-cache "@LO_PATH@"/share/fonts/truetype @cp $(abs_top_srcdir)/test/data/hello.odt $(abs_top_srcdir)/test/data/hello-world.odt @cp $(abs_top_srcdir)/test/data/hello.ods $(abs_top_srcdir)/test/data/hello-world.ods @cp $(abs_top_srcdir)/test/data/hello.odp $(abs_top_srcdir)/test/data/hello-world.odp valgrind --tool=memcheck --trace-children=no -v --read-var-info=yes \ ./loolwsd --o:sys_template_path="@SYSTEMPLATE_PATH@" \ --o:child_root_path="@JAILS_PATH@" --o:storage.filesystem[@allow]=true \ --o:ssl.cert_file_path="$(abs_top_srcdir)/etc/cert.pem" \ --o:ssl.key_file_path="$(abs_top_srcdir)/etc/key.pem" \ --o:ssl.ca_file_path="$(abs_top_srcdir)/etc/ca-chain.cert.pem" \ --o:admin_console.username=admin --o:admin_console.password=admin \ --o:logging.file[@enable]=false --o:logging.level=trace run-gdb: all @JAILS_PATH@ @echo "Launching loolwsd under gdb" @fc-cache "@LO_PATH@"/share/fonts/truetype @cp $(abs_top_srcdir)/test/data/hello.odt $(abs_top_srcdir)/test/data/hello-world.odt @cp $(abs_top_srcdir)/test/data/hello.ods $(abs_top_srcdir)/test/data/hello-world.ods @cp $(abs_top_srcdir)/test/data/hello.odp $(abs_top_srcdir)/test/data/hello-world.odp gdb --tui --args \ ./loolwsd --o:security.capabilities="false" \ --o:sys_template_path="@SYSTEMPLATE_PATH@" \ --o:child_root_path="@JAILS_PATH@" --o:storage.filesystem[@allow]=true \ --o:ssl.cert_file_path="$(abs_top_srcdir)/etc/cert.pem" \ --o:ssl.key_file_path="$(abs_top_srcdir)/etc/key.pem" \ --o:ssl.ca_file_path="$(abs_top_srcdir)/etc/ca-chain.cert.pem" \ --o:admin_console.username=admin --o:admin_console.password=admin \ --o:logging.file[@enable]=false --o:logging.level=error run-callgrind: all @JAILS_PATH@ @echo "Launching loolwsd under valgrind's callgrind" @fc-cache "@LO_PATH@"/share/fonts/truetype @cp $(abs_top_srcdir)/test/data/hello.odt $(abs_top_srcdir)/test/data/hello-world.odt @cp $(abs_top_srcdir)/test/data/hello.ods $(abs_top_srcdir)/test/data/hello-world.ods @cp $(abs_top_srcdir)/test/data/hello.odp $(abs_top_srcdir)/test/data/hello-world.odp valgrind --tool=callgrind --simulate-cache=yes --dump-instr=yes --num-callers=50 --error-limit=no --trace-children=yes \ ./loolwsd --o:security.capabilities="false" \ --o:sys_template_path="@SYSTEMPLATE_PATH@" \ --o:child_root_path="@JAILS_PATH@" --o:storage.filesystem[@allow]=true \ --o:ssl.cert_file_path="$(abs_top_srcdir)/etc/cert.pem" \ --o:ssl.key_file_path="$(abs_top_srcdir)/etc/key.pem" \ --o:ssl.ca_file_path="$(abs_top_srcdir)/etc/ca-chain.cert.pem" \ --o:admin_console.username=admin --o:admin_console.password=admin \ --o:logging.file[@enable]=false --o:logging.level=error run-strace: all @JAILS_PATH@ @echo "Launching loolwsd under strace" @fc-cache "@LO_PATH@"/share/fonts/truetype @cp $(abs_top_srcdir)/test/data/hello.odt $(abs_top_srcdir)/test/data/hello-world.odt @cp $(abs_top_srcdir)/test/data/hello.ods $(abs_top_srcdir)/test/data/hello-world.ods @cp $(abs_top_srcdir)/test/data/hello.odp $(abs_top_srcdir)/test/data/hello-world.odp strace -o strace.log -f -tt -s 256 \ ./loolwsd --o:security.capabilities="false" \ --o:sys_template_path="@SYSTEMPLATE_PATH@" \ --o:child_root_path="@JAILS_PATH@" --o:storage.filesystem[@allow]=true \ --o:ssl.cert_file_path="$(abs_top_srcdir)/etc/cert.pem" \ --o:ssl.key_file_path="$(abs_top_srcdir)/etc/key.pem" \ --o:ssl.ca_file_path="$(abs_top_srcdir)/etc/ca-chain.cert.pem" \ --o:admin_console.username=admin --o:admin_console.password=admin \ --o:logging.file[@enable]=false --o:logging.level=error else SYSTEM_STAMP = endif # After building loolforkit, set its capabilities as required. Do it # already after a plain 'make' to allow for testing without # installing. When building for packaging, no need for this, as the # capabilities won't survive packaging anyway. Instead, handle it when # installing the RPM or Debian package. all-local: loolforkit loolmount @JAILS_PATH@ $(SYSTEM_STAMP) if ENABLE_SETCAP sudo @SETCAP@ cap_fowner,cap_mknod,cap_sys_chroot=ep loolforkit sudo @SETCAP@ cap_sys_admin=ep loolmount else echo "Skipping capability setting" endif # just run the build without any tests build-nocheck: all-am endif