let rec parser_of_tree entry nlevn alevn =
                  function
                  | DeadEnd ->
                      (fun (__strm : _ Stream.t) -> raise Stream.Failure)
                  | LocAct (act, _) -> (fun (__strm : _ Stream.t) -> act)
                  | Node
                      {
                        node = Sself;
                        son = LocAct (act, _);
                        brother = DeadEnd
                      } ->
                      (fun (__strm : _ Stream.t) ->
                         let a = entry.estart alevn __strm
                         in Action.getf act a)
                  | Node { node = Sself; son = LocAct (act, _); brother = bro
                      } ->
                      let p2 = parser_of_tree entry nlevn alevn bro
                      in
                        (fun (__strm : _ Stream.t) ->
                           match try Some (entry.estart alevn __strm)
                                 with | Stream.Failure -> None
                           with
                           | Some a -> Action.getf act a
                           | _ -> p2 __strm)
                  | Node { node = s; son = son; brother = DeadEnd } ->
                      let tokl =
                        (match s with
                         | Stoken _ | Skeyword _ ->
                             Tools.get_token_list entry [] s son
                         | _ -> None)
                      in
                        (match tokl with
                         | None ->
                             let ps = parser_of_symbol entry nlevn s in
                             let p1 = parser_of_tree entry nlevn alevn son in
                             let p1 = parser_cont p1 entry nlevn alevn s son
                             in
                               (fun strm ->
                                  let bp = loc_bp strm in
                                  let (__strm : _ Stream.t) = strm in
                                  let a = ps __strm in
                                  let act =
                                    try p1 bp a __strm
                                    with
                                    | Stream.Failure ->
                                        raise (Stream.Error "")
                                  in Action.getf act a)
                         | Some ((tokl, last_tok, son)) ->
                             let p1 = parser_of_tree entry nlevn alevn son in
                             let p1 =
                               parser_cont p1 entry nlevn alevn last_tok son
                             in parser_of_token_list p1 tokl)
                  | Node { node = s; son = son; brother = bro } ->
                      let tokl =
                        (match s with
                         | Stoken _ | Skeyword _ ->
                             Tools.get_token_list entry [] s son
                         | _ -> None)
                      in
                        (match tokl with
                         | None ->
                             let ps = parser_of_symbol entry nlevn s in
                             let p1 = parser_of_tree entry nlevn alevn son in
                             let p1 =
                               parser_cont p1 entry nlevn alevn s son in
                             let p2 = parser_of_tree entry nlevn alevn bro
                             in
                               (fun strm ->
                                  let bp = loc_bp strm in
                                  let (__strm : _ Stream.t) = strm
                                  in
                                    match try Some (ps __strm)
                                          with | Stream.Failure -> None
                                    with
                                    | Some a ->
                                        let act =
                                          (try p1 bp a __strm
                                           with
                                           | Stream.Failure ->
                                               raise (Stream.Error ""))
                                        in Action.getf act a
                                    | _ -> p2 __strm)
                         | Some ((tokl, last_tok, son)) ->
                             let p1 = parser_of_tree entry nlevn alevn son in
                             let p1 =
                               parser_cont p1 entry nlevn alevn last_tok son in
                             let p1 = parser_of_token_list p1 tokl in
                             let p2 = parser_of_tree entry nlevn alevn bro
                             in
                               (fun (__strm : _ Stream.t) ->
                                  try p1 __strm
                                  with | Stream.Failure -> p2 __strm))
                and
                  parser_cont p1 entry nlevn alevn s son loc a
                              (__strm : _ Stream.t) =
                  try p1 __strm
                  with
                  | Stream.Failure ->
                      (try
                         recover parser_of_tree entry nlevn alevn loc a s son
                           __strm
                       with
                       | Stream.Failure ->
                           raise
                             (Stream.Error (Failed.tree_failed entry a s son)))
                and parser_of_token_list p1 tokl =
                  let rec loop n =
                    function
                    | Stoken ((tematch, _)) :: tokl ->
                        (match tokl with
                         | [] ->
                             let ps strm =
                               (match stream_peek_nth strm n with
                                | Some ((tok, _)) when tematch tok ->
                                    (njunk strm n; Action.mk tok)
                                | _ -> raise Stream.Failure)
                             in
                               (fun strm ->
                                  let bp = loc_bp strm in
                                  let (__strm : _ Stream.t) = strm in
                                  let a = ps __strm in
                                  let act =
                                    try p1 bp a __strm
                                    with
                                    | Stream.Failure ->
                                        raise (Stream.Error "")
                                  in Action.getf act a)
                         | _ ->
                             let ps strm =
                               (match stream_peek_nth strm n with
                                | Some ((tok, _)) when tematch tok -> tok
                                | _ -> raise Stream.Failure) in
                             let p1 = loop (n + 1) tokl
                             in
                               (fun (__strm : _ Stream.t) ->
                                  let tok = ps __strm in
                                  let s = __strm in
                                  let act = p1 s in Action.getf act tok))
                    | Skeyword kwd :: tokl ->
                        (match tokl with
                         | [] ->
                             let ps strm =
                               (match stream_peek_nth strm n with
                                | Some ((tok, _)) when
                                    Token.match_keyword kwd tok ->
                                    (njunk strm n; Action.mk tok)
                                | _ -> raise Stream.Failure)
                             in
                               (fun strm ->
                                  let bp = loc_bp strm in
                                  let (__strm : _ Stream.t) = strm in
                                  let a = ps __strm in
                                  let act =
                                    try p1 bp a __strm
                                    with
                                    | Stream.Failure ->
                                        raise (Stream.Error "")
                                  in Action.getf act a)
                         | _ ->
                             let ps strm =
                               (match stream_peek_nth strm n with
                                | Some ((tok, _)) when
                                    Token.match_keyword kwd tok -> tok
                                | _ -> raise Stream.Failure) in
                             let p1 = loop (n + 1) tokl
                             in
                               (fun (__strm : _ Stream.t) ->
                                  let tok = ps __strm in
                                  let s = __strm in
                                  let act = p1 s in Action.getf act tok))
                    | _ -> invalid_arg "parser_of_token_list"
                  in loop 1 tokl
                and parser_of_symbol entry nlevn =
                  function
                  | Smeta (_, symbl, act) ->
                      let act = Obj.magic act entry symbl in
                      let pl = List.map (parser_of_symbol entry nlevn) symbl
                      in
                        Obj.magic
                          (List.fold_left (fun act p -> Obj.magic act p) act
                             pl)
                  | Slist0 s ->
                      let ps = parser_of_symbol entry nlevn s in
                      let rec loop al (__strm : _ Stream.t) =
                        (match try Some (ps __strm)
                               with | Stream.Failure -> None
                         with
                         | Some a -> loop (a :: al) __strm
                         | _ -> al)
                      in
                        (fun (__strm : _ Stream.t) ->
                           let a = loop [] __strm in Action.mk (List.rev a))
                  | Slist0sep (symb, sep) ->
                      let ps = parser_of_symbol entry nlevn symb in
                      let pt = parser_of_symbol entry nlevn sep in
                      let rec kont al (__strm : _ Stream.t) =
                        (match try Some (pt __strm)
                               with | Stream.Failure -> None
                         with
                         | Some v ->
                             let a =
                               (try ps __strm
                                with
                                | Stream.Failure ->
                                    raise
                                      (Stream.Error
                                         (Failed.symb_failed entry v sep symb)))
                             in kont (a :: al) __strm
                         | _ -> al)
                      in
                        (fun (__strm : _ Stream.t) ->
                           match try Some (ps __strm)
                                 with | Stream.Failure -> None
                           with
                           | Some a ->
                               let s = __strm
                               in Action.mk (List.rev (kont [ a ] s))
                           | _ -> Action.mk [])
                  | Slist1 s ->
                      let ps = parser_of_symbol entry nlevn s in
                      let rec loop al (__strm : _ Stream.t) =
                        (match try Some (ps __strm)
                               with | Stream.Failure -> None
                         with
                         | Some a -> loop (a :: al) __strm
                         | _ -> al)
                      in
                        (fun (__strm : _ Stream.t) ->
                           let a = ps __strm in
                           let s = __strm
                           in Action.mk (List.rev (loop [ a ] s)))
                  | Slist1sep (symb, sep) ->
                      let ps = parser_of_symbol entry nlevn symb in
                      let pt = parser_of_symbol entry nlevn sep in
                      let rec kont al (__strm : _ Stream.t) =
                        (match try Some (pt __strm)
                               with | Stream.Failure -> None
                         with
                         | Some v ->
                             let a =
                               (try ps __strm
                                with
                                | Stream.Failure ->
                                    (try parse_top_symb entry symb __strm
                                     with
                                     | Stream.Failure ->
                                         raise
                                           (Stream.Error
                                              (Failed.symb_failed entry v sep
                                                 symb))))
                             in kont (a :: al) __strm
                         | _ -> al)
                      in
                        (fun (__strm : _ Stream.t) ->
                           let a = ps __strm in
                           let s = __strm
                           in Action.mk (List.rev (kont [ a ] s)))
                  | Sopt s ->
                      let ps = parser_of_symbol entry nlevn s
                      in
                        (fun (__strm : _ Stream.t) ->
                           match try Some (ps __strm)
                                 with | Stream.Failure -> None
                           with
                           | Some a -> Action.mk (Some a)
                           | _ -> Action.mk None)
                  | Stry s ->
                      let ps = parser_of_symbol entry nlevn s
                      in try_parser ps
                  | Stree t ->
                      let pt = parser_of_tree entry 1 0 t
                      in
                        (fun strm ->
                           let bp = loc_bp strm in
                           let (__strm : _ Stream.t) = strm in
                           let (act, loc) = add_loc bp pt __strm
                           in Action.getf act loc)
                  | Snterm e ->
                      (fun (__strm : _ Stream.t) -> e.estart 0 __strm)
                  | Snterml (e, l) ->
                      (fun (__strm : _ Stream.t) ->
                         e.estart (level_number e l) __strm)
                  | Sself ->
                      (fun (__strm : _ Stream.t) -> entry.estart 0 __strm)
                  | Snext ->
                      (fun (__strm : _ Stream.t) -> entry.estart nlevn __strm)
                  | Skeyword kwd ->
                      (fun (__strm : _ Stream.t) ->
                         match Stream.peek __strm with
                         | Some ((tok, _)) when Token.match_keyword kwd tok
                             -> (Stream.junk __strm; Action.mk tok)
                         | _ -> raise Stream.Failure)
                  | Stoken ((f, _)) ->
                      (fun (__strm : _ Stream.t) ->
                         match Stream.peek __strm with
                         | Some ((tok, _)) when f tok ->
                             (Stream.junk __strm; Action.mk tok)
                         | _ -> raise Stream.Failure)
                and parse_top_symb entry symb strm =
                  parser_of_symbol entry 0 (top_symb entry symb) strm