Mercurial Hosting > luan
changeset 50:272b6f1d7dac
fix java accessibility
git-svn-id: https://luan-java.googlecode.com/svn/trunk@51 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Fri, 28 Dec 2012 19:48:43 +0000 (2012-12-28) |
parents | 8ede219cd111 |
children | 28dfd91a816c |
files | src/luan/lib/JavaLib.java src/luan/tools/WebShell.java |
diffstat | 2 files changed, 24 insertions(+), 19 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/lib/JavaLib.java Fri Dec 28 19:35:04 2012 +0000 +++ b/src/luan/lib/JavaLib.java Fri Dec 28 19:48:43 2012 +0000 @@ -1,6 +1,7 @@ package luan.lib; import java.lang.reflect.Array; +import java.lang.reflect.AccessibleObject; import java.lang.reflect.Member; import java.lang.reflect.Field; import java.lang.reflect.Method; @@ -79,7 +80,7 @@ } } } else { - List<Member> members = getStaticMembers(cls,name); + List<AccessibleObject> members = getStaticMembers(cls,name); if( !members.isEmpty() ) { return member(null,members); } @@ -103,7 +104,7 @@ if( "instanceof".equals(name) ) { return new LuanJavaFunction(instanceOf,new InstanceOf(obj)); } else { - List<Member> members = getMembers(cls,name); + List<AccessibleObject> members = getMembers(cls,name); if( !members.isEmpty() ) { return member(obj,members); } @@ -112,10 +113,13 @@ throw new LuanException(luan,LuanElement.JAVA,"invalid index for java object: "+key); } - private static Object member(Object obj,List<Member> members) throws LuanException { + private static Object member(Object obj,List<AccessibleObject> members) throws LuanException { try { + for( AccessibleObject m : members ) { + m.setAccessible(true); + } if( members.size()==1 ) { - Member member = members.get(0); + AccessibleObject member = members.get(0); if( member instanceof Field ) { Field field = (Field)member; return field.get(obj); @@ -125,7 +129,7 @@ } } else { List<LuanJavaFunction> fns = new ArrayList<LuanJavaFunction>(); - for( Member member : members ) { + for( AccessibleObject member : members ) { Method method = (Method)member; fns.add(new LuanJavaFunction(method,obj)); } @@ -136,26 +140,26 @@ } } - private static Map<Class,Map<String,List<Member>>> memberMap = new HashMap<Class,Map<String,List<Member>>>(); + private static Map<Class,Map<String,List<AccessibleObject>>> memberMap = new HashMap<Class,Map<String,List<AccessibleObject>>>(); - private static synchronized List<Member> getMembers(Class cls,String name) { - Map<String,List<Member>> clsMap = memberMap.get(cls); + private static synchronized List<AccessibleObject> getMembers(Class cls,String name) { + Map<String,List<AccessibleObject>> clsMap = memberMap.get(cls); if( clsMap == null ) { - clsMap = new HashMap<String,List<Member>>(); + clsMap = new HashMap<String,List<AccessibleObject>>(); for( Field field : cls.getFields() ) { String s = field.getName(); - List<Member> list = clsMap.get(s); + List<AccessibleObject> list = clsMap.get(s); if( list == null ) { - list = new ArrayList<Member>(); + list = new ArrayList<AccessibleObject>(); clsMap.put(s,list); } list.add(field); } for( Method method : cls.getMethods() ) { String s = method.getName(); - List<Member> list = clsMap.get(s); + List<AccessibleObject> list = clsMap.get(s); if( list == null ) { - list = new ArrayList<Member>(); + list = new ArrayList<AccessibleObject>(); clsMap.put(s,list); } list.add(method); @@ -165,10 +169,10 @@ return clsMap.get(name); } - private static synchronized List<Member> getStaticMembers(Class cls,String name) { - List<Member> staticMembers = new ArrayList<Member>(); - for( Member m : getMembers(cls,name) ) { - if( Modifier.isStatic(m.getModifiers()) ) + private static synchronized List<AccessibleObject> getStaticMembers(Class cls,String name) { + List<AccessibleObject> staticMembers = new ArrayList<AccessibleObject>(); + for( AccessibleObject m : getMembers(cls,name) ) { + if( Modifier.isStatic(((Member)m).getModifiers()) ) staticMembers.add(m); } return staticMembers;
--- a/src/luan/tools/WebShell.java Fri Dec 28 19:35:04 2012 +0000 +++ b/src/luan/tools/WebShell.java Fri Dec 28 19:48:43 2012 +0000 @@ -48,10 +48,10 @@ PrintWriter out = response.getWriter(); HttpSession session = request.getSession(); - ByteArrayOutputStream history = (ByteArrayOutputStream)session.getValue("history"); + ByteArrayOutputStream history = (ByteArrayOutputStream)session.getValue("luan_history"); if( history==null ) { history = new ByteArrayOutputStream(); - session.putValue("history",history); + session.putValue("luan_history",history); } if( request.getParameter("clear") != null ) { @@ -82,6 +82,7 @@ } catch(LuanException e) { logger.info("",e); writer.write( HtmlLib.encode(e.toString()) ); + writer.write("\r\n"); } writer.flush(); }