initial code repo
[stor4nfv.git] / src / ceph / src / cls / CMakeLists.txt
diff --git a/src/ceph/src/cls/CMakeLists.txt b/src/ceph/src/cls/CMakeLists.txt
new file mode 100644 (file)
index 0000000..1c36c1f
--- /dev/null
@@ -0,0 +1,270 @@
+## Rados object classes
+
+set(cls_dir ${CMAKE_INSTALL_LIBDIR}/rados-classes)
+set(cls_embedded_srcs)
+
+# cls_sdk
+add_library(cls_sdk SHARED sdk/cls_sdk.cc)
+set_target_properties(cls_sdk PROPERTIES VERSION "1.0.0" SOVERSION "1")
+install(TARGETS cls_sdk DESTINATION ${cls_dir})
+
+# cls_hello
+set(cls_hello_srcs hello/cls_hello.cc)
+add_library(cls_hello SHARED ${cls_hello_srcs})
+set_target_properties(cls_hello PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_hello DESTINATION ${cls_dir})
+list(APPEND cls_embedded_srcs ${cls_hello_srcs})
+
+# cls_numops
+set(cls_numops_srcs numops/cls_numops.cc)
+add_library(cls_numops SHARED ${cls_numops_srcs})
+set_target_properties(cls_numops PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_numops DESTINATION ${cls_dir})
+
+set(cls_numops_client_srcs numops/cls_numops_client.cc)
+add_library(cls_numops_client STATIC ${cls_numops_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_numops_srcs} ${cls_numops_client_srcs})
+
+# cls_rbd
+if (WITH_RBD)
+  set(cls_rbd_srcs rbd/cls_rbd.cc rbd/cls_rbd_types.cc)
+  add_library(cls_rbd SHARED ${cls_rbd_srcs})
+  set_target_properties(cls_rbd PROPERTIES
+    VERSION "1.0.0"
+    SOVERSION "1"
+    INSTALL_RPATH "")
+  install(TARGETS cls_rbd DESTINATION ${cls_dir})
+
+  set(cls_rbd_client_srcs rbd/cls_rbd_client.cc rbd/cls_rbd_types.cc)
+  add_library(cls_rbd_client STATIC ${cls_rbd_client_srcs})
+  target_link_libraries(cls_rbd_client cls_lock_client)
+
+  list(APPEND cls_embedded_srcs ${cls_rbd_srcs} ${cls_rbd_client_srcs})
+endif (WITH_RBD)
+
+# cls_lock
+set(cls_lock_srcs lock/cls_lock.cc)
+add_library(cls_lock SHARED ${cls_lock_srcs})
+set_target_properties(cls_lock PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_lock DESTINATION ${cls_dir})
+
+set(cls_lock_client_srcs
+  lock/cls_lock_client.cc
+  lock/cls_lock_types.cc
+  lock/cls_lock_ops.cc)
+add_library(cls_lock_client STATIC ${cls_lock_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_lock_srcs} ${cls_lock_client_srcs})
+
+# cls_refcount
+set(cls_refcount_srcs
+  refcount/cls_refcount.cc
+  refcount/cls_refcount_ops.cc
+  ${CMAKE_SOURCE_DIR}/src/common/ceph_json.cc)
+add_library(cls_refcount SHARED ${cls_refcount_srcs})
+target_link_libraries(cls_refcount json_spirit)
+set_target_properties(cls_refcount PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_refcount DESTINATION ${cls_dir})
+
+set(cls_refcount_client_srcs
+  refcount/cls_refcount_client.cc
+  refcount/cls_refcount_ops.cc)
+add_library(cls_refcount_client STATIC ${cls_refcount_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_refcount_srcs} ${cls_refcount_client_srcs})
+
+# cls_version
+set(cls_version_srcs version/cls_version.cc)
+add_library(cls_version SHARED ${cls_version_srcs})
+set_target_properties(cls_version PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_version DESTINATION ${cls_dir})
+
+set(cls_version_client_srcs
+  version/cls_version_client.cc
+  version/cls_version_types.cc)
+add_library(cls_version_client STATIC ${cls_version_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_version_srcs} ${cls_version_client_srcs})
+
+# cls_log
+set(cls_log_srcs log/cls_log.cc)
+add_library(cls_log SHARED ${cls_log_srcs})
+set_target_properties(cls_log PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_log DESTINATION ${cls_dir})
+
+set(cls_log_client_srcs log/cls_log_client.cc)
+add_library(cls_log_client STATIC ${cls_log_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_log_srcs} ${cls_log_client_srcs})
+
+# cls_statelog
+set(cls_statelog_srcs statelog/cls_statelog.cc)
+add_library(cls_statelog SHARED ${cls_statelog_srcs})
+set_target_properties(cls_statelog PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_statelog DESTINATION ${cls_dir})
+
+set(cls_statelog_client_srcs statelog/cls_statelog_client.cc)
+add_library(cls_statelog_client STATIC ${cls_statelog_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_statelog_srcs} ${cls_statelog_client_srcs})
+
+# cls_timeindex
+set(cls_timeindex_srcs timeindex/cls_timeindex.cc)
+add_library(cls_timeindex SHARED ${cls_timeindex_srcs})
+set_target_properties(cls_timeindex PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_timeindex DESTINATION ${cls_dir})
+
+set(cls_timeindex_client_srcs timeindex/cls_timeindex_client.cc)
+add_library(cls_timeindex_client STATIC ${cls_timeindex_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_timeindex_srcs} ${cls_timeindex_client_srcs})
+
+# cls_replica_log
+set(cls_replica_log_srcs replica_log/cls_replica_log.cc)
+add_library(cls_replica_log SHARED ${cls_replica_log_srcs})
+set_target_properties(cls_replica_log PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_replica_log DESTINATION ${cls_dir})
+
+set(cls_replica_log_client_srcs
+  replica_log/cls_replica_log_types.cc
+  replica_log/cls_replica_log_ops.cc
+  replica_log/cls_replica_log_client.cc)
+add_library(cls_replica_log_client STATIC ${cls_replica_log_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_replica_log_srcs} ${cls_replica_log_client_srcs})
+
+# cls_user
+set(cls_user_srcs user/cls_user.cc)
+add_library(cls_user SHARED ${cls_user_srcs})
+set_target_properties(cls_user PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_user DESTINATION ${cls_dir})
+
+set(cls_user_client_srcs
+  user/cls_user_client.cc
+  user/cls_user_types.cc
+  user/cls_user_ops.cc)
+add_library(cls_user_client STATIC ${cls_user_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_user_srcs} ${cls_user_client_srcs})
+
+# cls_journal
+set(cls_journal_srcs
+  journal/cls_journal.cc
+  journal/cls_journal_types.cc)
+add_library(cls_journal SHARED ${cls_journal_srcs})
+set_target_properties(cls_journal PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_journal DESTINATION ${cls_dir})
+
+set(cls_journal_client_srcs
+  journal/cls_journal_client.cc
+  journal/cls_journal_types.cc)
+add_library(cls_journal_client STATIC ${cls_journal_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_journal_srcs} ${cls_journal_client_srcs})
+
+# cls_rgw
+if (WITH_RADOSGW)
+  set(cls_rgw_srcs
+    rgw/cls_rgw.cc
+    rgw/cls_rgw_ops.cc
+    rgw/cls_rgw_types.cc
+    ${CMAKE_SOURCE_DIR}/src/common/ceph_json.cc)
+  add_library(cls_rgw SHARED ${cls_rgw_srcs})
+  target_link_libraries(cls_rgw json_spirit)
+  set_target_properties(cls_rgw PROPERTIES
+    VERSION "1.0.0"
+    SOVERSION "1"
+    INSTALL_RPATH "")
+  install(TARGETS cls_rgw DESTINATION ${cls_dir})
+
+  set(cls_rgw_client_srcs
+    rgw/cls_rgw_client.cc
+    rgw/cls_rgw_types.cc
+    rgw/cls_rgw_ops.cc)
+  add_library(cls_rgw_client STATIC ${cls_rgw_client_srcs})
+
+  list(APPEND cls_embedded_srcs ${cls_rgw_srcs} ${cls_rgw_client_srcs})
+endif (WITH_RADOSGW)
+
+# cls_cephfs
+if (WITH_CEPHFS)
+  set(cls_cephfs_srcs
+    cephfs/cls_cephfs.cc)
+  add_library(cls_cephfs SHARED ${cls_cephfs_srcs})
+  set_target_properties(cls_cephfs PROPERTIES
+    VERSION "1.0.0"
+    SOVERSION "1"
+    INSTALL_RPATH "")
+  install(TARGETS cls_cephfs DESTINATION ${cls_dir})
+
+  set(cls_cephfs_client_srcs
+    cephfs/cls_cephfs_client.cc)
+  add_library(cls_cephfs_client STATIC ${cls_cephfs_client_srcs})
+
+  list(APPEND cls_embedded_srcs ${cls_cephfs_srcs} ${cls_cephfs_client_srcs})
+endif (WITH_CEPHFS)
+
+# cls_lua
+set(cls_lua_srcs
+    lua/cls_lua.cc
+    lua/lua_bufferlist.cc)
+add_library(cls_lua SHARED ${cls_lua_srcs})
+set_target_properties(cls_lua PROPERTIES
+  VERSION "1.0.0"
+  SOVERSION "1"
+  INSTALL_RPATH "")
+install(TARGETS cls_lua DESTINATION ${cls_dir})
+target_link_libraries(cls_lua
+    liblua
+    json_spirit)
+
+set(cls_lua_client_srcs
+    lua/cls_lua_client.cc)
+add_library(cls_lua_client STATIC ${cls_lua_client_srcs})
+
+list(APPEND cls_embedded_srcs ${cls_lua_srcs} ${cls_lua_client_srcs})
+
+if(WITH_EMBEDDED)
+  include(MergeStaticLibraries)
+  list(REMOVE_DUPLICATES cls_embedded_srcs)
+  add_library(cephd_cls_base STATIC ${cls_embedded_srcs})
+  # while not necessary this seems to bring in the lua's include directories
+  # so that cls_lua srcs build correctly
+  target_link_libraries(cephd_cls_base liblua)
+  set_target_properties(cephd_cls_base PROPERTIES COMPILE_DEFINITIONS BUILDING_FOR_EMBEDDED)
+  merge_static_libraries(cephd_cls cephd_cls_base liblua)
+endif()