2013-06-18 21 views
10

Próbuję użyć dopasowania do wzorca, aby napisać aplikację kalkulatora.Dopasowywanie wzorców typów rekordów w Ocaml

Dwa główne typy zdefiniowane jak poniżej:

type key = Plus | Minus | Multi | Div | Equals | Digit of int;; 

type state = { 
    lcd: int; (* last computation done *) 
    lka: key; (* last key actived *) 
    loa: key; (* last operation actived *) 
    vpr: int (* value print on the screen *) 
};; 

let print_state s = 
    match s with 
    state (a,_,_,d) -> print_int a; //Here has the compile error 
       print_newline(); 
       print_int d; 
        print_newline();; 

Jednak jeśli mam stan jak:

let initial_state = { lcd=0; lka=Equals; loa=Equals; vpr=0 } ;; 

potem, kiedy wywołać funkcję:

print_state initial_state;; 

Będzie mieć błąd kompilacji. Każdy może powiedzieć, co jest przyczyną nieudanej kompilacji. Dzięki w adv.

Error: Syntax error 
unexpected token "(" 
+1

Ale dlaczego wzorzec dopasowania na płytach? Aby uzyskać 'lcd' z' initial_state', użyj 'initial_state.lcd'. – ben

Odpowiedz

19

Wzór rekord wygląda rekordzie:

match s with 
| { lcd = a; vpr = d; _ } -> (* Expression *) 
+0

Dzięki. Rozwiązałem mój problem. – yjasrc

+4

@yjasrc W nowoczesnym OCaml możesz także pominąć część '=', jeśli nazwałeś zmienną w ten sam sposób, co etykieta: 'match s with {lcd; vpr; _} -> print_int lcd; print_int vpr'. – lukstafi

+1

Aby dodać do komentarza luksatfi, nie trzeba też mieć w ogóle instrukcji match. 'let print_state {lcd; vpr; _} = ... 'powinno wystarczyć. – rgrinberg