A new approach, using simp_of_act and simp_of_set to activate definitions when
necessary
GCD = WF_Rel +
consts gcd :: "nat*nat => nat"
recdef gcd "measure ((%(m,n).n))"
simpset "simpset() addsimps [mod_less_divisor]"
"gcd (m, n) = (if n=0 then m else gcd(n, m mod n))"
end