X-Git-Url: https://git.p6c8.net/selfforum.git/blobdiff_plain/489e7846289d4fb66eb4b9fab0fed4af719b98ee..7cfc9e17caf89a9b009e8fa2c65351255687706e:/selfforum-cgi/shared/Template.pm?ds=sidebyside diff --git a/selfforum-cgi/shared/Template.pm b/selfforum-cgi/shared/Template.pm index 44da2cc..5dc6322 100644 --- a/selfforum-cgi/shared/Template.pm +++ b/selfforum-cgi/shared/Template.pm @@ -4,16 +4,19 @@ package Template; # # # File: shared/Template.pm # # # -# Authors: André Malo , 2001-04-12 # +# Authors: André Malo # +# Frank Schönmann # # # # Description: Handle XML based HTML-Templates # # # ################################################################################ use strict; -use vars qw($xml_dom_used); +use vars qw( + $xml_dom_used +); -use Carp qw(croak confess); +use Carp qw(croak); BEGIN { $xml_dom_used = eval q[ @@ -23,7 +26,18 @@ BEGIN { ]; } -### sub new #################################################################### +################################################################################ +# +# Version check +# +# last modified: +# $Date$ (GMT) +# by $Author$ +# +sub VERSION {(q$Revision$ =~ /([\d.]+)\s*$/)[0] or '0.0'} + + +### new () ##################################################################### # # constructor # @@ -42,7 +56,7 @@ sub new { $self; } -### sub file ################################################################### +### file () #################################################################### # # assign new template file to object # parse the template file @@ -63,7 +77,7 @@ sub file { $old; } -### sub insert ################################################################# +### insert () ################################################################## # # return the placeholder surrounded by meta delimiters # @@ -82,7 +96,7 @@ sub insert { $self -> {metaon} . $name . $self -> {metaoff}; } -### sub list ################################################################### +### list () #################################################################### # # fill in a complete list # @@ -93,23 +107,43 @@ sub insert { # sub list { my $self = shift; - my $name = shift; croak "no template file specified" unless (defined $self -> {file}); -# no warnings 'uninitialized'; - my $list = join '' => map { ${ $self -> scrap ($name, $_) } } @{ +shift }; + $self -> joinlist ('' => @_); +} + +### joinlist () ################################################################ +# +# fill in a complete list, using a scrap between the list elements +# +# Params: $join - joining string (or stringref) +# $name - name of the atomic list scrap +# $array - list of hashes (same strcuture like the hash used by 'scrap') +# +# Return: scalar reference - filled in list +# +sub joinlist { + my $self = shift; + my $join = shift; + $join = $$join if ref($join); + my $name = shift; + + my $list = join $join => map { ${ $self -> scrap ($name, $_) } } @{ +shift }; # return \$list; } -### sub scrap ################################################################## +### scrap () ################################################################### # # fill in a template scrap # -# Params: $name - name of the scrap +# Params: $name name of the scrap +# ... +# $no_nl 1 - remove newlines (\n) +# 0 - do no such thing # # Return: scalar reference - filled in scrap # @@ -117,6 +151,11 @@ sub scrap { my $self = shift; my $name = shift; + my $no_nl; + if (!ref $_[$#_]) { + $no_nl = pop @_; + } + croak "no template file specified" unless (defined $self -> {file}); @@ -168,11 +207,51 @@ sub scrap { \%params ); + # remove newlines + # + $scrap =~ s/\015\012|\015|\012//g if ($no_nl); + # return \$scrap; } -### sub parse_file ############################################################# +### printscrap () ############################################################## +# +# fill in a template scrap and print to STDOUT +# +# Params: $name name of the scrap +# ... +# $no_nl 1 - remove newlines (\n) +# 0 - do no such thing +# +# Return: success code (boolean) +# +sub printscrap { + my $self = shift; + + $self -> scrap2file (\*STDOUT, @_); +} + +### scrap2file () ############################################################## +# +# fill in a template scrap and print to a file handle +# +# Params: $handle filehandle +# $name name of the scrap +# ... +# $no_nl 1 - remove newlines (\n) +# 0 - do no such thing +# +# Return: success code (boolean) +# +sub scrap2file { + my $self = shift; + my $handle = shift; + + print $handle ${$self->scrap(@_)}; +} + +### parse_file () ############################################################## # # read in and parse template file # @@ -272,7 +351,7 @@ sub parse_file { return; # anything failed (??) } -### sub parse_if ############################################################### +### parse_if () ################################################################ # # parse conditional blocks # @@ -333,7 +412,7 @@ sub parse_if { return; } -# keeping 'require' happy +# keep 'require' happy 1; #