summaryrefslogtreecommitdiffstats
path: root/šola/aps1/dn/mediane/Makefile
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--šola/aps1/dn/mediane/Makefile102
1 files changed, 102 insertions, 0 deletions
diff --git a/šola/aps1/dn/mediane/Makefile b/šola/aps1/dn/mediane/Makefile
new file mode 100644
index 0000000..2e8d376
--- /dev/null
+++ b/šola/aps1/dn/mediane/Makefile
@@ -0,0 +1,102 @@
+
+# Pred poganjanjem programa make:
+# export name=<ime_datoteke_brez_koncnice>
+#
+# Prevajanje:
+# make
+#
+# Testiranje:
+# make test [neobvezni parametri]
+#
+# Neobvezni parametri:
+# T: "casovna omejitev v sekundah (privzeto = 1)
+# M: za vsak testni primer izpi"si "cas izvajanja (1: da; 0: ne; privzeto = 0)
+# P: obseg testnih primerov, ki naj se obravnava (npr. 3-5 ali 7 ali 2- ali -6 ali -; privzeto = -)
+#
+# Primeri:
+# make test
+# make test P=4-7
+# make test T=3
+# make test T=2 M=1 P=6-
+
+CC = g++
+CFLAGS = -std=c++17 -Wall -Wextra -pedantic
+LIBS = -lm
+
+T = 5
+M = 1
+P = '-'
+
+DIFF_TIMEOUT = 0.5
+
+TIMEOUT_SIGNAL = 124
+SHELL = /bin/bash
+OK_STRING=\033[1;32mOK\033[0;38m
+FAILED_STRING=\033[1;31mfailed\033[0;38m
+TIMEOUT_STRING=\033[1;35mtimeout\033[0;38m
+
+${name} : ${name}.cpp
+ @echo "=== COMPILING: ==="
+ ${CC} ${CFLAGS} -o $@ $< ${LIBS}
+
+test : ${name}
+ @echo "=== TESTING: ==="; \
+ singleTestFile=$$(ls -1 test*.in | head -1); \
+ \
+ testNumberLength=$$(( $${#singleTestFile} - 7 )); \
+ cutParameter=$$((5 + testNumberLength - 1)); \
+ nTests=$$(ls -1 test*.in | cut -c5-$$cutParameter | sort | tail -1); \
+ firstTest=$$(echo $$P | cut -d'-' -f1); \
+ lastTest=$$(echo $$P | cut -d'-' -f2); \
+ if [[ -z $$firstTest ]]; then \
+ firstTest=1; \
+ fi; \
+ if [[ -z $$lastTest ]]; then \
+ lastTest=$$nTests; \
+ fi; \
+ \
+ nPassedTests=0; \
+ nConsideredTests=0; \
+ \
+ trap exit SIGINT; \
+ \
+ timeoutValue=${T}; \
+ hardTimeoutValue=$$((timeoutValue + 2)); \
+ \
+ for i0 in $$(seq $$firstTest $$lastTest); do \
+ i=$$(printf %0$${testNumberLength}d $$i0); \
+ startTime=$$(date +%s.%N); \
+ timeout -k $${hardTimeoutValue} $${timeoutValue} ./${name} < test$$i.in > test$$i.res 2> /dev/null; \
+ result=$$?; \
+ endTime=$$(date +%s.%N); \
+ if [[ $$result == ${TIMEOUT_SIGNAL} ]]; then \
+ if [[ ${M} = 1 ]]; then \
+ echo -e "test$$i -- ${TIMEOUT_STRING} [> $${timeoutValue} s]"; \
+ else \
+ echo -e "test$$i -- ${TIMEOUT_STRING}"; \
+ fi; \
+ else \
+ timeDifference=$$(echo "scale=2; ($${endTime} - $${startTime}) / 1.00" | bc); \
+ measuredTimeString=""; \
+ if [[ ${M} = 1 ]]; then \
+ measuredTimeString=" [$$timeDifference s]"; \
+ fi; \
+ timeout -k ${DIFF_TIMEOUT} ${DIFF_TIMEOUT} diff --ignore-trailing-space test$$i.res test$$i.out > test$$i.diff; \
+ result=$$?; \
+ if [[ $$result == ${TIMEOUT_SIGNAL} ]]; then \
+ cmp test$$i.res test$$i.out > test$$i.diff; \
+ result=$$?; \
+ fi; \
+ if [[ $$result == 0 ]]; then \
+ echo -e "test$$i -- ${OK_STRING} $${measuredTimeString}"; \
+ nPassedTests=$$((nPassedTests + 1)); \
+ else \
+ echo -e "test$$i -- ${FAILED_STRING} $${measuredTimeString}"; \
+ fi \
+ fi; \
+ nConsideredTests=$$((nConsideredTests + 1)); \
+ done; \
+ echo "Result: $$nPassedTests / $$nConsideredTests"
+
+clean :
+ rm -fr ${name} test*.res test*.diff