Mercurial Hosting > luan
changeset 861:cdab48877cfe
minor
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Wed, 28 Sep 2016 13:50:22 -0600 (2016-09-28) |
parents | 626815a4b19b |
children | 2bb375e94f64 |
files | src/luan/LuanJavaFunction.java |
diffstat | 1 files changed, 17 insertions(+), 16 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/LuanJavaFunction.java Tue Sep 27 22:20:07 2016 -0600 +++ b/src/luan/LuanJavaFunction.java Wed Sep 28 13:50:22 2016 -0600 @@ -11,7 +11,6 @@ import java.util.Set; import java.util.Arrays; import java.util.Collection; -import luan.impl.Closure; public final class LuanJavaFunction extends LuanFunction { @@ -111,34 +110,36 @@ if( !type.isInstance(arg) ) { String expected; if( i==a.length-1 && method.isVarArgs() ) - expected = fixType(paramType.getComponentType().getSimpleName())+"..."; + expected = type(paramType.getComponentType())+"..."; else - expected = fixType(paramType.getSimpleName()); + expected = type(paramType); if( arg==null ) { if( paramType.isPrimitive() ) throw new LuanException("bad argument #"+(i+1-start)+" ("+expected+" expected, got nil)"); } else { - String got = arg instanceof Closure ? "function" : fixType(arg.getClass().getSimpleName()); + String got = type(arg.getClass()); throw new LuanException("bad argument #"+(i+1-start)+" ("+expected+" expected, got "+got+")"); } } } } - private static String fixType(String type) { - if( type.equals("byte[]") ) - return "binary"; - if( type.equals("Double") ) + private static final Class byteArray = new byte[0].getClass(); + + private static String type(Class cls) { + if( LuanFunction.class.isAssignableFrom(cls) ) + return "function"; + if( Boolean.class.isAssignableFrom(cls) ) + return "boolean"; + if( String.class.isAssignableFrom(cls) ) + return "string"; + if( Number.class.isAssignableFrom(cls) ) return "number"; - if( type.equals("LuanTable") ) + if( LuanTable.class.isAssignableFrom(cls) ) return "table"; - if( type.equals("Boolean") ) - return "boolean"; - if( type.equals("String") ) - return "string"; - if( type.equals("LuanJavaFunction") ) - return "function"; - return type; + if( byteArray.isAssignableFrom(cls) ) + return "binary"; + return cls.getName(); } private Object[] fixArgs(LuanState luan,Object[] args) throws LuanException {