From mboxrd@z Thu Jan 1 00:00:00 1970 Received: (from majordomo@localhost) by pauillac.inria.fr (8.7.6/8.7.3) id EAA13547; Fri, 12 Jul 2002 04:33:12 +0200 (MET DST) X-Authentication-Warning: pauillac.inria.fr: majordomo set sender to owner-caml-list@pauillac.inria.fr using -f Received: from concorde.inria.fr (concorde.inria.fr [192.93.2.39]) by pauillac.inria.fr (8.7.6/8.7.3) with ESMTP id EAA13453 for ; Fri, 12 Jul 2002 04:33:11 +0200 (MET DST) Received: from postfix3-2.free.fr (postfix3-2.free.fr [213.228.0.169]) by concorde.inria.fr (8.11.1/8.11.1) with ESMTP id g6C2XAD04487 for ; Fri, 12 Jul 2002 04:33:10 +0200 (MET DST) Received: from lfs (strasbourg-4-a7-62-147-196-170.dial.proxad.net [62.147.196.170]) by postfix3-2.free.fr (Postfix) with SMTP id 28E8617F63 for ; Fri, 12 Jul 2002 04:33:10 +0200 (CEST) Date: Fri, 12 Jul 2002 04:41:21 +0200 From: Nicolas FRANCOIS (AKA El Bofo) To: Caml List Subject: [Caml-list] What's wrong with my parser ? Message-Id: <20020712044121.3f253c69.nicolas.francois@free.fr> X-Mailer: Sylpheed version 0.7.6 (GTK+ 1.2.10; i686-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-caml-list@pauillac.inria.fr Precedence: bulk I define a polynom parser like this : let rec parse = let parse_puissance = parser | [< ''^'; e = parse_int >] -> e | [< >] -> 1 in let parse_x = parser | [< ''X'; e = parse_puissance >] -> e | [< >] -> 0 in let parse_coeff = parser | [< n = R.parse >] -> n | [< >] -> R.one in let parse_monome = parser | [< n = R.parse; e = parse_x >] -> monome n e | [< e = parse_x >] -> monome R.one e in parser | [< ''+'; m = parse_monome; p = parse >] -> m ++ p | [< ''-'; m = parse_monome; p = parse >] -> (opp m) ++ p | [< m = parse_monome; p = parse >] -> m ++ p | [< >] -> zero parse_int and the R.parse functions work OK, and I'll add all the "_=parse_space" after. But : # let p1 = P.parse (Stream.of_string "1+X");; Stack overflow during evaluation (looping recursion?). What's the problem ? \bye -- Nicolas FRANCOIS http://nicolas.francois.free.fr A TRUE Klingon programmer does NOT comment his code ------------------- To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/ Beginner's list: http://groups.yahoo.com/group/ocaml_beginners