]> git.p6c8.net - devedit.git/commitdiff
Let's hope, check_path() is now working properly.
authorpcanterino <>
Fri, 7 Jan 2005 11:10:45 +0000 (11:10 +0000)
committerpcanterino <>
Fri, 7 Jan 2005 11:10:45 +0000 (11:10 +0000)
Maybe we should switch to Win32::GetFullPathName() on Windows...

modules/Tool.pm

index dc1157159e51b19cf193974f5ed89afd8c69ff58..0b1159d5b1386e5cb990ded06bc9369bb9eeb9ce 100644 (file)
@@ -6,7 +6,7 @@ package Tool;
 # Some shared sub routines
 #
 # Author:        Patrick Canterino <patrick@patshaping.de>
 # Some shared sub routines
 #
 # Author:        Patrick Canterino <patrick@patshaping.de>
-# Last modified: 2005-01-06
+# Last modified: 2005-01-07
 #
 
 use strict;
 #
 
 use strict;
@@ -61,9 +61,32 @@ sub check_path($$)
  # We extract the last part of the path and create the absolute path
 
  my $first = upper_path($path);
  # We extract the last part of the path and create the absolute path
 
  my $first = upper_path($path);
+ $first    = abs_path($first);
+
  my $last  = file_name($path);
  my $last  = file_name($path);
+ $last     = '' if($last eq '.');
+
+ if($last eq '..')
+ {
+  $first = upper_path($first);
+  $last  = '';
+ }
+ elsif($^O eq 'MSWin32' && $last =~ m!^\.\.\.+$!)
+ {
+  # Windows allows to go upwards in a path using things like
+  # "..." and "...." and so on
+
+  for(my $x=0;$x<length($last)-1;$x++)
+  {
+   unless($first =~ m!^[a-z]{1}:(/|\\)$!i)
+   {
+    $first = upper_path($first);
+   }
+  }
+
+  $last = '';
+ }
 
 
- $first = abs_path($first);
  $path  = $first.'/'.$last;
 
  $first = File::Spec->canonpath($first);
  $path  = $first.'/'.$last;
 
  $first = File::Spec->canonpath($first);
@@ -72,7 +95,6 @@ sub check_path($$)
  # Check if the path is above the root directory
 
  return if(index($path,$root) != 0);
  # Check if the path is above the root directory
 
  return if(index($path,$root) != 0);
- return if($first eq $root && ($last eq '..' || ($^O eq 'MSWin32' && $last =~ m!^\.\.+$!)));
 
  # Create short path name
 
 
  # Create short path name
 

patrick-canterino.de