made app.properties-object readonly, plus formatting fixes.
This commit is contained in:
		
							parent
							
								
									e6cf8647cc
								
							
						
					
					
						commit
						1012b31a6a
					
				
					 1 changed files with 31 additions and 26 deletions
				
			
		|  | @ -2,7 +2,9 @@ package helma.scripting.fesi; | ||||||
| 
 | 
 | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| 
 | 
 | ||||||
|  | import helma.framework.core.ApplicationBean; | ||||||
| import helma.objectmodel.INode; | import helma.objectmodel.INode; | ||||||
|  | import helma.util.SystemProperties; | ||||||
| 
 | 
 | ||||||
| import FESI.Interpreter.Evaluator; | import FESI.Interpreter.Evaluator; | ||||||
| import FESI.Exceptions.EcmaScriptException; | import FESI.Exceptions.EcmaScriptException; | ||||||
|  | @ -24,16 +26,20 @@ public class ESBeanWrapper extends ESWrapper { | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
|  	* Wrap getProperty, return ESNode if INode would be returned. |  	* Wrap getProperty, return ESNode if INode would be returned, | ||||||
|  |  	* ESMapWrapper if Map would be returned. | ||||||
|  	*/ |  	*/ | ||||||
|     public ESValue getProperty(String propertyName, int hash) |     public ESValue getProperty(String propertyName, int hash) throws EcmaScriptException { | ||||||
|                                  throws EcmaScriptException { |  | ||||||
| 	try { | 	try { | ||||||
| 	    ESValue val = super.getProperty (propertyName, hash); | 	    ESValue val = super.getProperty (propertyName, hash); | ||||||
| 			if (val instanceof ESWrapper && ((ESWrapper)val).getJavaObject() instanceof INode)	{ | 	    Object theObject = ((ESWrapper)val).getJavaObject (); | ||||||
| 				return eval.getNodeWrapper( (INode) ((ESWrapper)val).getJavaObject() ); | 	    if (val instanceof ESWrapper && theObject instanceof INode)	{ | ||||||
| 			} else if (val instanceof ESWrapper && ((ESWrapper)val).getJavaObject() instanceof Map)	{ | 	        return eval.getNodeWrapper ((INode) theObject); | ||||||
| 				return new ESMapWrapper(eval, (Map) ((ESWrapper)val).getJavaObject() ); | 	    } else if (val instanceof ESWrapper && theObject instanceof Map)	{ | ||||||
|  | 	        ESMapWrapper wrapper = new ESMapWrapper(eval, (Map) theObject); | ||||||
|  | 	        if (theObject instanceof SystemProperties && super.getJavaObject () instanceof ApplicationBean) | ||||||
|  | 	            wrapper.setReadonly(true); | ||||||
|  | 	        return wrapper; | ||||||
| 	    } else { | 	    } else { | ||||||
| 	        return val; | 	        return val; | ||||||
| 	    } | 	    } | ||||||
|  | @ -42,8 +48,7 @@ public class ESBeanWrapper extends ESWrapper { | ||||||
| 	} | 	} | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void putProperty(String propertyName, ESValue propertyValue, int hash) |     public void putProperty(String propertyName, ESValue propertyValue, int hash) throws EcmaScriptException { | ||||||
|                               throws EcmaScriptException { |  | ||||||
| 	try { | 	try { | ||||||
| 	    super.putProperty (propertyName, propertyValue, hash); | 	    super.putProperty (propertyName, propertyValue, hash); | ||||||
| 	} catch (Exception rte) { | 	} catch (Exception rte) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue