PK œqhYî¶J‚ßF ßF ) nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/
| Dir : /usr/share/doc/perl-Getopt-Long/examples/ |
| Server: Linux server1.ngambekcore.com 4.18.0-553.51.1.el8_10.x86_64 #1 SMP Wed Apr 30 04:00:07 EDT 2025 x86_64 IP: 159.198.77.92 |
| Dir : //usr/share/doc/perl-Getopt-Long/examples/parsetime.pl |
#!/usr/bin/perl
# This is a (working) example of how to write a helper routine for
# Getopt::Long to deal with specific cases.
#
# The basic principle is:
# - specify the option type to be string
# - specify a code reference to handle the parsing an assignment.
#
# This example parses time specifications in the form HH:MM:SS.mmm, where
# unneeded parts may be left out.
use strict;
use warnings;
use Getopt::Long;
# The helper routine. It will be called to handle the actual delivery
# of the option value.
# There are two parameters: the option name, and the value to be
# assigned.
# Note the use of 'die' to signal errors back to Getopt::Long.
sub parsetime {
my ($opt_name, $opt_value) = @_;
my $val = 0;
unless ( $opt_value =~ /
^ # beginning of value string
(?:(\d+):)? # hours
(?:(\d+):)? # minutes
(\d+(?:\.\d+)?) # seconds + fraction
$ # end of value string
/x ) {
die("Value \"$opt_value\" invalid for option $opt_name\n");
}
# Return the value.
( defined $1 ? 3600*$1 : 0) +
( defined $2 ? 60*$2 : 0) +
$3;
}
@ARGV = ("-time", "1:24.14") unless @ARGV;
my $time;
GetOptions("time=s" => sub { $time = &parsetime }) &&
print "time = $time seconds\n";