]> git.p6c8.net - devedit.git/blobdiff - modules/Output.pm
Now, all the error messages are defined in the configuration file.
[devedit.git] / modules / Output.pm
index 6e48bf30a448b62bce23af03964060fc6e9c98a7..22d4e3c94bf31d35b8003927266f2c56a2137c2a 100644 (file)
@@ -6,7 +6,7 @@ package Output;
 # HTML generating routines
 #
 # Author:        Patrick Canterino <patshaping@gmx.net>
 # HTML generating routines
 #
 # Author:        Patrick Canterino <patshaping@gmx.net>
-# Last modified: 2003-12-13
+# Last modified: 2004-03-04
 #
 
 use strict;
 #
 
 use strict;
@@ -14,65 +14,32 @@ use strict;
 use vars qw(@EXPORT);
 
 use CGI qw(header);
 use vars qw(@EXPORT);
 
 use CGI qw(header);
-use HTML::Entities;
 use Tool;
 
 use Tool;
 
+use HTML::Entities;
+use Template;
+
 ### Export ###
 
 use base qw(Exporter);
 
 ### Export ###
 
 use base qw(Exporter);
 
-@EXPORT = qw(htmlhead
-             htmlfoot
+@EXPORT = qw(error_template
              error
              abort
              error
              abort
-             error_in_use
-             equal_url
-             dir_link);
-
-# htmlhead()
-#
-# Generate the head of a HTML document
-# (a text/html HTTP header will also be created)
-#
-# Params: Title/heading
-#
-# Return: Head for the HTML document
-
-sub htmlhead($)
-{
- my $title = shift;
-
- my $html = header(-type => "text/html");
-
- $html .= <<END;
-<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
-"http://www.w3.org/TR/html4/loose.dtd">
-
-<html>
-<head>
-<title>$title</title>
-<meta http-equiv="content-type" content="text/html; charset=iso-8859-1">
-</head>
-<body bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
+             error_in_use);
 
 
-<h1>$title</h1>
+my $tpl_error;
 
 
-END
-
- return $html;
-}
-
-# htmlfoot()
+# error_template()
 #
 #
-# Generate the foot of a HTML document
+# Set the path to the template file used for error messages
+# (I'm lazy...)
 #
 #
-# Params: -nothing-
-#
-# Return: Foot for the HTML document
+# Params: Template file
 
 
-sub htmlfoot
+sub error_template($)
 {
 {
return "\n</body>\n</html>";
$tpl_error = shift;
 }
 
 # error()
 }
 
 # error()
@@ -81,25 +48,33 @@ sub htmlfoot
 #
 # Params: 1. Error message
 #         2. Virtual path to which a link should be displayed (optional)
 #
 # Params: 1. Error message
 #         2. Virtual path to which a link should be displayed (optional)
+#         3. Hash reference: Template variables (optional)
 #
 # Return: Formatted message (Scalar Reference)
 
 #
 # Return: Formatted message (Scalar Reference)
 
-sub error($;$)
+sub error($;$$)
 {
 {
- my ($message,$path) = @_;
+ my ($message,$path,$vars) = @_;
 
 
- my $output = htmlhead("Error");
- $output   .= "<p>$message</p>";
+ my $tpl = new Template;
+ $tpl->read_file($tpl_error);
 
 
- if($path)
- {
-  $path = encode_entities($path);
+ $tpl->fillin("ERROR",$message);
+ $tpl->fillin("DIR",$path);
+ $tpl->fillin("SCRIPT",encode_entities($ENV{'SCRIPT_NAME'}));
+
+ $tpl->parse_if_block("dir",defined $path);
 
 
-  $output .= "\n\n";
-  $output .= "<p><a href=\"$ENV{'SCRIPT_NAME'}?command=show&file=$path\">Back to $path</a></p>";
+ if(ref($vars) eq "HASH")
+ {
+  while(my ($key,$value) = each(%$vars))
+  {
+   $tpl->fillin($key,$value);
+  }
  }
 
  }
 
- $output .= htmlfoot;
+ my $output = header(-type => "text/html");
+ $output   .= $tpl->get_template;
 
  return \$output;
 }
 
  return \$output;
 }
@@ -109,69 +84,16 @@ sub error($;$)
 # Print an error message and exit script
 # ^^^^^
 #
 # Print an error message and exit script
 # ^^^^^
 #
-# Params: Error message
+# Params: 1. Error message
+#         2. Hash reference: Template variables (optional)
 
 
-sub abort($)
+sub abort($;$)
 {
 {
- my $output = error(shift);
+ my $output = error(shift,undef,shift);
  print $$output;
  exit;
 }
 
  print $$output;
  exit;
 }
 
-# error_in_use()
-#
-# Create a message, which shows, that a
-# file is currently in use
-#
-# Params: File, which is in use
-#
-# Return: Formatted message (Scalar Reference)
-
-sub error_in_use($)
-{
- my $file = shift;
-
- return error("The file '".encode_entities($file)."' is currently edited by someone else.",upper_path($file));
-}
-
-# equal_url()
-#
-# Create an "equals"-link
-#
-# 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;
- $url  =  encode_entities($url);
-
- return "<p>(equals <a href=\"$url\" target=\"_blank\">$url</a>)</p>\n\n";
-}
-
-# dir_link()
-#
-# Create the link to the directory of a file
-#
-# Params: File
-#
-# Return: Formatted link (String)
-
-sub dir_link($)
-{
- my $dir = upper_path(shift);
- $dir    = encode_entities($dir);
-
- return "<p><a href=\"$ENV{'SCRIPT_NAME'}?command=show&file=$dir\">Back to $dir</a></p>\n\n";
-}
-
 # it's true, baby ;-)
 
 1;
 # it's true, baby ;-)
 
 1;

patrick-canterino.de