changeset 1096:5dc601c4ed6d

fix parser errors
author Franklin Schmidt <fschmidt@gmail.com>
date Sun, 05 Mar 2017 15:25:23 -0700 (2017-03-05)
parents 2443152dc2f1
children b2e4a22ffa5d
files src/luan/impl/LuanParser.java
diffstat 1 files changed, 43 insertions(+), 21 deletions(-) [+]
line wrap: on
line diff
diff -r 2443152dc2f1 -r 5dc601c4ed6d src/luan/impl/LuanParser.java
--- a/src/luan/impl/LuanParser.java	Tue Feb 21 20:27:17 2017 -0700
+++ b/src/luan/impl/LuanParser.java	Sun Mar 05 15:25:23 2017 -0700
@@ -1263,8 +1263,20 @@
 
 	private Var nameVar(final String name) {
 		return new Var() {
+			private Expr exp = null;
 
 			public Expr exp() throws ParseException {
+				if( exp == null ) {
+					String sp = parser.sb().toString();
+					parser.sb().setLength(0);
+					exp = calcExp();
+					if( sp.length() > 0 )
+						exp.add(sp);
+				}
+				return exp;
+			}
+
+			private Expr calcExp() throws ParseException {
 				Sym sym = getSym(name);
 				if( sym != null )
 					return sym.exp();
@@ -1438,6 +1450,7 @@
 		if( keywords.contains(match) )
 			return parser.failure(null);
 		Spaces();
+		parser.upSb();
 		return parser.success(match);
 	}
 
@@ -1919,32 +1932,41 @@
 	}
 
 	private Expr expString(List<Expr> list) {
-		Expr exp = new Expr(Val.ARRAY,false);
 		switch(list.size()) {
 		case 0:
-			exp.add("LuanFunction.NOTHING");
-			return exp;
+			{
+				Expr exp = new Expr(Val.ARRAY,false);
+				exp.add("LuanFunction.NOTHING");
+				return exp;
+			}
 		case 1:
-			return list.get(0);
-		default:
-			int lastI = list.size() - 1;
-			exp.add( "new Object[]{" );
-			for( int i=0; i<lastI; i++ ) {
-				exp.addAll( list.get(i).single() );
-				exp.add( "," );
+			{
+				Expr exp = list.get(0);
+				exp.prependNewLines();
+				return exp;
 			}
-			Expr last = list.get(lastI);
-			if( last.valType==Val.SINGLE ) {
-				exp.addAll( last );
-				exp.add( "}" );
-			} else {
-				exp.add( "}" );
-				exp.add( 0, "LuanImpl.concatArgs(" );
-				exp.add( "," );
-				exp.addAll( last );
-				exp.add( ")" );
+		default:
+			{
+				Expr exp = new Expr(Val.ARRAY,false);
+				int lastI = list.size() - 1;
+				exp.add( "new Object[]{" );
+				for( int i=0; i<lastI; i++ ) {
+					exp.addAll( list.get(i).single() );
+					exp.add( "," );
+				}
+				Expr last = list.get(lastI);
+				if( last.valType==Val.SINGLE ) {
+					exp.addAll( last );
+					exp.add( "}" );
+				} else {
+					exp.add( "}" );
+					exp.add( 0, "LuanImpl.concatArgs(" );
+					exp.add( "," );
+					exp.addAll( last );
+					exp.add( ")" );
+				}
+				return exp;
 			}
-			return exp;
 		}
 	}