changeset 46:a443637829c1

remove LuaNumber git-svn-id: https://luan-java.googlecode.com/svn/trunk@47 21e917c8-12df-6dd8-5cb6-c86387c605b9
author fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
date Thu, 27 Dec 2012 01:48:36 +0000 (2012-12-27)
parents b1b14d09fc98
children 659c7139e903
files src/luan/Lua.java src/luan/LuaJavaFunction.java src/luan/LuaNumber.java src/luan/LuaState.java src/luan/LuaTable.java src/luan/interp/AddExpr.java src/luan/interp/DivExpr.java src/luan/interp/EqExpr.java src/luan/interp/LeExpr.java src/luan/interp/LenExpr.java src/luan/interp/LtExpr.java src/luan/interp/LuaParser.java src/luan/interp/ModExpr.java src/luan/interp/MulExpr.java src/luan/interp/NumericForStmt.java src/luan/interp/PowExpr.java src/luan/interp/SubExpr.java src/luan/interp/TableExpr.java src/luan/interp/UnmExpr.java src/luan/lib/BasicLib.java src/luan/lib/JavaLib.java src/luan/lib/StringLib.java src/luan/lib/TableLib.java src/luan/tools/CmdLine.java
diffstat 24 files changed, 126 insertions(+), 348 deletions(-) [+]
line wrap: on
line diff
--- a/src/luan/Lua.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/Lua.java	Thu Dec 27 01:48:36 2012 +0000
@@ -11,7 +11,7 @@
 			return "string";
 		if( obj instanceof Boolean )
 			return "boolean";
-		if( obj instanceof LuaNumber )
+		if( obj instanceof Number )
 			return "number";
 		return "userdata";
 	}
@@ -21,25 +21,27 @@
 	}
 
 	public static String asString(Object obj) {
-		if( obj instanceof String || obj instanceof LuaNumber )
-			return obj.toString();
+		if( obj instanceof String )
+			return (String)obj;
+		if( obj instanceof Number )
+			return toString((Number)obj);
 		return null;
 	}
 
-	public static LuaNumber toNumber(Object obj) {
+	public static Number toNumber(Object obj) {
 		return toNumber(obj,null);
 	}
 
-	public static LuaNumber toNumber(Object obj,Integer base) {
-		if( obj instanceof LuaNumber )
-			return (LuaNumber)obj;
+	public static Number toNumber(Object obj,Integer base) {
+		if( obj instanceof Number )
+			return (Number)obj;
 		if( obj instanceof String ) {
 			String s = (String)obj;
 			try {
 				if( base==null )
-					return LuaNumber.of( Double.parseDouble(s) );
+					return Double.valueOf(s);
 				else
-					return LuaNumber.of( Long.parseLong(s,base) );
+					return Long.valueOf(s,base);
 			} catch(NumberFormatException e) {}
 		}
 		return null;
@@ -49,4 +51,30 @@
 		return a.length==0 ? null : a[0];
 	}
 
+	public static String toString(Number n) {
+		if( n instanceof Integer )
+			return n.toString();
+		String s = n.toString();
+		int iE = s.indexOf('E');
+		String ending  = null;
+		if( iE != -1 ) {
+			ending = s.substring(iE);
+			s = s.substring(0,iE);
+		}
+		if( s.endsWith(".0") )
+			s = s.substring(0,s.length()-2);
+		if( ending != null )
+			s += ending;
+		return s;
+	}
+
+	public static Integer asInteger(Object obj) {
+		if( obj instanceof Integer )
+			return (Integer)obj;
+		if( !(obj instanceof Number) )
+			return null;
+		Number n = (Number)obj;
+		int i = n.intValue();
+		return i==n.doubleValue() ? Integer.valueOf(i) : null;
+	}
 }
--- a/src/luan/LuaJavaFunction.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/LuaJavaFunction.java	Thu Dec 27 01:48:36 2012 +0000
@@ -125,56 +125,16 @@
 
 	private static final Object[] NULL_RTN = new Object[1];
 
-	private static final RtnConverter RTN_NUMBER = new RtnConverter() {
-		public Object[] convert(Object obj) {
-			if( obj == null )
-				return NULL_RTN;
-			Number n = (Number)obj;
-			LuaNumber ln = LuaNumber.of(n);
-			return new Object[]{ln};
-		}
-	};
-
-	private static final RtnConverter RTN_NUMBER_ARRAY = new RtnConverter() {
-		public Object[] convert(Object obj) {
-			if( obj == null )
-				return NULL_RTN;
-			Object[] rtn = new Object[Array.getLength(obj)];
-			for( int i=0; i<rtn.length; i++ ) {
-				Number n = (Number)Array.get(obj,i);
-				if( n != null )
-					rtn[i] = LuaNumber.of(n.doubleValue());
-			}
-			return rtn;
-		}
-	};
-
 	private static RtnConverter getRtnConverter(JavaMethod m) {
 		Class<?> rtnType = m.getReturnType();
 		if( rtnType == Void.TYPE )
 			return RTN_EMPTY;
-		if( isNumber(rtnType) )
-			return RTN_NUMBER;
 		if( rtnType.isArray() ) {
-			rtnType = rtnType.getComponentType();
-			if( isNumber(rtnType) )
-				return RTN_NUMBER_ARRAY;
 			return RTN_ARRAY;
 		}
 		return RTN_ONE;
 	}
 
-	private static boolean isNumber(Class<?> rtnType) {
-		return Number.class.isAssignableFrom(rtnType)
-			|| rtnType == Byte.TYPE
-			|| rtnType == Short.TYPE
-			|| rtnType == Integer.TYPE
-			|| rtnType == Long.TYPE
-			|| rtnType == Float.TYPE
-			|| rtnType == Double.TYPE
-		;
-	}
-
 
 	private interface ArgConverter {
 		public Object convert(Object obj);
@@ -186,110 +146,6 @@
 		}
 	};
 
-	private static final ArgConverter ARG_DOUBLE = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				return Double.valueOf(ln.n);
-			}
-			if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Double.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
-	private static final ArgConverter ARG_FLOAT = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				return Float.valueOf((float)ln.n);
-			}
-			if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Float.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
-	private static final ArgConverter ARG_LONG = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				long i = (long)ln.n;
-				if( i == ln.n )
-					return Long.valueOf(i);
-			}
-			else if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Long.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
-	private static final ArgConverter ARG_INTEGER = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				int i = (int)ln.n;
-				if( i == ln.n )
-					return Integer.valueOf(i);
-			}
-			else if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Integer.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
-	private static final ArgConverter ARG_SHORT = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				short i = (short)ln.n;
-				if( i == ln.n )
-					return Short.valueOf(i);
-			}
-			else if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Short.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
-	private static final ArgConverter ARG_BYTE = new ArgConverter() {
-		public Object convert(Object obj) {
-			if( obj instanceof LuaNumber ) {
-				LuaNumber ln = (LuaNumber)obj;
-				byte i = (byte)ln.n;
-				if( i == ln.n )
-					return Byte.valueOf(i);
-			}
-			else if( obj instanceof String ) {
-				String s = (String)obj;
-				try {
-					return Byte.valueOf(s);
-				} catch(NumberFormatException e) {}
-			}
-			return obj;
-		}
-	};
-
 	private static boolean takesLuaState(JavaMethod m) {
 		Class<?>[] paramTypes = m.getParameterTypes();
 		return paramTypes.length > 0 && paramTypes[0].equals(LuaState.class);
@@ -314,18 +170,6 @@
 	}
 
 	private static ArgConverter getArgConverter(Class<?> cls) {
-		if( cls == Double.TYPE || cls.equals(Double.class) )
-			return ARG_DOUBLE;
-		if( cls == Float.TYPE || cls.equals(Float.class) )
-			return ARG_FLOAT;
-		if( cls == Long.TYPE || cls.equals(Long.class) )
-			return ARG_LONG;
-		if( cls == Integer.TYPE || cls.equals(Integer.class) )
-			return ARG_INTEGER;
-		if( cls == Short.TYPE || cls.equals(Short.class) )
-			return ARG_SHORT;
-		if( cls == Byte.TYPE || cls.equals(Byte.class) )
-			return ARG_BYTE;
 		return ARG_SAME;
 	}
 
--- a/src/luan/LuaNumber.java	Thu Dec 27 00:44:58 2012 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,67 +0,0 @@
-package luan;
-
-
-public final class LuaNumber implements Comparable<LuaNumber> {
-	final double n;
-
-	private LuaNumber(double n) {
-		this.n = n;
-	}
-
-	public double value() {
-		return n;
-	}
-
-	// convert to Lua format
-	@Override public String toString() {
-		String s = Double.toString(n);
-		int iE = s.indexOf('E');
-		String ending  = null;
-		if( iE != -1 ) {
-			ending = s.substring(iE);
-			s = s.substring(0,iE);
-		}
-		if( s.endsWith(".0") )
-			s = s.substring(0,s.length()-2);
-		if( ending != null )
-			s += ending;
-		return s;
-	}
-
-	@Override public boolean equals(Object obj) {
-		if( !(obj instanceof LuaNumber) )
-			return false;
-		LuaNumber ln = (LuaNumber)obj;
-		return n == ln.n;
-	}
-
-	@Override public int hashCode() {
-		return Double.valueOf(n).hashCode();
-	}
-
-	@Override public int compareTo(LuaNumber ln) {
-		return Double.compare(n,ln.n);
-	}
-
-	public static LuaNumber of(double n) {
-		return new LuaNumber(n);
-	}
-
-	private static LuaNumber[] ints = new LuaNumber[100];
-	static {
-		for( int i=0; i<ints.length; i++ ) {
-			ints[i] = new LuaNumber(i);
-		}
-	}
-
-	public static LuaNumber of(int n) {
-		if( 0 <= n && n < ints.length )
-			return ints[n];
-		return new LuaNumber(n);
-	}
-
-	public static LuaNumber of(Number n) {
-		return n instanceof Integer ? of(n.intValue()) : of(n.doubleValue());
-	}
-
-}
--- a/src/luan/LuaState.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/LuaState.java	Thu Dec 27 01:48:36 2012 +0000
@@ -46,8 +46,8 @@
 		return s;
 	}
 
-	public final LuaNumber checkNumber(LuaElement el,Object obj) throws LuaException {
-		LuaNumber n = Lua.toNumber(obj);
+	public final Number checkNumber(LuaElement el,Object obj) throws LuaException {
+		Number n = Lua.toNumber(obj);
 		if( n == null )
 			throw new LuaException( this, el, "attempt to perform arithmetic on a " + Lua.type(obj) + " value" );
 		return n;
@@ -65,6 +65,8 @@
 			return checkString( el, Lua.first( call(fn,el,"__tostring",obj) ) );
 		if( obj == null )
 			return "nil";
+		if( obj instanceof Number )
+			return Lua.toString((Number)obj);
 		if( obj instanceof LuaException ) {
 			LuaException le = (LuaException)obj;
 			return le.getMessage();
@@ -93,10 +95,10 @@
 	}
 
 	public final boolean isLessThan(LuaElement el,Object o1,Object o2) throws LuaException {
-		if( o1 instanceof LuaNumber && o2 instanceof LuaNumber ) {
-			LuaNumber n1 = (LuaNumber)o1;
-			LuaNumber n2 = (LuaNumber)o2;
-			return n1.compareTo(n2) < 0;
+		if( o1 instanceof Number && o2 instanceof Number ) {
+			Number n1 = (Number)o1;
+			Number n2 = (Number)o2;
+			return n1.doubleValue() < n2.doubleValue();
 		}
 		if( o1 instanceof String && o2 instanceof String ) {
 			String s1 = (String)o1;
--- a/src/luan/LuaTable.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/LuaTable.java	Thu Dec 27 01:48:36 2012 +0000
@@ -26,11 +26,10 @@
 	}
 
 	public Object get(Object key) {
-		if( list != null && key instanceof LuaNumber ) {
-			LuaNumber ln = (LuaNumber)key;
-			int i = (int)ln.n;
-			if( i == ln.n ) {
-				i--;
+		if( list != null ) {
+			Integer iT = Lua.asInteger(key);
+			if( iT != null ) {
+				int i = iT - 1;
 				if( i>=0 && i<list.size() )
 					return list.get(i);
 			}
@@ -41,43 +40,44 @@
 	}
 
 	public Object put(Object key,Object val) {
-		if( key instanceof LuaNumber ) {
-			LuaNumber ln = (LuaNumber)key;
-			int i = (int)ln.n;
-			if( i == ln.n ) {
-				i--;
-				if( list == null && i == 0 )
-					list = new ArrayList<Object>();
-				if( list != null ) {
-					if( i == list.size() ) {
-						if( val != null ) {
-							list.add(val);
-							if( map != null ) {
-								while(true) {
-									Object v = map.remove(LuaNumber.of(list.size()+1));
-									if( v == null )
-										break;
-									list.add(v);
-								}
+		Integer iT = Lua.asInteger(key);
+		if( iT != null ) {
+			int i = iT - 1;
+			if( list == null && i == 0 )
+				list = new ArrayList<Object>();
+			if( list != null ) {
+				if( i == list.size() ) {
+					if( val != null ) {
+						list.add(val);
+						if( map != null ) {
+							while(true) {
+								Object v = map.remove(Double.valueOf(list.size()+1));
+								if( v == null )
+									break;
+								list.add(v);
 							}
 						}
-						return null;
-					} else if( i>=0 && i<list.size() ) {
-						Object old = list.get(i);
-						list.set(i,val);
-						if( val == null && i == list.size()-1 ) {
-							while( i>=0 && list.get(i)==null ) {
-								list.remove(i--);
-							}
+					}
+					return null;
+				} else if( i>=0 && i<list.size() ) {
+					Object old = list.get(i);
+					list.set(i,val);
+					if( val == null && i == list.size()-1 ) {
+						while( i>=0 && list.get(i)==null ) {
+							list.remove(i--);
 						}
-						return old;
 					}
+					return old;
 				}
 			}
 		}
 		if( map==null ) {
 			map = new HashMap<Object,Object>();
 		}
+		if( key instanceof Number && !(key instanceof Double) ) {
+			Number n = (Number)key;
+			key = Double.valueOf(n.doubleValue());
+		}
 		if( val == null ) {
 			return map.remove(key);
 		} else {
@@ -144,7 +144,7 @@
 				return iter.hasNext();
 			}
 			public Map.Entry<Object,Object> next() {
-				LuaNumber key = LuaNumber.of(iter.nextIndex()+1);
+				Double key = Double.valueOf(iter.nextIndex()+1);
 				return new MapEntry(key,iter.next());
 			}
 			public void remove() {
--- a/src/luan/interp/AddExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/AddExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( n1.value() + n2.value() );
+			return n1.doubleValue() + n2.doubleValue();
 		return arithmetic(lua,"__add",o1,o2);
 	}
 }
--- a/src/luan/interp/DivExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/DivExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( n1.value() / n2.value() );
+			return n1.doubleValue() / n2.doubleValue();
 		return arithmetic(lua,"__div",o1,o2);
 	}
 }
--- a/src/luan/interp/EqExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/EqExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaTable;
 import luan.LuaException;
@@ -19,6 +18,11 @@
 		Object o2 = op2.eval(lua);
 		if( o1 == o2 || o1 != null && o1.equals(o2) )
 			return true;
+		if( o1 instanceof Number && o2 instanceof Number ) {
+			Number n1 = (Number)o1;
+			Number n2 = (Number)o2;
+			return n1.doubleValue() == n2.doubleValue();
+		}
 		if( !o1.getClass().equals(o2.getClass()) )
 			return false;
 		LuaTable mt1 = lua.getMetatable(o1);
--- a/src/luan/interp/LeExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/LeExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaException;
 import luan.LuaSource;
@@ -16,10 +15,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		if( o1 instanceof LuaNumber && o2 instanceof LuaNumber ) {
-			LuaNumber n1 = (LuaNumber)o1;
-			LuaNumber n2 = (LuaNumber)o2;
-			return n1.compareTo(n2) <= 0;
+		if( o1 instanceof Number && o2 instanceof Number ) {
+			Number n1 = (Number)o1;
+			Number n2 = (Number)o2;
+			return n1.doubleValue() <= n2.doubleValue();
 		}
 		if( o1 instanceof String && o2 instanceof String ) {
 			String s1 = (String)o1;
--- a/src/luan/interp/LenExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/LenExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaTable;
 import luan.LuaFunction;
 import luan.LuaException;
@@ -18,7 +17,7 @@
 		Object o = op.eval(lua);
 		if( o instanceof String ) {
 			String s = (String)o;
-			return LuaNumber.of( s.length() );
+			return s.length();
 		}
 		LuaFunction fn = lua.getHandlerFunction(se,"__len",o);
 		if( fn != null )
--- a/src/luan/interp/LtExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/LtExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaException;
 import luan.LuaSource;
--- a/src/luan/interp/LuaParser.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/LuaParser.java	Thu Dec 27 01:48:36 2012 +0000
@@ -17,7 +17,6 @@
 import org.parboiled.support.ValueStack;
 import org.parboiled.errors.ErrorUtils;
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaState;
 import luan.LuaSource;
 
@@ -304,7 +303,7 @@
 		return Sequence(
 			start.set(currentIndex()),
 			Keyword("for"), Name(), '=', Spaces(), Expr(), Keyword("to"), Expr(),
-			push( new ConstExpr(LuaNumber.of(1)) ),  // default step
+			push( new ConstExpr(1) ),  // default step
 			Optional(
 				Keyword("step"),
 				drop(),
@@ -892,13 +891,6 @@
 	}
 
 	Rule NumberLiteral() {
-		return Sequence(
-			Number(),
-			push(LuaNumber.of((Double)pop()))
-		);
-	}
-
-	Rule Number() {
 		return FirstOf(
 			Sequence(
 				IgnoreCase("0x"),
@@ -906,7 +898,7 @@
 			),
 			Sequence(
 				DecNumber(),
-				push(Double.parseDouble(match()))
+				push(Double.valueOf(match()))
 			)
 		);
 	}
--- a/src/luan/interp/ModExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/ModExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( n1.value() % n2.value() );
+			return n1.doubleValue() % n2.doubleValue();
 		return arithmetic(lua,"__mod",o1,o2);
 	}
 }
--- a/src/luan/interp/MulExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/MulExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( n1.value() * n2.value() );
+			return n1.doubleValue() * n2.doubleValue();
 		return arithmetic(lua,"__mul",o1,o2);
 	}
 }
--- a/src/luan/interp/NumericForStmt.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/NumericForStmt.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -23,12 +22,12 @@
 	}
 
 	@Override public void eval(LuaStateImpl lua) throws LuaException {
-		double v = lua.checkNumber( se, fromExpr.eval(lua) ).value();
-		double limit = lua.checkNumber( se, toExpr.eval(lua) ).value();
-		double step = lua.checkNumber( se, stepExpr.eval(lua) ).value();
+		double v = lua.checkNumber( se, fromExpr.eval(lua) ).doubleValue();
+		double limit = lua.checkNumber( se, toExpr.eval(lua) ).doubleValue();
+		double step = lua.checkNumber( se, stepExpr.eval(lua) ).doubleValue();
 		try {
 			while( step > 0.0 && v <= limit || step < 0.0 && v >= limit ) {
-				lua.stackSet( iVar, LuaNumber.of(v) );
+				lua.stackSet( iVar, v );
 				block.eval(lua);
 				v += step;
 			}
--- a/src/luan/interp/PowExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/PowExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( Math.pow( n1.value(), n2.value() ) );
+			return Math.pow( n1.doubleValue(), n2.doubleValue() );
 		return arithmetic(lua,"__pow",o1,o2);
 	}
 }
--- a/src/luan/interp/SubExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/SubExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.LuaSource;
 
@@ -15,10 +14,10 @@
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o1 = op1.eval(lua);
 		Object o2 = op2.eval(lua);
-		LuaNumber n1 = Lua.toNumber(o1);
-		LuaNumber n2 = Lua.toNumber(o2);
+		Number n1 = Lua.toNumber(o1);
+		Number n2 = Lua.toNumber(o2);
 		if( n1 != null && n2 != null )
-			return LuaNumber.of( n1.value() - n2.value() );
+			return n1.doubleValue() - n2.doubleValue();
 		return arithmetic(lua,"__sub",o1,o2);
 	}
 }
--- a/src/luan/interp/TableExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/TableExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -2,7 +2,6 @@
 
 import luan.LuaException;
 import luan.LuaTable;
-import luan.LuaNumber;
 import luan.LuaSource;
 
 
@@ -34,7 +33,7 @@
 		}
 		Object[] a = expressions.eval(lua);
 		for( int i=0; i<a.length; i++ ) {
-			table.put( LuaNumber.of(i+1), a[i] );
+			table.put( i+1, a[i] );
 		}
 		return table;
 	}
--- a/src/luan/interp/UnmExpr.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/interp/UnmExpr.java	Thu Dec 27 01:48:36 2012 +0000
@@ -1,7 +1,6 @@
 package luan.interp;
 
 import luan.Lua;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaException;
 import luan.LuaSource;
@@ -16,9 +15,9 @@
 
 	@Override public Object eval(LuaStateImpl lua) throws LuaException {
 		Object o = op.eval(lua);
-		LuaNumber n = Lua.toNumber(o);
+		Number n = Lua.toNumber(o);
 		if( n != null )
-			return LuaNumber.of( -n.value() );
+			return -n.doubleValue();
 		LuaFunction fn = lua.getHandlerFunction(se,"__unm",o);
 		if( fn != null ) {
 			return Lua.first(lua.call(fn,se,"__unm",o));
--- a/src/luan/lib/BasicLib.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/lib/BasicLib.java	Thu Dec 27 01:48:36 2012 +0000
@@ -11,7 +11,6 @@
 import luan.Lua;
 import luan.LuaState;
 import luan.LuaTable;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaJavaFunction;
 import luan.LuaException;
@@ -174,7 +173,7 @@
 		throw new LuaException( lua, LuaElement.JAVA, "bad argument #1 to 'raw_len' (table or string expected)" );
 	}
 
-	public static LuaNumber to_number(Object e,Integer base) {
+	public static Number to_number(Object e,Integer base) {
 		return Lua.toNumber(e,base);
 	}
 
--- a/src/luan/lib/JavaLib.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/lib/JavaLib.java	Thu Dec 27 01:48:36 2012 +0000
@@ -11,7 +11,7 @@
 import java.util.List;
 import java.util.ArrayList;
 import java.util.Iterator;
-import luan.LuaNumber;
+import luan.Lua;
 import luan.LuaState;
 import luan.LuaTable;
 import luan.MetatableGetter;
@@ -92,13 +92,9 @@
 			if( "length".equals(key) ) {
 				return Array.getLength(obj);
 			}
-			if( key instanceof LuaNumber ) {
-				LuaNumber n = (LuaNumber)key;
-				double d = n.value();
-				int i = (int)d;
-				if( d==i ) {
-					return Array.get(obj,i);
-				}
+			Integer i = Lua.asInteger(key);
+			if( i != null ) {
+				return Array.get(obj,i);
 			}
 			throw new LuaException(lua,LuaElement.JAVA,"invalid index for java array: "+key);
 		}
@@ -122,12 +118,7 @@
 				Member member = members.get(0);
 				if( member instanceof Field ) {
 					Field field = (Field)member;
-					Object value = field.get(obj);
-					if( value instanceof Number ) {
-						Number n = (Number)value;
-						value = LuaNumber.of(n);
-					}
-					return value;
+					return field.get(obj);
 				} else {
 					Method method = (Method)member;
 					return new LuaJavaFunction(method,obj);
--- a/src/luan/lib/StringLib.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/lib/StringLib.java	Thu Dec 27 01:48:36 2012 +0000
@@ -7,7 +7,6 @@
 import luan.LuaTable;
 import luan.LuaFunction;
 import luan.LuaJavaFunction;
-import luan.LuaNumber;
 import luan.LuaElement;
 import luan.LuaException;
 
@@ -157,7 +156,7 @@
 				i++;
 			}
 			m.appendTail(sb);
-			return new Object[]{ sb.toString(), LuaNumber.of(i) };
+			return new Object[]{ sb.toString(), i };
 		}
 		if( repl instanceof LuaTable ) {
 			LuaTable t = (LuaTable)repl;
@@ -175,7 +174,7 @@
 				i++;
 			}
 			m.appendTail(sb);
-			return new Object[]{ sb.toString(), LuaNumber.of(i) };
+			return new Object[]{ sb.toString(), i };
 		}
 		if( repl instanceof LuaFunction ) {
 			LuaFunction fn = (LuaFunction)repl;
@@ -202,7 +201,7 @@
 				i++;
 			}
 			m.appendTail(sb);
-			return new Object[]{ sb.toString(), LuaNumber.of(i) };
+			return new Object[]{ sb.toString(), i };
 		}
 		throw new LuaException( lua, LuaElement.JAVA, "bad argument #3 to 'gsub' (string/function/table expected)" );
 	}
--- a/src/luan/lib/TableLib.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/lib/TableLib.java	Thu Dec 27 01:48:36 2012 +0000
@@ -6,7 +6,6 @@
 import luan.Lua;
 import luan.LuaState;
 import luan.LuaTable;
-import luan.LuaNumber;
 import luan.LuaFunction;
 import luan.LuaJavaFunction;
 import luan.LuaElement;
@@ -41,7 +40,7 @@
 		int last = j==null ? list.length() : j;
 		StringBuilder buf = new StringBuilder();
 		for( int k=first; k<=last; k++ ) {
-			Object val = list.get(LuaNumber.of(k));
+			Object val = list.get(k);
 			if( val==null )
 				break;
 			if( sep!=null && k > first )
--- a/src/luan/tools/CmdLine.java	Thu Dec 27 00:44:58 2012 +0000
+++ b/src/luan/tools/CmdLine.java	Thu Dec 27 01:48:36 2012 +0000
@@ -10,7 +10,6 @@
 import luan.LuaState;
 import luan.LuaFunction;
 import luan.LuaTable;
-import luan.LuaNumber;
 import luan.LuaException;
 import luan.interp.LuaCompiler;
 
@@ -72,7 +71,7 @@
 			System.arraycopy(args,1,varArgs,0,varArgs.length);
 			LuaTable argsTable = new LuaTable();
 			for( int j=0; j<args.length; j++ ) {
-				argsTable.put( LuaNumber.of(j), args[j] );
+				argsTable.put( j, args[j] );
 			}
 			lua.global().put("arg",argsTable);
 			try {