OSDN Git Service

Code cleanup.
[mhash384/mhash384.git] / Makefile
index 748f1a9..5d230b9 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -4,51 +4,75 @@ SHELL = /bin/bash
 # BUILD OPTIONS
 #############################################################################
 
-PLUSPLUS ?= 0
-STATIC   ?= 0
-CPU_TYPE ?= native
+CPLUSPLUS ?= 0
+CPU_TYPE  ?= native
+NO_JAVA   ?= 0
+NO_PYTHON ?= 0
 
 
 #############################################################################
 # CONFIGURATION
 #############################################################################
 
-ISO_DATE := $(shell date "+%Y-%m-%d")
-CM_FLAGS := -Iinclude
-RL_FLAGS := -DNDEBUG -O3 -march=$(CPU_TYPE)
-DB_FLAGS := -g
-SO_FLAGS := -fPIC -shared
-PD_FLAGS := --from markdown --to html5 --toc -N --standalone
-
 ifdef ARCH
   CM_FLAGS += $(if $(filter x64,$(ARCH)),-m64,-m32)
 else
   ARCH := $(if $(findstring x86_64,$(shell $(CXX) -v 2>&1 | grep "Target:")),x64,x86)
 endif
 
-ifeq ($(STATIC),1)
-  CM_FLAGS += -static
-endif
-
 ifeq ($(OS),Windows_NT)
   OSTYPE := mingw
-  SUFFIX := .exe
+  JNIDIR := win32
+  BINEXT := .exe
+  DLLEXT := .dll
+  PYDEXT := .pyd
+  DLLOPT := -shared
 else
   OSTYPE := linux
-  SUFFIX :=
+  JNIDIR := linux
+  BINEXT := .run
+  DLLEXT := .so
+  PYDEXT := .so
+  DLLOPT := -fPIC -shared
 endif
 
+ROOT_DIR := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
+WORK_DIR := /tmp/$(shell head /dev/urandom | tr -dc A-Za-z0-9 | head -c 12)
+ISO_DATE := $(shell date "+%Y-%m-%d")
+
+CM_FLAGS := -I$(ROOT_DIR)/include
+RL_FLAGS := -DNDEBUG -O3 -march=$(CPU_TYPE)
+DB_FLAGS := -g
+EX_FLAGS := -static
+SO_FLAGS := $(DLLOPT) -static-libgcc -static-libstdc++
+PD_FLAGS := --from markdown --to html5 --toc -N --standalone
+
 
 #############################################################################
-# FILE NAMES
+# CHECKS
 #############################################################################
 
-ROOT_DIR := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
+ifneq ($(NO_JAVA),1)
+  ifneq ($(notdir $(realpath $(JAVA_HOME)/include/jni.h)),jni.h)
+    $(error $$(JAVA_HOME)/include/jni.h not found! Please make sure JAVA_HOME is set correctly)
+  endif
+endif
+
+ifneq ($(NO_PYTHON),1)
+  ifneq ($(notdir $(realpath $(PYTHON_INC)/Python.h)),Python.h)
+    $(error $$(PYTHON_INC)/Python.h not found! Please make sure PYTHON_INC is set correctly)
+  endif
+endif
+
+
+#############################################################################
+# FILE NAMES
+#############################################################################
 
 TXT := $(ROOT_DIR)COPYING.txt
 DOC := $(ROOT_DIR)README.html 
 
-ifeq ($(PLUSPLUS),1)
+ifeq ($(CPLUSPLUS),1)
   CLI_CXX := g++
   CLI_SRC := $(wildcard $(ROOT_DIR)/src/*.cpp)
 else
@@ -56,16 +80,36 @@ else
   CLI_SRC := $(wildcard $(ROOT_DIR)/src/*.c)
 endif
 
-CLI_BIN := $(ROOT_DIR)bin/mhash_384.$(ARCH)$(SUFFIX)
-CLI_DBG := $(BIN).dbg
+CLI_BIN := $(ROOT_DIR)bin/mhash_384.$(ARCH)$(BINEXT)
+CLI_DBG := $(ROOT_DIR)bin/mhash_384_g.$(ARCH)$(BINEXT)
 CLI_OUT := $(ROOT_DIR)out/mhash_384.$(ISO_DATE).bin-$(OSTYPE)-$(ARCH).tar.gz
 
 JNI_SRC := $(wildcard $(ROOT_DIR)bindings/Java/native/src/*.cpp)
-JNI_INC := $(ROOT_DIR)bindings/Java/native/include
-JNI_BIN := $(ROOT_DIR)bindings/Java/native/bin/MHashJava384.$(ARCH).so
-JNI_JAR := $(ROOT_DIR)bindings/Java/wrapper/out/MHashJava384-Wrapper.jar
+JNI_JAR := $(ROOT_DIR)bindings/Java/library/out/MHashJava384.jar
 JNI_GUI := $(ROOT_DIR)bindings/Java/example/out/MHashJava384-Example.jar
-JNI_OUT := $(ROOT_DIR)out/mhash_384.$(ISO_DATE).java-$(OSTYPE)-$(ARCH).tar.gz
+JNI_OUT := $(ROOT_DIR)out/mhash_384.$(ISO_DATE).bin-java.tar.gz
+
+PYC_SRC := $(wildcard $(ROOT_DIR)bindings/Python/native/src/*.cpp)
+PYC_PTH := $(ROOT_DIR)bindings/Python/wrapper/mhash.pth
+PYC_LIB := $(ROOT_DIR)bindings/Python/wrapper/MHashPy384_Wrapper.py
+PYC_GUI := $(ROOT_DIR)bindings/Python/example/MHashPy384_Example.py
+PYC_BIN := $(ROOT_DIR)bindings/Python/native/bin/MHashPy384_Native.$(ARCH)$(PYDEXT)
+PYC_OUT := $(ROOT_DIR)out/mhash_384.$(ISO_DATE).python-$(OSTYPE)-$(ARCH).tar.gz
+
+
+#############################################################################
+# TARGETS
+#############################################################################
+
+TARGETS = $(CLI_OUT)
+
+ifneq ($(NO_JAVA),1)
+  TARGETS += $(JNI_OUT)
+endif
+
+ifneq ($(NO_PYTHON),1)
+  TARGETS += $(PYC_OUT)
+endif
 
 
 #############################################################################
@@ -74,30 +118,51 @@ JNI_OUT := $(ROOT_DIR)out/mhash_384.$(ISO_DATE).java-$(OSTYPE)-$(ARCH).tar.gz
 
 .PHONY: all clean
 
-all: $(CLI_OUT) $(JNI_OUT)
+all: $(TARGETS)
+
+# -----------------------------------------------
+# PACKAGE
+# -----------------------------------------------
 
 $(CLI_OUT): $(CLI_BIN) $(CLI_DBG) $(DOC) $(TXT)
-       mkdir -p $(dir $@)
-       rm -fv $@
-       tar -czf $@ -C $(dir $(DOC)) $(notdir $(DOC)) -C $(dir $(TXT)) $(notdir $(TXT)) -C $(dir $(CLI_BIN)) $(notdir $(CLI_BIN))
+       mkdir -p $(dir $@) $(WORK_DIR)
+       rm -fv $@ $(WORK_DIR)/*
+       cp $(DOC) $(TXT) $(CLI_BIN) $(WORK_DIR)
+       pushd $(WORK_DIR) && tar -czf $@ *
 
 $(JNI_OUT): $(JNI_BIN) $(JNI_JAR) $(JNI_GUI) $(DOC) $(TXT)
-       mkdir -p $(dir $@)
-       rm -fv $@
-       tar -czf $@ -C $(dir $(DOC)) $(notdir $(DOC)) -C $(dir $(TXT)) $(notdir $(TXT)) -C $(dir $(JNI_BIN)) $(notdir $(JNI_BIN)) -C $(dir $(JNI_JAR)) $(notdir $(JNI_JAR)) -C $(dir $(JNI_GUI)) $(notdir $(JNI_GUI))
+       mkdir -p $(dir $@) $(WORK_DIR)
+       rm -fv $@ $(WORK_DIR)/*
+       cp $(DOC) $(TXT) $(JNI_BIN) $(JNI_JAR) $(JNI_GUI) $(WORK_DIR)
+       pushd $(WORK_DIR) && tar -czf $@ *
+
+$(PYC_OUT): $(PYC_BIN) $(PYC_LIB) $(PYC_PTH) $(PYC_GUI) $(DOC) $(TXT)
+       mkdir -p $(dir $@) $(WORK_DIR)
+       rm -fv $@ $(WORK_DIR)/*
+       cp $(DOC) $(TXT) $(PYC_BIN) $(PYC_LIB) $(PYC_PTH) $(PYC_GUI) $(WORK_DIR)
+       pushd $(WORK_DIR) && tar -czf $@ *
+
+# -----------------------------------------------
+# COMPILE
+# -----------------------------------------------
 
 $(CLI_BIN): $(CLI_SRC)
        mkdir -p $(dir $@)
-       $(CLI_CXX) $(CM_FLAGS) $(RL_FLAGS) -o $@ $^
+       $(CLI_CXX) $(CM_FLAGS) $(EX_FLAGS) $(RL_FLAGS) -o $@ $^
        strip -s $@
 
 $(CLI_DBG): $(CLI_SRC)
        mkdir -p $(dir $@)
-       $(CLI_CXX) $(CM_FLAGS) $(DB_FLAGS) -o $@ $^
+       $(CLI_CXX) $(CM_FLAGS) $(EX_FLAGS) $(DB_FLAGS) -o $@ $^
 
 $(JNI_BIN): $(JNI_SRC)
        mkdir -p $(dir $@)
-       g++ $(CM_FLAGS) $(RL_FLAGS) $(SO_FLAGS) -I$(JNI_INC) -I$(JAVA_HOME)/include -o $@ $^
+       g++ $(CM_FLAGS) $(SO_FLAGS) $(RL_FLAGS) -I$(JNI_INC) -I$(JAVA_HOME)/include -I$(JAVA_HOME)/include/$(JNIDIR) -o $@ $^
+       strip -s $@
+
+$(PYC_BIN): $(PYC_SRC)
+       mkdir -p $(dir $@)
+       g++ $(CM_FLAGS) $(SO_FLAGS) $(RL_FLAGS) -I$(PYTHON_INC) -o $@ $^
        strip -s $@
 
 $(JNI_JAR): $(abspath $(dir $(JNI_JAR))/../build.xml)
@@ -108,11 +173,20 @@ $(JNI_GUI): $(abspath $(dir $(JNI_GUI))/../build.xml)
        mkdir -p $(dir $@)
        pushd $(dir $^) && ant clean jar
 
+# -----------------------------------------------
+# DOCUMENTS
+# -----------------------------------------------
+
 %.html: %.md
        pandoc $(PD_FLAGS) --output $@ $^
 
+# -----------------------------------------------
+# CLEAN UP
+# -----------------------------------------------
+
 clean:
        rm -fv $(CLI_BIN) $(CLI_DBG) $(CLI_OUT)
        rm -fv $(JNI_BIN) $(JNI_JAR) $(JNI_GUI) $(JNI_OUT)
+       rm -fv $(PYC_BIN) $(PYC_OUT)
        rm -fv $(DOC)