OCaml解析器和语法结构

Dav*_*ink 7 parsing ocaml camlp4

我一直在为一种小语言开发一个解析器,其语法如下

P::= 1 | 0 | P+P | P and P | P wait(d) P 
Run Code Online (Sandbox Code Playgroud)

这是我用Ocaml camlp4编写的代码

action:
  [
     ["act"; a = LIDENT  -> Act(a)]
    |
     ["coact"; a = LIDENT  -> Act2(a)]  
  ];

  proc: 
  [ 
     [ "ZERO" -> Zero]
    | RIGHTA
     ["."; l = action; p = SELF -> Now(l,p)]
    | RIGHTA
     [":"; l = action;  p = SELF -> Delay(l,p)]
    | LEFTA
     [p1 = SELF; "+"; p2 = SELF -> Plus(p1,p2)]
    |RIGHTA
     [p1 = SELF; "WAIT"; "("; d = INT; ")"; p2 = SELF -> Wait(p1,d,p2)]
    | 
     [ x = UIDENT -> Proc(x)]   
  ];
Run Code Online (Sandbox Code Playgroud)

但不幸的是,解析器不解析字符串

.act abort WAIT(4) :act close
Run Code Online (Sandbox Code Playgroud)

因为WAIT构造的规则要求proc作为第一个参数.

我怎样才能解决这个问题?