X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=src%2Fssic.pl;h=db7a39f047c033c381daa95e3fc40c7037069b94;hb=6ada252e60e6e9904764eeff808e7b0a265840ca;hp=f87aa9e5df96af57219a219e4a3a704aa5fe0781;hpb=4a6dbfd99444de6e7cb30934378294ac135d9c76;p=ssic.git diff --git a/src/ssic.pl b/src/ssic.pl index f87aa9e..db7a39f 100644 --- a/src/ssic.pl +++ b/src/ssic.pl @@ -86,16 +86,16 @@ sub version sub warning { - my ($fmt, $args) = @_; + my ($fmt, @args) = @_; - printf("ssic: Warning: " . $fmt, $args); + printf("ssic: Warning: " . $fmt, @args); } sub error { - my ($status, $fmt, $args) = @_; + my ($status, $fmt, @args) = @_; - printf("ssic: Error: " . $fmt, $args); + printf("ssic: Error: " . $fmt, @args); exit($status); } @@ -112,13 +112,23 @@ sub compile error(4, "Input and output files are equal\n"); } - open($input_fh, "<", $input); - open($output_fh, ">", $output); + if (not open($input_fh, "<", $input)) { + error(4, "%s: %s\n", $input, $!); + } + if (not open($output_fh, ">", $output)) { + error(4, "%s: %s\n", $output, $!); + } - %ENV = (); + %ENV = ( + "DOCUMENT_NAME" => $input, + "DOCUMENT_URI" => $input, + ); $CGI::SSI::DEBUG = 0; - $ssi = CGI::SSI->new(); + $ssi = CGI::SSI->new( + "DOCUMENT_NAME" => $input, + "DOCUMENT_URI" => $input, + ); while (($var_name, $var_value) = each(%{$vars})) { $ssi->set($var_name => $var_value);