56c7459
diff -up ./Makefile.packageMain ./Makefile
0f3e08b
--- ./Makefile.packageMain	2013-03-31 17:06:44.000000000 +1000
0f3e08b
+++ ./Makefile	2013-04-13 22:59:43.796601417 +1000
0f3e08b
@@ -1,11 +1,45 @@
56c7459
 CXX ?= g++
56c7459
-CFLAGS = -Wall -Wconversion -O3 -fPIC
56c7459
+CFLAGS = ${RPM_CFLAGS} -Wall -Wconversion -O3 -fPIC
56c7459
 SHVER = 2
c8f3ad5
+export SHVER
c8f3ad5
 OS = $(shell uname)
56c7459
+MAKE = make
c8f3ad5
+DOT_LIBS=.
56c7459
+LIBS= -L${DOT_LIBS} -lsvm
d766271
+export LIBSVM_VER
921d062
+IS_64:=$(shell /bin/uname -i | awk '/64/ {print 64}')
921d062
+PREFIXDIR?= /usr
921d062
+export PREFIXDIR
0f3e08b
 
0f3e08b
-all: svm-train svm-predict svm-scale
921d062
+LIBDIR?=${PREFIXDIR}/lib${IS_64}
921d062
+export LIBDIR
0f3e08b
 
0f3e08b
-lib: svm.o
921d062
+DATADIR?=${PREFIXDIR}/share
921d062
+export DATADIR
56c7459
+
921d062
+BINDIR?=${PREFIXDIR}/bin
921d062
+export BINDIR
921d062
+
921d062
+INCLUDEDIR_INSTALL:=${DESTDIR}/${PREFIXDIR}/include
921d062
+export INCLUDEDIR_INSTALL
921d062
+
921d062
+LIBDIR_INSTALL:=${DESTDIR}/${LIBDIR}
921d062
+export LIBDIR_INSTALL
921d062
+
921d062
+DATADIR_INSTALL:=${DESTDIR}/${DATADIR}
921d062
+export DATA_INSTALL
921d062
+
921d062
+BINDIR_INSTALL:=${DESTDIR}/${BINDIR}
921d062
+export BINDIR_INSTALL
56c7459
+
56c7459
+all: lib svm-train svm-predict svm-scale svm-python svm-java svm-toy-gtk svm-toy-qt
c8f3ad5
+
c8f3ad5
+lib: libsvm.so.$(SHVER) libsvm.so
c8f3ad5
+
c8f3ad5
+libsvm.so: libsvm.so.$(SHVER)
56c7459
+	ln -sf libsvm.so.$(SHVER) libsvm.so
0b558ee
+
c8f3ad5
+libsvm.so.$(SHVER): svm.o
c8f3ad5
 	if [ "$(OS)" = "Darwin" ]; then \
0f3e08b
 		SHARED_LIB_FLAG="-dynamiclib -Wl,-install_name,libsvm.so.$(SHVER)"; \
c8f3ad5
 	else \
0f3e08b
@@ -14,12 +48,72 @@ lib: svm.o
c8f3ad5
 	$(CXX) $${SHARED_LIB_FLAG} svm.o -o libsvm.so.$(SHVER)
56c7459
 
56c7459
 svm-predict: svm-predict.c svm.o
c8f3ad5
-	$(CXX) $(CFLAGS) svm-predict.c svm.o -o svm-predict -lm
c8f3ad5
+	$(CXX) $(CFLAGS) svm-predict.c $(LIBS) -o svm-predict -lm
c8f3ad5
 svm-train: svm-train.c svm.o
c8f3ad5
-	$(CXX) $(CFLAGS) svm-train.c svm.o -o svm-train -lm
c8f3ad5
+	$(CXX) $(CFLAGS) svm-train.c $(LIBS) -o svm-train -lm
c8f3ad5
 svm-scale: svm-scale.c
c8f3ad5
 	$(CXX) $(CFLAGS) svm-scale.c -o svm-scale
56c7459
 svm.o: svm.cpp svm.h
56c7459
 	$(CXX) $(CFLAGS) -c svm.cpp
56c7459
 clean:
56c7459
-	rm -f *~ svm.o svm-train svm-predict svm-scale libsvm.so.$(SHVER)
56c7459
+	rm -f *~ svm.o svm-train svm-predict svm-scale svm-toy/gtk/svm-toy-gtk  svm-toy/qt/svm-toy-qt
56c7459
+	${MAKE} -C python clean
56c7459
+	${MAKE} -C java clean
56c7459
+svm-python:
56c7459
+	${MAKE} -C python
56c7459
+
56c7459
+svm-java:
56c7459
+ifneq ("${NO_JAVA}","NO_JAVA")
56c7459
+	${MAKE} -C java
56c7459
+endif
56c7459
+svm-toy-gtk:
56c7459
+	${MAKE} -C svm-toy/gtk
56c7459
+
56c7459
+svm-toy-qt:
56c7459
+	${MAKE} -C svm-toy/qt
d766271
+
56c7459
+install: all
921d062
+	mkdir -p ${BINDIR_INSTALL}
921d062
+	install -m 755 svm-train ${BINDIR_INSTALL}
921d062
+	install -m 755 svm-predict ${BINDIR_INSTALL}
921d062
+	install -m 755 svm-scale ${BINDIR_INSTALL}
921d062
+	mkdir -p ${LIBDIR_INSTALL}
921d062
+	install -m 755 libsvm.so.$(SHVER) ${LIBDIR_INSTALL}
56c7459
+# install package libsvm-devel
921d062
+	mkdir -p ${INCLUDEDIR_INSTALL}/libsvm
921d062
+	install -m 644 svm.h ${INCLUDEDIR_INSTALL}/libsvm
921d062
+	mkdir -p ${DATADIR_INSTALL}/libsvm/src/java/libsvm
921d062
+	install -m 644 *.h ${DATADIR_INSTALL}/libsvm/src
921d062
+	install -m 644 *.c ${DATADIR_INSTALL}/libsvm/src
921d062
+	install -m 644 *.cpp ${DATADIR_INSTALL}/libsvm/src
921d062
+	install -m 644 Makefile ${DATADIR_INSTALL}/libsvm/src
56c7459
+ifneq ("${NO_JAVA}","NO_JAVA")
921d062
+	install -m 644 java/*.java ${DATADIR_INSTALL}/libsvm/src/java
921d062
+	install -m 644 java/Makefile ${DATADIR_INSTALL}/libsvm/src/java
921d062
+	install -m 644 java/libsvm/*.java ${DATADIR_INSTALL}/libsvm/src/java/libsvm
921d062
+	install -m 644 java/libsvm/*.m4 ${DATADIR_INSTALL}/libsvm/src/java/libsvm
56c7459
+# install package libsvm-java
56c7459
+	${MAKE} -C java install
56c7459
+endif
56c7459
+# install package libsvm-python
56c7459
+	${MAKE} -C python install
56c7459
+# install package svm-toy
921d062
+	install -m 755 svm-toy/gtk/svm-toy-gtk ${BINDIR_INSTALL}
921d062
+	install -m 755 svm-toy/qt/svm-toy-qt ${BINDIR_INSTALL}
56c7459
+# install examples
921d062
+	mkdir -p ${DATADIR_INSTALL}/libsvm/examples
921d062
+	install -m 644 heart_scale ${DATADIR_INSTALL}/libsvm/examples
56c7459
+uninstall:
921d062
+	rm -f ${BINDIR_INSTALL}/svm-train
921d062
+	rm -f ${BINDIR_INSTALL}/svm-predict
921d062
+	rm -f ${BINDIR_INSTALL}/svm-scale
921d062
+	rm -fr ${DATADIR_INSTALL}/libsvm
921d062
+	rm -f ${INCLUDEDIR_INSTALL}/libsvm/svm.h
921d062
+	rm -f ${LIBDIR_INSTALL}/libsvm.so*
56c7459
+	${MAKE} -C python uninstall
56c7459
+ifneq ("${NO_JAVA}","NO_JAVA")
56c7459
+	${MAKE} -C java uninstall
56c7459
+endif
921d062
+	rm -f ${BINDIR_INSTALL}/svm-toy-gtk
921d062
+	rm -f ${BINDIR_INSTALL}/svm-toy-qt
921d062
+