]> www.ginac.de Git - ginac.git/commitdiff
Parser can now read GiNaC lists (lst) defined by braces.
authorJens Vollinga <jens.vollinga@googlemail.com>
Fri, 28 Oct 2011 19:09:33 +0000 (21:09 +0200)
committerJens Vollinga <jens.vollinga@googlemail.com>
Fri, 28 Oct 2011 19:09:33 +0000 (21:09 +0200)
This commit completes the bug fix in commit
9a4f392521083d28e1c238e7898ab1d2ac5b73cd.

ginac/parser/parser.cpp
ginac/parser/parser.h

index 992b151079c60aee8daaf6a632c4cbff1f5486a3..de6b269ac1ac934209d16989e2d836b431e0db8d 100644 (file)
@@ -120,6 +120,34 @@ ex parser::parse_paren_expr()
        return e;
 }
 
+/// lst_expr:  '{' expression { ',' expression } '}'
+ex parser::parse_lst_expr()
+{
+       get_next_tok();  // eat {.
+
+       lst list;
+       if (token != '}') {
+               while (true) {
+                       ex e = parse_expression(); // expression();
+                       list.append(e);
+
+                       if (token == '}') {
+                               break;
+                       }
+
+                       if (token != ',') {
+                               Parse_error("expected '}'");
+                       }
+
+                       get_next_tok();  // eat ','.
+               }
+       }
+       // Eat the '}'.
+       get_next_tok();
+
+       return list;
+}
+
 extern const ex _ex0;
 
 /// unary_expr: [+-] expression
@@ -151,6 +179,8 @@ ex parser::parse_primary()
                         return parse_number_expr();
                case '(': 
                         return parse_paren_expr();
+               case '{': 
+                        return parse_lst_expr();
                case '-':
                case '+':
                         return parse_unary_expr();
index ac57a7986f0fd4990b04ccb6f637415a4e8f1973..cab02c39b679a0457e29fd49db9f551d5d1f6078 100644 (file)
@@ -67,6 +67,9 @@ class parser
        /// paren_expr: '(' expression ')'
        ex parse_paren_expr();
 
+       /// lst_expr: '{' expression { ',' expression } '}'
+       ex parse_lst_expr();
+
        /// number_expr: number
        ex parse_number_expr();