changeset 1495:2e8a5df45d56

better xml
author Franklin Schmidt <fschmidt@gmail.com>
date Tue, 05 May 2020 11:03:48 -0600 (2020-05-05)
parents 91c167099462
children 6c830be6be98
files src/luan/LuanTable.java src/luan/modules/parsers/Xml.java
diffstat 2 files changed, 24 insertions(+), 36 deletions(-) [+]
line wrap: on
line diff
--- a/src/luan/LuanTable.java	Sun May 03 11:51:31 2020 -0600
+++ b/src/luan/LuanTable.java	Tue May 05 11:03:48 2020 -0600
@@ -124,7 +124,7 @@
 		return map==null || map.isEmpty();
 	}
 
-	boolean isMap() {
+	public boolean isMap() {
 		return map!=null || list==null;
 	}
 
--- a/src/luan/modules/parsers/Xml.java	Sun May 03 11:51:31 2020 -0600
+++ b/src/luan/modules/parsers/Xml.java	Tue May 05 11:03:48 2020 -0600
@@ -11,6 +11,7 @@
 import luan.Luan;
 import luan.LuanTable;
 import luan.LuanException;
+import luan.modules.BasicLuan;
 
 
 public final class Xml {
@@ -22,31 +23,27 @@
 		return elements[0].toString();
 	}
 
-	private static final Integer ONE = Integer.valueOf(1);
-	private static final Integer TWO = Integer.valueOf(2);
-	private static final String LIST = "$list";
+	private static final String ATTRIBUTES = "xml_attributes";
+	private static final String TEXT = "xml_text";
 
 	private static XmlElement[] elements(LuanTable tbl) throws LuanException {
 		List<XmlElement> list = new ArrayList<XmlElement>();
 		for( Map.Entry entry : tbl.iterable() ) {
 			Object key = entry.getKey();
-			if( key.equals(ONE) )
-				continue;
 			if( !(key instanceof String) )
 				throw new LuanException("XML key must be string");
 			String name = (String)key;
 			Object value = entry.getValue();
-			if( value instanceof String ) {
-				list.add( element(name,value) );
+			if( name.equals(ATTRIBUTES) )
+				continue;
+			if( name.equals(TEXT) )
+				throw new LuanException("Can't mix text and elements");
+			LuanTable t = (LuanTable)value;
+			if( t.isMap() ) {
+				list.add( element(name,t) );
 			} else {
-				LuanTable t = (LuanTable)value;
-				LuanTable tList = (LuanTable)t.get(LIST);
-				if( tList == null ) {
-					list.add( element(name,t) );
-				} else {
-					for( Object obj : tList.asList() ) {
-						list.add( element(name,obj) );
-					}
+				for( Object obj : t.asList() ) {
+					list.add( element(name,obj) );
 				}
 			}
 		}
@@ -59,7 +56,7 @@
 		}
 		LuanTable t = (LuanTable)obj;
 		Map<String,String> attributes = attributes(t);
-		String s = (String)t.get(TWO);
+		String s = (String)t.get(TEXT);
 		if( s != null ) {
 			return new XmlElement(name,attributes,s);
 		} else {
@@ -73,7 +70,7 @@
 	}
 
 	private static Map<String,String> attributes(LuanTable tbl) throws LuanException {
-		Object obj = tbl.get(ONE);
+		Object obj = tbl.get(ATTRIBUTES);
 		if( obj==null )
 			return Collections.emptyMap();
 		LuanTable t = (LuanTable)obj;
@@ -102,36 +99,27 @@
 				for( Map.Entry<String,String> entry : element.attributes.entrySet() ) {
 					attrs.put(entry.getKey(),entry.getValue());
 				}
-				t.put( 1, attrs );
+				t.put( ATTRIBUTES, attrs );
 			}
-			Object value = t;
 			if( element.content == null ) {
 				// nothing
 			} else if( element.content instanceof String ) {
-				if( t.isEmpty() ) {
-					value = element.content;
-				} else {
-					t.put( 2, element.content );
-				}
+				t.put( TEXT, element.content );
 			} else {
 				XmlElement[] els = (XmlElement[])element.content;
 				addElements(t,els);
 			}
-			Object old = tbl.get(element.name);
+			LuanTable old = (LuanTable)tbl.get(element.name);
 			if( old==null ) {
-				tbl.put(element.name,value);
+				tbl.put(element.name,t);
 			} else {
-				LuanTable list = null;
-				if( old instanceof LuanTable )
-					list = (LuanTable)((LuanTable)old).get(LIST);
-				if( list==null ) {
-					list = new LuanTable(tbl.luan());
+				if( !old.isList() ) {
+					LuanTable list = new LuanTable(tbl.luan());
 					list.rawAdd(old);
-					LuanTable wrap = new LuanTable(tbl.luan());
-					wrap.put(LIST,list);
-					tbl.put(element.name,wrap);
+					old = list;
+					tbl.put(element.name,old);
 				}
-				list.rawAdd(value);
+				old.rawAdd(t);
 			}
 		}
 		return tbl;