From b328697d6cc1b17e86d7f66267b2eda69be318a5 Mon Sep 17 00:00:00 2001
From: Andreas Gohr <andi@splitbrain.org>
Date: Sat, 13 Dec 2008 09:33:55 +0100
Subject: [PATCH] don't check for file existance in fullpath() by default

In most (all) calls to fullpath() the existance of the resulting path is not
important or is checked externally, so checking inside fullpath() is a waste
of CPU cycles.

darcs-hash:20081213083355-7ad00-4987a85950a13e5d3c527b3b17b1092e0fa1c567.gz
---
 inc/init.php | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/inc/init.php b/inc/init.php
index 8d094ef66..b70dbabe9 100644
--- a/inc/init.php
+++ b/inc/init.php
@@ -464,7 +464,7 @@ EOT;
  * @author <richpageau at yahoo dot co dot uk>
  * @link   http://de3.php.net/manual/en/function.realpath.php#75992
  */
-function fullpath($path){
+function fullpath($path,$exists=false){
     static $run = 0; 
     $root  = '';
     $iswin = (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN' || $GLOBALS['DOKU_UNITTEST_ASSUME_WINDOWS']);
@@ -490,7 +490,7 @@ function fullpath($path){
         $path = $base.'/'.$path;
         if($run == 0){ // avoid endless recursion when base isn't absolute for some reason
             $run++;
-            return fullpath($path,1);
+            return fullpath($path,$exists);
         }
     }
     $run = 0;
@@ -508,8 +508,8 @@ function fullpath($path){
     }
     $finalpath = $root.implode('/', $newpath);
 
-    // check for existance (except when unit testing)
-    if(!defined('DOKU_UNITTEST') && !@file_exists($finalpath)) {
+    // check for existance when needed (except when unit testing)
+    if($exists && !defined('DOKU_UNITTEST') && !@file_exists($finalpath)) {
         return false;
     }
     return $finalpath;
-- 
GitLab