# bash makefile for MIRACL (http://www.shamus.ie/)
# for use on MacOSX systems (tested with MIRACL v5.3.2)
#
# Usual steps to compile MIRACL:
#
# mkdir MIRACL;cd MIRACL
# wget ftp://ftp.computing.dcu.ie/pub/crypto/miracl.zip
# or: curl -O ftp://ftp.computing.dcu.ie/pub/crypto/miracl.zip
# unzip -j -aa -L miracl.zip
# cp /path/to/mirdef_macosx.h mirdef.h
# cp /path/to/mir_macosx macosx
# bash macosx
#
# test with: ./pk-demo or ./bmark


if [ ! -f "../mirdef_macosx.h" ]; then
	if [ ! -f "mirdef_macosx.h" ]; then
		echo "mirdef_macosx.h not found! Make sure you are using the correct mirdef.h"
		echo
		echo "Press ENTER to continue or CTRL+C to abort..."; read junk
	else
		cp mirdef_macosx.h mirdef.h
		echo; echo "Okay: Using mirdef_macosx.h ..."; echo
	fi
else
	cp ../mirdef_macosx.h mirdef.h
	echo; echo "Okay: Using ../mirdef_macosx.h ..."; echo
fi


# choose your gcc compiler
CC=gcc

# CCFLAGS=-fPIC is probably required on intel macs and works on PowerPC too
CCFLAGS=-fPIC


rm -f miracl.a mr*.o pk-demo bmark

$CC -I. -c -O2 $CCFLAGS mrcore.c
$CC -I. -c -O2 $CCFLAGS mrarth0.c
$CC -I. -c -O2 $CCFLAGS mrarth1.c
$CC -I. -c -O2 $CCFLAGS mrarth2.c
$CC -I. -c -O2 $CCFLAGS mralloc.c
$CC -I. -c -O2 $CCFLAGS mrsmall.c
$CC -I. -c -O2 $CCFLAGS mrio1.c
$CC -I. -c -O2 $CCFLAGS mrio2.c
$CC -I. -c -O2 $CCFLAGS mrgcd.c
$CC -I. -c -O2 $CCFLAGS mrjack.c
$CC -I. -c -O2 $CCFLAGS mrxgcd.c
$CC -I. -c -O2 $CCFLAGS mrarth3.c
$CC -I. -c -O2 $CCFLAGS mrbits.c
$CC -I. -c -O2 $CCFLAGS mrrand.c
$CC -I. -c -O2 $CCFLAGS mrprime.c
$CC -I. -c -O2 $CCFLAGS mrcrt.c
$CC -I. -c -O2 $CCFLAGS mrscrt.c
$CC -I. -c -O2 $CCFLAGS mrmonty.c
$CC -I. -c -O2 $CCFLAGS mrpower.c
$CC -I. -c -O2 $CCFLAGS mrsroot.c
$CC -I. -c -O2 $CCFLAGS mrcurve.c
$CC -I. -c -O2 $CCFLAGS mrfast.c
$CC -I. -c -O2 $CCFLAGS mrshs.c
$CC -I. -c -O2 $CCFLAGS mrshs256.c
$CC -I. -c -O2 $CCFLAGS -w mrshs512.c
$CC -I. -c -O2 $CCFLAGS mraes.c
$CC -I. -c -O2 $CCFLAGS mrlucas.c
$CC -I. -c -O2 $CCFLAGS mrstrong.c
$CC -I. -c -O2 $CCFLAGS mrbrick.c
$CC -I. -c -O2 $CCFLAGS mrebrick.c
$CC -I. -c -O2 $CCFLAGS mrec2m.c
$CC -I. -c -O2 $CCFLAGS mrgf2m.c

cp mrmuldv.ccc mrmuldv.c
$CC -I. -c -O2 $CCFLAGS mrmuldv.c
#as mrmuldv.s -o mrmuldv.o

ar rc miracl.a mrcore.o mrarth0.o mrarth1.o mrarth2.o mralloc.o mrsmall.o
ar r miracl.a mrio1.o mrio2.o mrjack.o mrgcd.o mrxgcd.o mrarth3.o mrbits.o
ar r miracl.a mrrand.o mrprime.o mrcrt.o mrscrt.o mrmonty.o mrcurve.o mrsroot.o
ar r miracl.a mrpower.o mrfast.o mrshs.o mrshs256.o mraes.o mrlucas.o mrstrong.o       
ar r miracl.a mrbrick.o mrebrick.o mrec2m.o mrgf2m.o mrmuldv.o mrshs512.o

ranlib miracl.a

$CC -I. bmark.c miracl.a -o bmark
$CC -I. fact.c miracl.a -o fact
$CC -I. -O2 $CCFLAGS pk-demo.c miracl.a -o pk-demo

rm mr*.o


echo;echo
echo -e "\033[1mtest with: ./pk-demo or ./bmark\033[0m"
echo
