X-Git-Url: https://git.p6c8.net/devedit.git/blobdiff_plain/89269f652fc46e65006b9aead5eb1ae61ebc311e..aeaff6f362f8e376c592469db74f9da3434ecacc:/modules/Tool.pm diff --git a/modules/Tool.pm b/modules/Tool.pm index a37967e..3a43ffc 100644 --- a/modules/Tool.pm +++ b/modules/Tool.pm @@ -6,15 +6,19 @@ package Tool; # Some shared sub routines # # Author: Patrick Canterino -# Last modified: 10-03-2003 +# Last modified: 2004-07-28 # use strict; use vars qw(@EXPORT); +use CGI qw(redirect + escape + virtual_host + https); + use Cwd qw(abs_path); -use File::Basename; use File::Spec; ### Export ### @@ -23,7 +27,10 @@ use base qw(Exporter); @EXPORT = qw(check_path clean_path + devedit_reload + equal_url file_name + mode_string upper_path); # check_path() @@ -54,17 +61,11 @@ sub check_path($$) # The path points to a file # We have to extract the directory name and create the absolute path - my @pathinfo = fileparse($path); - - # This is only to avoid errors - - my $basename = $pathinfo[0] || ''; - my $dir = $pathinfo[1] || ''; - my $ext = $pathinfo[2] || ''; + my $dir = upper_path($path); + my $file = file_name($path); - $dir = abs_path($dir); - - $path = $dir."/".$basename.$ext; + $dir = abs_path($dir); + $path = $dir."/".$file; } else { @@ -81,7 +82,7 @@ sub check_path($$) my $short_path = substr($path,length($root)); $short_path =~ tr!\\!\/!; - $short_path = "/".$short_path unless($short_path =~ m!^/!); + $short_path = "/".$short_path if($short_path !~ m!^/!); $short_path = $short_path."/" if($short_path !~ m!/$! && -d $path); return ($path,$short_path); @@ -105,9 +106,83 @@ sub clean_path($) return $path; } +# devedit_reload() +# +# Create a HTTP redirection header to load Dev-Editor +# with some other parameters +# +# Params: Hash Reference (will be merged to a query string) +# +# Return: HTTP redirection header (Scalar Reference) + +sub devedit_reload($) +{ + my $params = shift; + + # Detect the protocol (simple HTTP or SSL encrypted HTTP) + # and check if the server listens on the default port + + my $protocol = ""; + my $port = ""; + + if(https) + { + # SSL encrypted HTTP (HTTPS) + + $protocol = "https"; + $port = ":".$ENV{'SERVER_PORT'} if($ENV{'SERVER_PORT'} != 443); + } + else + { + # Simple HTTP + + $protocol = "http"; + $port = ":".$ENV{'SERVER_PORT'} if($ENV{'SERVER_PORT'} != 80); + } + + # The following code is grabbed from Template::_query of + # Andre Malo's selfforum (http://sourceforge.net/projects/selfforum/) + # and modified by Patrick Canterino + + my $query = '?'.join ('&' => + map { + (ref) + ? map{escape ($_).'='.escape ($params -> {$_})} @{$params -> {$_}} + : escape ($_).'='.escape ($params -> {$_}) + } keys %$params + ); + + # Create the redirection header + + my $header = redirect($protocol."://".virtual_host.$port.$ENV{'SCRIPT_NAME'}.$query); + + return \$header; +} + +# equal_url() +# +# Create URL equal to a file or directory +# +# Params: 1. HTTP root +# 2. Relative path +# +# Return: Formatted link (String) + +sub equal_url($$) +{ + my ($root,$path) = @_; + my $url; + + $root =~ s!/$!!; + $path =~ s!^/!!; + $url = $root."/".$path; + + return $url; +} + # file_name() # -# Returns the last path of a filename +# Return the last part of a path # # Params: Path # @@ -127,14 +202,51 @@ sub file_name($) return $path; } -# upper_path() +# mode_string() +# +# Convert a binary file mode string into a human +# readable string (rwxr-x-r-x) +# +# Params: Binary file mode string # -# Truncate a path in one of the following ways: +# Return: Humand readable mode string + +sub mode_string($) +{ + my $mode = shift; + + my $string = ""; + + # Owner + $string .= (($mode & 0x0100) ? 'r' : '-') . + (($mode & 0x0080) ? 'w' : '-') . + (($mode & 0x0040) ? + (($mode & 0x0800) ? 's' : 'x' ) : + (($mode & 0x0800) ? 'S' : '-') + ); + + # Group + $string .= (($mode & 0x0020) ? 'r' : '-') . + (($mode & 0x0010) ? 'w' : '-') . + (($mode & 0x0008) ? + (($mode & 0x0400) ? 's' : 'x') : + (($mode & 0x0400) ? 'S' : '-') + ); + + # World + $string .= (($mode & 0x0004) ? 'r' : '-') . + (($mode & 0x0002) ? 'w' : '-') . + (($mode & 0x0001) ? + (($mode & 0x0200) ? 't' : 'x' ) : + (($mode & 0x0200) ? 'T' : '-') + ); + + return $string; +} + +# upper_path() # -# - If the path points to a directory, the upper directory -# will be returned. -# - If the path points to a file, the directory containing -# the file will be returned. +# Cut away the last part of a path # # Params: Path # @@ -148,8 +260,7 @@ sub upper_path($) unless($path eq "/") { $path = substr($path,0,-1) if($path =~ m!/$!); - $path = substr($path,0,rindex($path,"/")); - $path = $path."/"; + $path = substr($path,0,rindex($path,"/")+1); } return $path;