Apache-ASP
view release on metacpan or search on metacpan
lib/Apache/ASP/Error.pm view on Meta::CPAN
}
}
my $out = <<OUT;
<tt>
<b><u>Errors Output</u></b>
<ol>
$errors_out
</ol>
<b><u>Debug Output</u></b>
<ol>
@{[join("\n<li> ", '', map { $_ } @{$self->{debugs_output}}) ]}
</ol>
</tt>
<pre>
OUT
;
# could be looking at a compilation error, then set the script to what
# we were compiling (maybe global.asa), else its our real script
# with probably a runtime error
my $script;
if($self->{compile_error}) {
$script = ${$self->{compile_eval}};
}
if($$response_buffer) {
my $length = &config($self, 'DebugBufferLength') || 100;
$out .= "<b><u>Last $length Bytes of Buffered Output</u></b>\n\n";
$out .= $self->Escape(substr($$response_buffer, -1 * $length));
$out .= "\n\n";
}
my $error_desc;
if($script) {
$error_desc = "Compiled Data with Error";
} else {
$error_desc = "ASP to Perl Script";
my $run_perl_script = $self->{run_perl_script};
$script = $run_perl_script ? $$run_perl_script : '';
}
$out .= "<b><u>$error_desc</u></b><a name=1> </a>\n\n";
my($file_context, $lineno) = ('', 0);
for(split(/\n/, $script)) {
my($lineprint, $lineurl,$frag);
if ($_ =~ /^#\s*line (\d+) (.+)$/){
$lineno = $1;
$file_context = $2;
$lineurl = ' -';
} elsif (($lineno == 0)) {
$lineurl = ' -';
} else {
$frag = $self->{Server}->URLEncode($file_context.' '.$lineno);
$lineurl = "<a name=$frag>".sprintf('%3d', $lineno)."</a>";
$lineno++;
}
$frag ||= '';
grep($frag eq $_, @eval_error_lines) &&
($lineurl = "<b><font color=red>$lineurl</font></b>");
unless(&config($self, 'CommandLine')) {
$_ = $self->Escape($_);
}
$out .= "$lineurl: $_\n";
}
$out .= <<OUT;
</pre>
<hr width=30% size=1>\n<font size=-1>
<i>
An error has occured with the Apache::ASP script just run.
If you are the developer working on this script, and cannot work
through this problem, please try researching it at the
<a href=http://www.apache-asp.org/>Apache::ASP web site</a>,
specifically the <a href=http://www.apache-asp.org/faq.html>FAQ section</a>.
Failing that, check out your
<a href=http://www.apache-asp.org/support.html>support options</a>, and
if necessary include this debug output with any query.
OUT
;
$out;
}
sub MailErrors {
my $self = shift;
# email during register cleanup so the user doesn't have
# to wait, and possible cancel the mail by pressing "STOP"
$self->Log("registering error mail to $self->{mail_errors_to} for cleanup phase");
my $body_ref;
eval {
# there was a "use strict" + warn error while compiling this template
local $^W = 0;
$body_ref = $self->Response->TrapInclude('Share::CORE/MailErrors.inc',
COMPILE_ERROR => $self->PrettyErrorHelper
);
};
if($@) {
$self->Error("error creating error mail in MailErrors(): $@");
return;
}
my($subject,$body);
if($$body_ref =~ /^\s+Subject:\s*(.*?)\s*\n\s*(.*)$/is) {
($subject,$body) = ($1,$2);
} else {
($subject,$body) = ('Apache::ASP::Error', $$body_ref);
}
$self->{Server}->RegisterCleanup
(
sub {
for(1..3) {
my $success =
$self->SendMail
({
To => $self->{mail_errors_to},
From => &config($self, 'MailFrom') || $self->{mail_errors_to},
Subject => $subject,
Body => $body,
'Content-Type' => 'text/html',
});
if($success) {
last;
} else {
$self->Error("can't send errors mail to $self->{mail_errors_to}");
}
( run in 1.021 second using v1.01-cache-2.11-cpan-ceb78f64989 )