* Null out scriptingEngine if initScriptingEngine() fails.
* Make sure we cause no uncaught exceptions in request evaluator loop, will cause helma to hang. * Make initScriptingEngine() synchronized.
This commit is contained in:
		
							parent
							
								
									4f7765259a
								
							
						
					
					
						commit
						2ec32f146a
					
				
					 1 changed files with 5 additions and 3 deletions
				
			
		|  | @ -85,7 +85,7 @@ public final class RequestEvaluator implements Runnable { | ||||||
|         this.app = app; |         this.app = app; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     protected void initScriptingEngine() { |     protected synchronized void initScriptingEngine() { | ||||||
|         if (scriptingEngine == null) { |         if (scriptingEngine == null) { | ||||||
|             String engineClassName = app.getProperty("scriptingEngine", |             String engineClassName = app.getProperty("scriptingEngine", | ||||||
|                                                      "helma.scripting.rhino.RhinoEngine"); |                                                      "helma.scripting.rhino.RhinoEngine"); | ||||||
|  | @ -108,6 +108,8 @@ public final class RequestEvaluator implements Runnable { | ||||||
|                 app.logEvent("******************************************"); |                 app.logEvent("******************************************"); | ||||||
|                 app.logError("Error creating scripting engine", t); |                 app.logError("Error creating scripting engine", t); | ||||||
| 
 | 
 | ||||||
|  |                 // null out invalid scriptingEngine | ||||||
|  |                 scriptingEngine = null; | ||||||
|                 // rethrow exception |                 // rethrow exception | ||||||
|                 if (t instanceof RuntimeException) { |                 if (t instanceof RuntimeException) { | ||||||
|                     throw((RuntimeException) t); |                     throw((RuntimeException) t); | ||||||
|  | @ -566,12 +568,12 @@ public final class RequestEvaluator implements Runnable { | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 // exit execution context |                 // exit execution context | ||||||
|                 scriptingEngine.exitContext(); |                 if (scriptingEngine != null) | ||||||
|  |                     scriptingEngine.exitContext(); | ||||||
| 
 | 
 | ||||||
|                 notifyAndWait(); |                 notifyAndWait(); | ||||||
| 
 | 
 | ||||||
|             } |             } | ||||||
| 
 |  | ||||||
|         } finally { |         } finally { | ||||||
|             localrtx.closeConnections(); |             localrtx.closeConnections(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue