# possible cron job:
# 
# cd /cfg/backup
# { for(i in 'E0 E1' 'E2 E3' 'E4 E5' 'E6 E7' 'F0 F1' 'F2 F3' 'F4 F5'){
# 	x=`{echo $i}
# 	venti/mirrorarenas -v /dev/sd$x(1)^/arenas /dev/sd$x(2)^/arenas
# } } >www/mirror1.txt >[2=1]
# mv www/mirror1.txt www/mirror.txt
# awk -f mirror-log.awk www/mirror.txt >www/mirror.html

BEGIN {
	print "<html><body><h1>mirror status</h1>"
	print "details in <a href=mirror.txt>mirror.txt</a><br><br>"
	print "<hr><table cellpadding=5 cellspacing=0 border=0>"
	laststatus = ""
	firstarena = ""
	lastarena = ""
	status = ""
	arena = ""
	
}

function fmt(  color) {
	nfmt++
	if(nfmt%2 == 0)
		color = "#cccccc"
	else
		color = "#ffffff"
	return "<tr bgcolor=" color "><td valign=top>%s</td><td valign=top>%s</td><td>%s</td><td>%s</td><td>"
}


function finish() {
	if(!arena && !status)
		return
	if(info == "" && laststatus == status){
		lastarena = arena
		return
	}
	if(firstarena != ""){
		if(firstarena == lastarena)
			printf(fmt(), time, firstarena, "", "");
		else
			printf(fmt(), time, firstarena, "-", lastarena);
		print laststatus "</td></tr>"
		firstarena = ""
		lastarena = ""
		laststatus = ""
	}
	if(info == ""){
		firstarena = arena
		laststatus = status
		lastarena = arena
		return
	}
	printf(fmt(), time, arena, "", "");
	print status
	if(info != ""){
		print "<pre>"
		printf("%s", info)
		print "</pre>"
	}
	print "</td>"
}

$3 !~ /:$/ && $4 ~ /^\(.*-.*\)$/ {
	finish();
	arena = $3
	range = $4
	status = ""
	info = ""
	size = 0
	time = $1 " " $2
	next
}

$3 ~ /:$/ && $0 ~ /^....\/.... ..:..:.. [^ ]/ {
	if($4 == "0" && $5 == "used" && $6 == "mirrored"){
		status = "empty"
		next
	}
	if($4 ~ /^[0-9,]+$/ && $5 == "used" && $6 == "mirrored"){
		size = $4
		status = "partial " size ", mirrored"
		next
	}
	if($4 ~ /^[0-9a-f]+$/ && length($4) == 40 && $5 == "sealed" && $6 == "mirrored"){
		status = "sealed, mirrored";
		next
	}
}

{
	info = info $0 "\n"
}

END{
	finish();
	status = "done"
	arena = ""
	info = ""
	finish();
	print "</table><hr>"
	print "</body></html>"
}