 
 
 
 
 
 
 
 
 
 










 
PL::Tutu
con las funciones de compilación y los correspondientes
guiones de compilación.
Mejore el script tutu para que acepte opciones desde la línea de comandos.
Debera soportar al menos las siguientes opciones:
--usage 
Muestra de forma concisa el comando de uso
--help 
Un resumen de cada opción disponible
--version
Muestra la versión del programa
--man 
Muestra la documentación
Use para ello el módulo  Getopt::Long .
Este módulo provee la función  GetOptions  la cual
se atiene a los estándares de especificación
de opciones en la línea de comandos POSIX y GNU.
Esta función soporta el uso del guión doble --
y el simple así como admitir el prefijo mas corto
que deshace la ambiguedad entre las diferentes opciones.
La llamada a 
 GetOptions  analiza la línea de comandos en
ARGV
inicializa la variable asociada de manera adecuada. Retorna un valor verdadero
si la línea de comandos pudo ser procesada con
En caso contrario emitirá
un mensaje de error y devolverá falso. Recuerde hacer
perldoc Getopt::Long
para obtener información mas detallada
El siguiente ejemplo ilustra el uso de Getopt::Long.
Se hace uso también del módulo (función  pod2usage  en la línea 63)
Pod::Usage el cual permite la documentación empotrada.
nereida:~/LEyapp/examples> cat -n treereg
 1  #!/usr/bin/perl -w
 2  use strict;
 3  use Parse::Eyapp::YATW;
 4  use Parse::Eyapp::Node;
 5  use Parse::Eyapp::Treeregexp;
 6  use Carp;
 7  use Getopt::Long;
 8  use Pod::Usage;
 9
10  my $infile;
11  my $outfile;
12  my $packagename;
13  my $prefix = '';
14  my $syntax = 1;
15  my $numbers = 1;
16  my $severity = 0; # 0 = Don't  check arity. 1 = Check arity. 
17                    # 2 = Check arity and give a warning 3 = ... and croak
18  GetOptions(
19    'in=s'       => \$infile,
20    'out=s'      => \$outfile,
21    'mod=s'      => \$packagename,
22    'prefix=s'   => \$prefix,
23    'severity=i' => \$severity,
24    'syntax!'    => \$syntax,
25    'numbers!'   => \$numbers,
26    'version'    => \&version,
27    'usage'      => \&usage,
28    'help'       => \&man,
29  ) or croak usage();
30
31  # If an argument remains is the inputfile 
32  ($infile) = @ARGV unless defined($infile);
33  die usage() unless defined($infile);
34
35  my $treeparser = Parse::Eyapp::Treeregexp->new(
36                      INFILE   => $infile,
37                      OUTFILE  => $outfile,
38                      PACKAGE  => $packagename,
39                      PREFIX   => $prefix,
40                      SYNTAX   => $syntax,
41                      NUMBERS  => $numbers,
42                      SEVERITY => $severity
43                    );
44
45  $treeparser->generate();
46
47  sub version {
48    print "Version $Parse::Eyapp::Treeregexp::VERSION\n";
49    exit;
50  }
51
52  sub usage {
53    print <<"END_ERR";
54  Supply the name of a file containing a tree grammar (.trg)
55  Usage is:
56  treereg [-m packagename] [[no]syntax] [[no]numbers] [-severity 0|1|2|3] \
57          [-p treeprefix] [-o outputfile] -i filename[.trg]
58  END_ERR
59    exit;
60  }
61
62  sub man {
63    pod2usage(
64      -exitval => 1,
65      -verbose => 2
66    );
67  }
68  __END__
69
70  =head1 SYNOPSIS
71
72    treereg [-m packagename] [[no]syntax] [[no]numbers] [-severity 0|1|2|3] \
73            [-p treeprefix] [-o outputfile] -i filename[.trg]
74    treereg [-m packagename] [[no]syntax] [[no]numbers] [-severity 0|1|2|3] \
75            [-p treeprefix] [-o outputfile] filename[.trg]
76 ... # Follows the documentation bla, bla, bla
Ahora podemos ejecutar el guión de múltiples formas:
nereida:~/LEyapp/examples> treereg -nos -nonu -se 3 -m Tutu Foldonly1.trg nereida:~/LEyapp/examples> treereg -nos -nonu -s 3 -m Tutu Foldonly1.trg Option s is ambiguous (severity, syntax) nereida:~/LEyapp/examples> treereg -nos -bla -nonu -m Tutu Foldonly1.trg Unknown option: bla nereida:~/LEyapp/examples>
La librería estandar de Perl incluye el módulo Getopt::Long. 
No es el caso de Pod::Usage. Descarge el módulo e instalelo
en un directorio local en el que tenga permisos. Si es preciso repase las secciones
![[*]](crossref.png) [4] y
 [4] y 
![[*]](crossref.png) [4]  de los apuntes de 
introducción a Perl.
 [4]  de los apuntes de 
introducción a Perl.
 
 
 
 
 
 
 
 
 
 










