# CMake configuration for the main memgraph library and executable # add memgraph sub libraries, ordered by dependency add_subdirectory(lisp) add_subdirectory(utils) add_subdirectory(requests) add_subdirectory(integrations) add_subdirectory(io) add_subdirectory(telemetry) add_subdirectory(communication) add_subdirectory(stats) add_subdirectory(auth) # ---------------------------------------------------------------------------- # Memgraph Single Node # ---------------------------------------------------------------------------- set(mg_single_node_sources data_structures/concurrent/skiplist_gc.cpp database/single_node/config.cpp database/single_node/graph_db.cpp database/single_node/graph_db_accessor.cpp durability/single_node/state_delta.cpp durability/single_node/paths.cpp durability/single_node/recovery.cpp durability/single_node/snapshooter.cpp durability/single_node/wal.cpp glue/auth.cpp glue/communication.cpp query/common.cpp query/frontend/ast/cypher_main_visitor.cpp query/frontend/ast/pretty_print.cpp query/frontend/semantic/required_privileges.cpp query/frontend/semantic/symbol_generator.cpp query/frontend/stripped.cpp query/interpret/awesome_memgraph_functions.cpp query/interpreter.cpp query/plan/operator.cpp query/plan/preprocess.cpp query/plan/pretty_print.cpp query/plan/profile.cpp query/plan/rule_based_planner.cpp query/plan/variable_start_planner.cpp query/repl.cpp query/typed_value.cpp storage/single_node/edge_accessor.cpp storage/common/locking/record_lock.cpp storage/common/types/property_value.cpp storage/common/types/property_value_store.cpp storage/single_node/record_accessor.cpp storage/single_node/vertex_accessor.cpp transactions/single_node/engine.cpp memgraph_init.cpp ) define_add_lcp(add_lcp_single_node mg_single_node_sources generated_lcp_single_node_files) add_lcp_single_node(durability/single_node/state_delta.lcp) add_lcp_single_node(query/frontend/ast/ast.lcp) add_lcp_single_node(query/frontend/semantic/symbol.lcp) add_lcp_single_node(query/plan/operator.lcp) add_custom_target(generate_lcp_single_node DEPENDS ${generated_lcp_single_node_files}) set(MG_SINGLE_NODE_LIBS stdc++fs Threads::Threads fmt cppitertools antlr_opencypher_parser_lib dl glog gflags capnp kj mg-utils mg-io mg-integrations-kafka mg-requests mg-communication mg-auth mg-stats) if (USE_LTALLOC) list(APPEND MG_SINGLE_NODE_LIBS ltalloc) # TODO(mferencevic): Enable this when clang is updated on apollo. # set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -flto") endif() if (READLINE_FOUND) list(APPEND MG_SINGLE_NODE_LIBS readline) endif() add_library(mg-single-node STATIC ${mg_single_node_sources}) target_link_libraries(mg-single-node ${MG_SINGLE_NODE_LIBS}) add_dependencies(mg-single-node generate_opencypher_parser) add_dependencies(mg-single-node generate_lcp_single_node) target_compile_definitions(mg-single-node PUBLIC MG_SINGLE_NODE) # ---------------------------------------------------------------------------- # END Memgraph Single Node # ---------------------------------------------------------------------------- # ---------------------------------------------------------------------------- # Memgraph Distributed # ---------------------------------------------------------------------------- set(mg_distributed_sources database/distributed/distributed_counters.cpp database/distributed/distributed_graph_db.cpp distributed/bfs_rpc_clients.cpp distributed/bfs_subcursor.cpp distributed/cluster_discovery_master.cpp distributed/cluster_discovery_worker.cpp distributed/coordination.cpp distributed/coordination_master.cpp distributed/coordination_worker.cpp distributed/data_manager.cpp distributed/data_rpc_clients.cpp distributed/data_rpc_server.cpp distributed/dgp/partitioner.cpp distributed/dgp/vertex_migrator.cpp distributed/durability_rpc_master.cpp distributed/durability_rpc_worker.cpp distributed/dynamic_worker.cpp distributed/index_rpc_server.cpp distributed/plan_consumer.cpp distributed/plan_dispatcher.cpp distributed/produce_rpc_server.cpp distributed/pull_rpc_clients.cpp distributed/updates_rpc_clients.cpp distributed/updates_rpc_server.cpp query/distributed_interpreter.cpp query/plan/distributed.cpp query/plan/distributed_ops.cpp query/plan/distributed_pretty_print.cpp storage/distributed/concurrent_id_mapper_master.cpp storage/distributed/concurrent_id_mapper_worker.cpp transactions/distributed/engine_master.cpp transactions/distributed/engine_worker.cpp data_structures/concurrent/skiplist_gc.cpp database/distributed/config.cpp database/distributed/graph_db_accessor.cpp durability/distributed/state_delta.cpp durability/distributed/paths.cpp durability/distributed/recovery.cpp durability/distributed/snapshooter.cpp durability/distributed/wal.cpp glue/auth.cpp glue/communication.cpp query/common.cpp query/frontend/ast/pretty_print.cpp query/frontend/ast/cypher_main_visitor.cpp query/frontend/semantic/required_privileges.cpp query/frontend/semantic/symbol_generator.cpp query/frontend/stripped.cpp query/interpret/awesome_memgraph_functions.cpp query/interpreter.cpp query/plan/operator.cpp query/plan/preprocess.cpp query/plan/pretty_print.cpp query/plan/profile.cpp query/plan/rule_based_planner.cpp query/plan/variable_start_planner.cpp query/repl.cpp query/serialization.cpp query/typed_value.cpp storage/common/locking/record_lock.cpp storage/common/types/property_value.cpp storage/common/types/property_value_store.cpp storage/common/types/slk.cpp storage/distributed/edge_accessor.cpp storage/distributed/record_accessor.cpp storage/distributed/rpc/serialization.cpp storage/distributed/vertex_accessor.cpp memgraph_init.cpp transactions/distributed/engine_single_node.cpp ) # ----------------------------------------------------------------------------- define_add_capnp(add_capnp_distributed mg_distributed_sources generated_capnp_files) define_add_lcp(add_lcp_distributed mg_distributed_sources generated_lcp_distributed_files) add_lcp_distributed(durability/distributed/state_delta.lcp) add_lcp_distributed(database/distributed/counters_rpc_messages.lcp CAPNP_SCHEMA @0x95a2c3ea3871e945) add_capnp_distributed(database/distributed/counters_rpc_messages.capnp) add_lcp_distributed(database/distributed/serialization.lcp CAPNP_SCHEMA @0xdea01657b3563887 DEPENDS durability/distributed/state_delta.lcp) add_capnp_distributed(database/distributed/serialization.capnp) add_lcp_distributed(distributed/bfs_rpc_messages.lcp CAPNP_SCHEMA @0x8e508640b09b6d2a) add_capnp_distributed(distributed/bfs_rpc_messages.capnp) add_lcp_distributed(distributed/coordination_rpc_messages.lcp CAPNP_SCHEMA @0x93df0c4703cf98fb) add_capnp_distributed(distributed/coordination_rpc_messages.capnp) add_lcp_distributed(distributed/data_rpc_messages.lcp CAPNP_SCHEMA @0xc1c8a341ba37aaf5) add_capnp_distributed(distributed/data_rpc_messages.capnp) add_lcp_distributed(distributed/durability_rpc_messages.lcp CAPNP_SCHEMA @0xf5e53bc271e2163d) add_capnp_distributed(distributed/durability_rpc_messages.capnp) add_lcp_distributed(distributed/index_rpc_messages.lcp CAPNP_SCHEMA @0xa8aab46862945bd6) add_capnp_distributed(distributed/index_rpc_messages.capnp) add_lcp_distributed(distributed/plan_rpc_messages.lcp CAPNP_SCHEMA @0xfcbc48dc9f106d28) add_capnp_distributed(distributed/plan_rpc_messages.capnp) add_lcp_distributed(distributed/pull_produce_rpc_messages.lcp CAPNP_SCHEMA @0xa78a9254a73685bd DEPENDS transactions/distributed/serialization.lcp) add_capnp_distributed(distributed/pull_produce_rpc_messages.capnp) add_lcp_distributed(distributed/storage_gc_rpc_messages.lcp CAPNP_SCHEMA @0xd705663dfe36cf81) add_capnp_distributed(distributed/storage_gc_rpc_messages.capnp) add_lcp_distributed(distributed/token_sharing_rpc_messages.lcp CAPNP_SCHEMA @0x8f295db54ec4caec) add_capnp_distributed(distributed/token_sharing_rpc_messages.capnp) add_lcp_distributed(distributed/updates_rpc_messages.lcp CAPNP_SCHEMA @0x82d5f38d73c7b53a) add_capnp_distributed(distributed/updates_rpc_messages.capnp) add_lcp_distributed(distributed/dynamic_worker_rpc_messages.lcp CAPNP_SCHEMA @0x8c53f6c9a0c71b05) add_capnp_distributed(distributed/dynamic_worker_rpc_messages.capnp) # distributed_ops.lcp is leading the capnp code generation, so we don't need # to generate any capnp for operator.lcp add_lcp_distributed(query/frontend/ast/ast.lcp) add_lcp_distributed(query/frontend/ast/ast_serialization.lcp CAPNP_SCHEMA @0xb107d3d6b4b1600b DEPENDS query/frontend/ast/ast.lcp) add_capnp_distributed(query/frontend/ast/ast_serialization.capnp) add_lcp_distributed(query/frontend/semantic/symbol.lcp) add_lcp_distributed(query/frontend/semantic/symbol_serialization.lcp CAPNP_SCHEMA @0x93c1dcee84e93b76 DEPENDS query/frontend/semantic/symbol.lcp) add_lcp_distributed(query/plan/operator.lcp) add_lcp_distributed(query/plan/distributed_ops.lcp CAPNP_SCHEMA @0xe5cae8d045d30c42 DEPENDS query/plan/operator.lcp) add_capnp_distributed(query/plan/distributed_ops.capnp) add_lcp_distributed(storage/distributed/rpc/concurrent_id_mapper_rpc_messages.lcp CAPNP_SCHEMA @0xa6068dae93d225dd) add_capnp_distributed(storage/distributed/rpc/concurrent_id_mapper_rpc_messages.capnp) add_lcp_distributed(transactions/distributed/engine_rpc_messages.lcp CAPNP_SCHEMA @0xde02b7c49180cad5 DEPENDS transactions/distributed/serialization.lcp) add_capnp_distributed(transactions/distributed/engine_rpc_messages.capnp) add_custom_target(generate_lcp_distributed DEPENDS ${generated_lcp_distributed_files}) # Registering capnp must come after registering lcp files. add_capnp_distributed(communication/rpc/messages.capnp) add_capnp_distributed(durability/distributed/serialization.capnp) add_capnp_distributed(query/frontend/semantic/symbol_serialization.capnp) add_capnp_distributed(query/serialization.capnp) add_capnp_distributed(storage/distributed/rpc/serialization.capnp) add_custom_target(generate_capnp DEPENDS generate_lcp_distributed ${generated_capnp_files}) set(MG_DISTRIBUTED_LIBS stdc++fs Threads::Threads fmt cppitertools antlr_opencypher_parser_lib dl glog gflags capnp kj mg-utils mg-io mg-integrations-kafka mg-requests mg-communication mg-auth mg-stats) # STATIC library used by memgraph executables add_library(mg-distributed STATIC ${mg_distributed_sources}) target_link_libraries(mg-distributed ${MG_DISTRIBUTED_LIBS}) add_dependencies(mg-distributed generate_opencypher_parser) add_dependencies(mg-distributed generate_lcp_distributed) add_dependencies(mg-distributed generate_capnp) target_compile_definitions(mg-distributed PUBLIC MG_DISTRIBUTED) # ---------------------------------------------------------------------------- # END Memgraph Distributed # ---------------------------------------------------------------------------- # ---------------------------------------------------------------------------- # Memgraph Single Node High Availability # ---------------------------------------------------------------------------- set(mg_single_node_ha_sources data_structures/concurrent/skiplist_gc.cpp database/single_node_ha/config.cpp database/single_node_ha/graph_db.cpp database/single_node_ha/graph_db_accessor.cpp database/single_node_ha/state_delta_applier.cpp durability/single_node_ha/state_delta.cpp durability/single_node_ha/paths.cpp durability/single_node_ha/snapshooter.cpp durability/single_node_ha/recovery.cpp glue/auth.cpp glue/communication.cpp raft/coordination.cpp raft/raft_server.cpp query/common.cpp query/frontend/ast/cypher_main_visitor.cpp query/frontend/ast/pretty_print.cpp query/frontend/semantic/required_privileges.cpp query/frontend/semantic/symbol_generator.cpp query/frontend/stripped.cpp query/interpret/awesome_memgraph_functions.cpp query/interpreter.cpp query/plan/operator.cpp query/plan/preprocess.cpp query/plan/pretty_print.cpp query/plan/profile.cpp query/plan/rule_based_planner.cpp query/plan/variable_start_planner.cpp query/repl.cpp query/typed_value.cpp storage/common/types/property_value.cpp storage/common/types/slk.cpp storage/common/types/property_value_store.cpp storage/common/locking/record_lock.cpp storage/single_node_ha/edge_accessor.cpp storage/single_node_ha/record_accessor.cpp storage/single_node_ha/rpc/serialization.cpp storage/single_node_ha/vertex_accessor.cpp transactions/single_node_ha/engine.cpp memgraph_init.cpp ) define_add_capnp(add_capnp_single_node_ha mg_single_node_ha_sources generated_capnp_single_node_ha_files) define_add_lcp(add_lcp_single_node_ha mg_single_node_ha_sources generated_lcp_single_node_ha_files) add_lcp_single_node_ha(durability/single_node_ha/state_delta.lcp) add_lcp_single_node_ha(database/single_node_ha/serialization.lcp CAPNP_SCHEMA @0xd0f4a502575fb6f7 DEPENDS durability/single_node_ha/state_delta.lcp) add_capnp_single_node_ha(database/single_node_ha/serialization.capnp) add_lcp_single_node_ha(query/frontend/ast/ast.lcp) add_lcp_single_node_ha(query/frontend/semantic/symbol.lcp) add_lcp_single_node_ha(query/plan/operator.lcp) add_lcp_single_node_ha(raft/raft_rpc_messages.lcp CAPNP_SCHEMA @0xa6c29b4287233b66) add_capnp_single_node_ha(raft/raft_rpc_messages.capnp) add_lcp_single_node_ha(raft/log_entry.lcp CAPNP_SCHEMA @0x96c07fe13850c22a) add_capnp_single_node_ha(raft/log_entry.capnp) add_custom_target(generate_lcp_single_node_ha DEPENDS ${generated_lcp_single_node_ha_files}) # Registering capnp must come after registering lcp files. add_capnp_single_node_ha(storage/single_node_ha/rpc/serialization.capnp) add_custom_target(generate_capnp_single_node_ha DEPENDS generate_lcp_single_node_ha ${generated_capnp_single_node_ha_files}) set(MG_SINGLE_NODE_HA_LIBS stdc++fs Threads::Threads fmt cppitertools antlr_opencypher_parser_lib dl glog gflags capnp kj mg-utils mg-io mg-integrations-kafka mg-requests mg-communication mg-auth mg-stats) if (USE_LTALLOC) list(APPEND MG_SINGLE_NODE_HA_LIBS ltalloc) # TODO(mferencevic): Enable this when clang is updated on apollo. # set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -flto") endif() if (READLINE_FOUND) list(APPEND MG_SINGLE_NODE_HA_LIBS readline) endif() add_library(mg-single-node-ha STATIC ${mg_single_node_ha_sources}) target_link_libraries(mg-single-node-ha ${MG_SINGLE_NODE_HA_LIBS}) add_dependencies(mg-single-node-ha generate_opencypher_parser) add_dependencies(mg-single-node-ha generate_lcp_single_node_ha) add_dependencies(mg-single-node-ha generate_capnp_single_node_ha) target_compile_definitions(mg-single-node-ha PUBLIC MG_SINGLE_NODE_HA) # ---------------------------------------------------------------------------- # END Memgraph Single Node High Availability # ---------------------------------------------------------------------------- string(TOLOWER ${CMAKE_BUILD_TYPE} lower_build_type) # STATIC library used to store key-value pairs add_library(kvstore_lib STATIC storage/common/kvstore/kvstore.cpp) target_link_libraries(kvstore_lib stdc++fs mg-utils rocksdb bzip2 zlib glog gflags) # STATIC library for dummy key-value storage add_library(kvstore_dummy_lib STATIC storage/common/kvstore/kvstore_dummy.cpp) target_link_libraries(kvstore_dummy_lib mg-utils) # Generate a version.hpp file set(VERSION_STRING ${memgraph_VERSION}) configure_file(version.hpp.in version.hpp @ONLY) include_directories(${CMAKE_CURRENT_BINARY_DIR}) # memgraph main executable add_executable(memgraph memgraph.cpp) target_link_libraries(memgraph mg-single-node kvstore_lib telemetry_lib) set_target_properties(memgraph PROPERTIES # Set the executable output name to include version information. OUTPUT_NAME "memgraph-${memgraph_VERSION}-${COMMIT_HASH}_${CMAKE_BUILD_TYPE}" # Output the executable in main binary dir. RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}) # Create symlink to the built executable. add_custom_command(TARGET memgraph POST_BUILD COMMAND ${CMAKE_COMMAND} -E create_symlink $ ${CMAKE_BINARY_DIR}/memgraph BYPRODUCTS ${CMAKE_BINARY_DIR}/memgraph COMMENT Creating symlink to memgraph executable) # Strip the executable in release build. if (lower_build_type STREQUAL "release") add_custom_command(TARGET memgraph POST_BUILD COMMAND strip -s $ COMMENT Stripping symbols and sections from memgraph) endif() # Everything here is under "memgraph" install component. set(CMAKE_INSTALL_DEFAULT_COMPONENT_NAME "memgraph") # TODO: Default directory permissions to 755 # NOTE: This is added in CMake 3.11, so enable it then #set(CMAKE_INSTALL_DEFAULT_DIRECTORY_PERMISSIONS # OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ WORLD_READ) # Install and rename executable to just 'memgraph' Since we have to rename, # we cannot use the recommended `install(TARGETS ...)`. install(PROGRAMS $ DESTINATION lib/memgraph RENAME memgraph) # Install the config file (must use absolute path). install(FILES ${CMAKE_SOURCE_DIR}/config/community.conf DESTINATION /etc/memgraph RENAME memgraph.conf) # Install logrotate configuration (must use absolute path). install(FILES ${CMAKE_SOURCE_DIR}/release/logrotate.conf DESTINATION /etc/logrotate.d RENAME memgraph) # Create empty directories for default location of lib and log. install(CODE "file(MAKE_DIRECTORY \$ENV{DESTDIR}/var/log/memgraph \$ENV{DESTDIR}/var/lib/memgraph)") # Install the license file. install(FILES ${CMAKE_SOURCE_DIR}/release/LICENSE.md DESTINATION share/doc/memgraph RENAME copyright) # Install systemd service (must use absolute path). install(FILES ${CMAKE_SOURCE_DIR}/release/memgraph.service DESTINATION /lib/systemd/system) # Install examples set(examples ${CMAKE_SOURCE_DIR}/release/examples) install( CODE "execute_process(COMMAND ${examples}/build_examples ${CMAKE_BINARY_DIR}/memgraph ${CMAKE_BINARY_DIR}/tests/manual/bolt_client WORKING_DIRECTORY ${examples})") install(DIRECTORY ${examples}/build/ DESTINATION share/memgraph/examples) # memgraph distributed main executable add_executable(memgraph_distributed memgraph_distributed.cpp) target_link_libraries(memgraph_distributed mg-distributed kvstore_lib telemetry_lib) set_target_properties(memgraph_distributed PROPERTIES # Set the executable output name to include version information. OUTPUT_NAME "memgraph_distributed-${memgraph_VERSION}-${COMMIT_HASH}_${CMAKE_BUILD_TYPE}" # Output the executable in main binary dir. RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}) # Create symlink to the built executable. add_custom_command(TARGET memgraph_distributed POST_BUILD COMMAND ${CMAKE_COMMAND} -E create_symlink $ ${CMAKE_BINARY_DIR}/memgraph_distributed BYPRODUCTS ${CMAKE_BINARY_DIR}/memgraph_distributed COMMENT Creating symlink to memgraph distributed executable) # memgraph single node high availability executable add_executable(memgraph_ha memgraph_ha.cpp) target_link_libraries(memgraph_ha mg-single-node-ha kvstore_lib telemetry_lib) set_target_properties(memgraph_ha PROPERTIES # Set the executable output name to include version information. OUTPUT_NAME "memgraph_ha-${memgraph_VERSION}-${COMMIT_HASH}_${CMAKE_BUILD_TYPE}" # Output the executable in main binary dir. RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}) # Create symlink to the built executable. add_custom_command(TARGET memgraph_ha POST_BUILD COMMAND ${CMAKE_COMMAND} -E create_symlink $ ${CMAKE_BINARY_DIR}/memgraph_ha BYPRODUCTS ${CMAKE_BINARY_DIR}/memgraph_ha COMMENT Creating symlink to memgraph single node high availability executable)