# Copyright (C) 2013 Stephane Galland <galland@arakhne.org> # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; see the file COPYING. If not, write to # the Free Software Foundation, Inc., 59 Temple Place - Suite 330, # Boston, MA 02111-1307, USA. =pod =head1 NAME AutoLaTeX::Interpreter::batch - A DOS-Batch interpreter =head1 DESCRIPTION AutoLaTeX::Interpreter::batch is a Perl module, which permits to run DOS-Batch scripts. =head1 METHOD DESCRIPTIONS This section contains only the methods in batch.pm itself. =over =cut package AutoLaTeX::Interpreter::batch; @ISA = qw( AutoLaTeX::Interpreter::AbstractInterpreter ); @EXPORT = qw(); @EXPORT_OK = qw(); require 5.014; use strict; use utf8; use vars qw(@ISA @EXPORT @EXPORT_OK $VERSION); use Exporter; use Carp; use Scalar::Util qw(looks_like_number); use AutoLaTeX::Interpreter::AbstractInterpreter; use AutoLaTeX::Core::Util; #------------------------------------------------------ # # Global vars # #------------------------------------------------------ # Version number my $VERSION = "1.0" ; =pod =item * new() Constructor =cut sub new() : method { my $proto = shift; my $class = ref($proto) || $proto; my $self = bless( $class->SUPER::new(), $class); return $self; } sub _to_batch($$) { my $name = shift; my $value = shift; if (defined($value)) { if (isArray($value)) { my $array = ''; my $i=0; foreach my $v (@{$value}) { $array .= "set $name"."[$i]=\"".str2language("$v").'"'; $i++; } return $array; } elsif (isHash($value)) { die("Associative arrays are not yet supported by the Shell wrapper\n"); } elsif (looks_like_number($value)) { return "set $name=$value"; } else { return "set $name=\"".str2language("$value").'"'; } } return "unset $name"; } =pod =item * run($) Run the given code. =cut sub run($) : method { my $self = shift; my $code = shift || confess("no code"); my $fullcode = ""; while (my ($name,$value) = each(%{$self->{'global'}})) { $fullcode .= _to_batch($name,$value)."\n"; } $fullcode .= "\n\n\n$code"; runCommandOrFailFromInput($fullcode, 'bash'); } 1; __END__ =back =head1 COPYRIGHT (c) Copyright 2013 Stephane Galland E<lt>galland@arakhne.orgE<gt>, under GPL. =head1 AUTHORS =over =item * Conceived and initially developed by Stéphane Galland E<lt>galland@arakhne.orgE<gt>. =back =head1 SEE ALSO L<autolatex>