Author: markt
Date: Fri Oct  3 05:09:16 2008
New Revision: 701358

URL: http://svn.apache.org/viewvc?rev=701358&view=rev
Log:
Better fix for https://issues.apache.org/bugzilla/show_bug.cgi?id=45403
With this patch, the allowLinking flag applies to all web application 
resources. It is very slightly slower. On my machine with allowLinking=false, 
the change to line 899 increases the time from ~7 microseconds to create the 
file to ~70 microseconds to create and validate the file. As far as I can tell, 
this change is only going to affect context start times. If directory listings 
are enabled in the default servlet, they will also be slightly slower but they 
were horribly slow to start with.

Modified:
    tomcat/trunk/java/org/apache/naming/resources/FileDirContext.java

Modified: tomcat/trunk/java/org/apache/naming/resources/FileDirContext.java
URL: 
http://svn.apache.org/viewvc/tomcat/trunk/java/org/apache/naming/resources/FileDirContext.java?rev=701358&r1=701357&r2=701358&view=diff
==============================================================================
--- tomcat/trunk/java/org/apache/naming/resources/FileDirContext.java (original)
+++ tomcat/trunk/java/org/apache/naming/resources/FileDirContext.java Fri Oct  
3 05:09:16 2008
@@ -819,6 +819,15 @@
     protected File file(String name) {
 
         File file = new File(base, name);
+        return validate(file);
+
+    }
+
+
+    /*
+     * Check that the file is valid for this context
+     */
+    private File validate(File file) {
         if (file.exists() && file.canRead()) {
 
                if (allowLinking)
@@ -896,7 +905,9 @@
 
         for (int i = 0; i < names.length; i++) {
 
-            File currentFile = new File(file, names[i]);
+            File currentFile = validate(new File(file, names[i]));
+            if (currentFile == null) continue;
+            
             Object object = null;
             if (currentFile.isDirectory()) {
                 FileDirContext tempContext = new FileDirContext(env);



---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to