forked from mit-plv/koika
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Show.v
39 lines (32 loc) · 1.28 KB
/
Show.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
(*! Utilities | Show typeclass (α → string) !*)
Require Export Coq.Strings.String.
Require Import Coq.Arith.PeanoNat.
Class Show (A: Type) :=
{ show: A -> string }.
Module Show_nat.
Lemma digit_lt_base m {n} : not (m + n < m).
Proof.
red; intros; eapply Nat.nle_succ_diag_l; eauto using Nat.le_trans, Nat.le_add_r.
Qed.
Definition string_of_base10_digit (n: {i : nat | i < 10}) :=
match n with
| exist _ 0 _ => "0" | exist _ 1 _ => "1" | exist _ 2 _ => "2" | exist _ 3 _ => "3" | exist _ 4 _ => "4"
| exist _ 5 _ => "5" | exist _ 6 _ => "6" | exist _ 7 _ => "7" | exist _ 8 _ => "8" | exist _ 9 _ => "9"
| exist _ _n pr => False_rect _ (digit_lt_base 10 pr)
end%string.
Fixpoint string_of_nat_rec (fuel: nat) (n: nat) :=
match fuel with
| O => ""%string
| S fuel =>
match (Compare_dec.lt_dec n 10) with
| left pr => string_of_base10_digit (exist _ n pr)
| right pr => append (string_of_nat_rec fuel (PeanoNat.Nat.div n 10)) (string_of_nat_rec fuel (PeanoNat.Nat.modulo n 10))
end
end.
Definition string_of_nat (n: nat) :=
string_of_nat_rec (S n) n.
End Show_nat.
#[export] Instance Show_nat : Show nat :=
{| show := Show_nat.string_of_nat |}.
#[export] Instance Show_string : Show string :=
{| show x := x |}.