# bash makefile for MIRACL (http://indigo.ie/~mscott/)
# for use on AMD64 systems (tested with MIRACL v5.00)
#
# Usual steps to compile MIRACL:
#
# mkdir MIRACL;cd MIRACL
# wget http://indigo.ie/~mscott/miracl.zip
# or: curl -O http://indigo.ie/~mscott/miracl.zip
# unzip -j -aa -L miracl.zip
# cp /path/to/mirdef_amd64.h mirdef.h
# bash <thisFile>
#
# test with: ./pk-demo or ./bmark


if [ ! -f "../mirdef_amd64.h" ]; then
	if [ ! -f "mirdef_amd64.h" ]; then
		echo "mirdef_amd64.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_amd64.h mirdef.h
	fi
else
	cp ../mirdef_amd64.h mirdef.h
fi


# Looks like you'll need '-fPIC' on AMD64 
arg1=-fPIC

rm miracl.a

gcc -I. -c $arg1 -O2 mrcore.c
gcc -I. -c $arg1 -O2 mrarth0.c
gcc -I. -c $arg1 -O2 mrarth1.c
gcc -I. -c $arg1 -O2 mrarth2.c
gcc -I. -c $arg1 -O2 mralloc.c
gcc -I. -c $arg1 -O2 mrsmall.c
gcc -I. -c $arg1 -O2 mrio1.c
gcc -I. -c $arg1 -O2 mrio2.c
gcc -I. -c $arg1 -O2 mrgcd.c
gcc -I. -c $arg1 -O2 mrjack.c
gcc -I. -c $arg1 -O2 mrxgcd.c
gcc -I. -c $arg1 -O2 mrarth3.c
gcc -I. -c $arg1 -O2 mrbits.c
gcc -I. -c $arg1 -O2 mrrand.c
gcc -I. -c $arg1 -O2 mrprime.c
gcc -I. -c $arg1 -O2 mrcrt.c
gcc -I. -c $arg1 -O2 mrscrt.c
gcc -I. -c $arg1 -O2 mrmonty.c
gcc -I. -c $arg1 -O2 mrpower.c
gcc -I. -c $arg1 -O2 mrsroot.c
gcc -I. -c $arg1 -O2 mrcurve.c
gcc -I. -c $arg1 -O2 mrfast.c
gcc -I. -c $arg1 -O2 mrshs.c
gcc -I. -c $arg1 -O2 mrshs256.c
gcc -I. -c $arg1 -O2 -W mrshs512.c
gcc -I. -c $arg1 -O2 mraes.c
gcc -I. -c $arg1 -O2 mrlucas.c
gcc -I. -c $arg1 -O2 mrstrong.c
gcc -I. -c $arg1 -O2 mrbrick.c
gcc -I. -c $arg1 -O2 mrebrick.c
gcc -I. -c $arg1 -O2 mrecgf2m.c
gcc -I. -c $arg1 -O2 mrflash.c
gcc -I. -c $arg1 -O2 mrfrnd.c
gcc -I. -c $arg1 -O2 mrdouble.c
gcc -I. -c $arg1 -O2 mrround.c
gcc -I. -c $arg1 -O2 mrbuild.c
gcc -I. -c $arg1 -O2 mrflsh1.c
gcc -I. -c $arg1 -O2 mrpi.c
gcc -I. -c $arg1 -O2 mrflsh2.c
gcc -I. -c $arg1 -O2 mrflsh3.c
gcc -I. -c $arg1 -O2 mrflsh4.c

as mrmuldv.s64 -o mrmuldv.o
# cp mrmuldv.ccc mrmuldv.c
# gcc -I. -c -O2 $arg1 mrmuldv.c

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 mrflash.o mrfrnd.o mrdouble.o mrround.o mrbuild.o
ar r miracl.a mrflsh1.o mrpi.o mrflsh2.o mrflsh3.o mrflsh4.o 
ar r miracl.a mrbrick.o mrebrick.o mrecgf2m.o mrmuldv.o mrshs512.o

rm mr*.o

ranlib miracl.a

gcc -I. bmark.c miracl.a -o bmark
gcc -I. fact.c miracl.a -o fact
g++  -I. -c $arg1 -O2 big.cpp
g++  -I. -c $arg1 -O2 crt.cpp
g++  -I. -c $arg1 -O2 zzn.cpp
g++  -I. -c $arg1 -O2 ecn.cpp
g++  -I. -c $arg1 -O2 ec2.cpp
g++  -I. mersenne.cpp big.o miracl.a -o mersenne
g++  -I. brent.cpp big.o zzn.o miracl.a -o brent
g++  -I. -c $arg1 -O2 flash.cpp
g++  -I. sample.cpp flash.o miracl.a -o sample
g++  -I. ecsgen.cpp ecn.o big.o miracl.a -o ecsgen
g++  -I. ecsign.cpp ecn.o big.o miracl.a -o ecsign
g++  -I. ecsver.cpp ecn.o big.o miracl.a -o ecsver
g++  -I. pk-demo.cpp ecn.o crt.o big.o miracl.a -o pk-demo
g++  -I. -c $arg1 -O2 polymod.cpp
g++  -I. -c $arg1 -O2 poly.cpp
g++  -I. schoof.cpp polymod.o poly.o ecn.o crt.o zzn.o big.o miracl.a -o schoof


if [ ! -f "miracl.a" ]; then
	echo
	echo "Some sjit happened - MIRACL was NOT compiled :("
	echo
else
	echo
	ls -l miracl.a
	echo
	echo -e "MIRACL compiled -->> $PWD/\033[1mmiracl.a\033[0m"
	echo
	echo "Try './pk-demo' to test it..."
	echo
fi
