aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNathanael Sensfelder <SpamShield0@MultiAgentSystems.org>2017-09-01 21:29:26 +0200
committerNathanael Sensfelder <SpamShield0@MultiAgentSystems.org>2017-09-01 21:29:26 +0200
commit9441ae8cfe0bb5da4e67cdb76880d3ef291db8a9 (patch)
tree589fe89f18a1ceef99b60b654ad0766bb46500a1
parent12e8c037e63c952c66595654edd1316d3ef37f50 (diff)
downloadstorage-9441ae8cfe0bb5da4e67cdb76880d3ef291db8a9.zip
storage-9441ae8cfe0bb5da4e67cdb76880d3ef291db8a9.tar.bz2
Switches to Makefiles.
-rw-r--r--CMakeLists.txt30
-rw-r--r--Makefile27
-rw-r--r--README.md2
-rw-r--r--src/CMakeLists.txt13
-rw-r--r--src/Makefile30
-rw-r--r--src/core/CMakeLists.txt7
l---------src/core/Makefile1
-rw-r--r--src/error/CMakeLists.txt6
-rw-r--r--src/filter/CMakeLists.txt6
l---------src/filter/Makefile1
-rw-r--r--src/parameters/CMakeLists.txt7
l---------src/parameters/Makefile1
-rw-r--r--src/server/CMakeLists.txt16
l---------src/server/Makefile1
-rw-r--r--src/timespec/CMakeLists.txt7
l---------src/timespec/Makefile1
16 files changed, 63 insertions, 93 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
deleted file mode 100644
index b35d2f1..0000000
--- a/CMakeLists.txt
+++ /dev/null
@@ -1,30 +0,0 @@
-cmake_minimum_required(VERSION 3.0 FATAL_ERROR)
-
-project("JabberHive - Storage")
-
-include(FindPkgConfig)
-
-add_subdirectory(src)
-add_definitions(-D_POSIX_SOURCE)
-add_definitions(-D_POSIX_C_SOURCE=200809L)
-
-set(CMAKE_C_FLAGS $ENV{CFLAGS})
-if(CMAKE_COMPILER_IS_GNUCC)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g -Wall -Wpedantic -Wconversion")
- message(STATUS "GNUCC detected. Adding '-O3' parameter.")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O3")
-endif()
-message(STATUS "CFLAGS=${CMAKE_C_FLAGS}")
-
-# ${SRC_FILES} is recursively defined in the subdirectories.
-# Each subdirectory only adds the source files that are present at its level.
-add_executable(jabberhive-storage ${SRC_FILES})
-set_property(TARGET jabberhive-storage PROPERTY C_STANDARD 99)
-set_property(TARGET jabberhive-storage PROPERTY C_STANDARD_REQUIRED ON)
-
-find_package(Threads)
-target_link_libraries(jabberhive-storage ${CMAKE_THREAD_LIBS_INIT})
-target_link_libraries(jabberhive-storage m)
-
-## OPTION HANDLING #############################################################
-# TODO
diff --git a/Makefile b/Makefile
new file mode 100644
index 0000000..08487e9
--- /dev/null
+++ b/Makefile
@@ -0,0 +1,27 @@
+################################################################################
+PTHREADS_LIB_FLAGS = -pthread
+MATH_LIB_FLAGS = -lm
+################################################################################
+CFLAGS += -O3
+CFLAGS += -D_POSIX_SOURCE
+CFLAGS += -D_POSIX_C_SOURCE=200809L
+CFLAGS += $(PTHREADS_LIB_FLAGS)
+CFLAGS += $(MATH_LIB_FLAGS)
+################################################################################
+EXECUTABLE = jh-lowercase
+SRC_DIR = ./src
+################################################################################
+export
+################################################################################
+
+build: $(EXECUTABLE)
+
+$(EXECUTABLE): $(SRC_DIR)/export.a
+ $(CC) $(CFLAGS) -o $@ $<
+
+$(SRC_DIR)/export.a:
+ $(MAKE) -C $(SRC_DIR) export.a
+
+clean:
+ $(MAKE) -C $(SRC_DIR) clean
+ rm -f $(EXECUTABLE)
diff --git a/README.md b/README.md
index 313e70a..d4c7373 100644
--- a/README.md
+++ b/README.md
@@ -22,4 +22,4 @@ network.
## Dependencies
- POSIX compliant OS.
- C compiler (with C99 support).
-- CMake.
+- (GNU) make.
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
deleted file mode 100644
index f89d3e9..0000000
--- a/src/CMakeLists.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-add_subdirectory(error)
-add_subdirectory(core)
-add_subdirectory(filter)
-add_subdirectory(server)
-add_subdirectory(timespec)
-add_subdirectory(parameters)
-
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/main.c
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
diff --git a/src/Makefile b/src/Makefile
new file mode 100644
index 0000000..8ffa1ab
--- /dev/null
+++ b/src/Makefile
@@ -0,0 +1,30 @@
+SUBCOMPONENTS = $(dir $(filter-out "./Makefile",$(wildcard ./*/Makefile)))
+SUBCOMPONENTS_EXPORT = $(addsuffix /export.a,$(SUBCOMPONENTS))
+################################################################################
+SRC_FILES = $(wildcard ./*.c)
+OBJ_FILES = $(SRC_FILES:.c=.o)
+DEP_FILES = $(SRC_FILES:.c=.d)
+################################################################################
+build: export.a
+
+export.a: $(OBJ_FILES) $(SUBCOMPONENTS_EXPORT)
+ ar -crT $@ $^
+
+$(SUBCOMPONENTS_EXPORT):
+ $(MAKE) -C $(dir $@) export.a
+
+clean:
+ rm -f $(OBJ_FILES)
+ rm -f $(DEP_FILES)
+ rm -f export.a
+ for subcmp in $(SUBCOMPONENTS) ; do \
+ $(MAKE) -C $$subcmp clean ; \
+ done
+################################################################################
+%.d: %.c
+ @set -e; rm -f $@; \
+ $(CC) -M $(CPPFLAGS) $< > $@.$$$$; \
+ sed 's,\($*\)\.o[ :]*,\1.o $@ : ,g' < $@.$$$$ > $@; \
+ rm -f $@.$$$$
+
+include $(DEP_FILES)
diff --git a/src/core/CMakeLists.txt b/src/core/CMakeLists.txt
deleted file mode 100644
index f5ede7c..0000000
--- a/src/core/CMakeLists.txt
+++ /dev/null
@@ -1,7 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/index.c
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
-
diff --git a/src/core/Makefile b/src/core/Makefile
new file mode 120000
index 0000000..d0b0e8e
--- /dev/null
+++ b/src/core/Makefile
@@ -0,0 +1 @@
+../Makefile \ No newline at end of file
diff --git a/src/error/CMakeLists.txt b/src/error/CMakeLists.txt
deleted file mode 100644
index fa07534..0000000
--- a/src/error/CMakeLists.txt
+++ /dev/null
@@ -1,6 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
-
diff --git a/src/filter/CMakeLists.txt b/src/filter/CMakeLists.txt
deleted file mode 100644
index c8add44..0000000
--- a/src/filter/CMakeLists.txt
+++ /dev/null
@@ -1,6 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/filter.c
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
diff --git a/src/filter/Makefile b/src/filter/Makefile
new file mode 120000
index 0000000..d0b0e8e
--- /dev/null
+++ b/src/filter/Makefile
@@ -0,0 +1 @@
+../Makefile \ No newline at end of file
diff --git a/src/parameters/CMakeLists.txt b/src/parameters/CMakeLists.txt
deleted file mode 100644
index 2aa7ece..0000000
--- a/src/parameters/CMakeLists.txt
+++ /dev/null
@@ -1,7 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/parameters.c
- ${CMAKE_CURRENT_SOURCE_DIR}/parameters_getters.c
-)
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
-
diff --git a/src/parameters/Makefile b/src/parameters/Makefile
new file mode 120000
index 0000000..d0b0e8e
--- /dev/null
+++ b/src/parameters/Makefile
@@ -0,0 +1 @@
+../Makefile \ No newline at end of file
diff --git a/src/server/CMakeLists.txt b/src/server/CMakeLists.txt
deleted file mode 100644
index 625749b..0000000
--- a/src/server/CMakeLists.txt
+++ /dev/null
@@ -1,16 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/server.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_create_socket.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_finalize.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_initialize.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_joining_threads.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_new_connection.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_signal.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_wait_for_event.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_worker.c
- ${CMAKE_CURRENT_SOURCE_DIR}/server_worker_data_merger.c
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
-
diff --git a/src/server/Makefile b/src/server/Makefile
new file mode 120000
index 0000000..d0b0e8e
--- /dev/null
+++ b/src/server/Makefile
@@ -0,0 +1 @@
+../Makefile \ No newline at end of file
diff --git a/src/timespec/CMakeLists.txt b/src/timespec/CMakeLists.txt
deleted file mode 100644
index a84f996..0000000
--- a/src/timespec/CMakeLists.txt
+++ /dev/null
@@ -1,7 +0,0 @@
-set(
- SRC_FILES ${SRC_FILES}
- ${CMAKE_CURRENT_SOURCE_DIR}/timespec.c
-)
-
-set(SRC_FILES ${SRC_FILES} PARENT_SCOPE)
-
diff --git a/src/timespec/Makefile b/src/timespec/Makefile
new file mode 120000
index 0000000..d0b0e8e
--- /dev/null
+++ b/src/timespec/Makefile
@@ -0,0 +1 @@
+../Makefile \ No newline at end of file