Browse Source
add hoa-library-for-prism script, for directly injecting HOA automata, useful for testing
add hoa-library-for-prism script, for directly injecting HOA automata, useful for testing
git-svn-id: https://www.prismmodelchecker.org/svn/prism/prism/trunk@10267 bbc10eb1-c90d-0410-af57-cb519fbb1720master
1 changed files with 100 additions and 0 deletions
@ -0,0 +1,100 @@ |
|||||
|
#! /usr/bin/perl -w |
||||
|
|
||||
|
# For usage notes see end of file or run hoa-library-for-prism without parameters. |
||||
|
|
||||
|
use strict; |
||||
|
|
||||
|
use File::Spec; |
||||
|
use Pod::Usage; |
||||
|
|
||||
|
if (scalar @ARGV != 2) { |
||||
|
pod2usage(2); |
||||
|
} |
||||
|
|
||||
|
my $formula_file = shift; |
||||
|
my $output_file = shift; |
||||
|
|
||||
|
my $hoa_lib_dir = "hoa-lib"; |
||||
|
if (defined $ENV{HOA_LIB}) { |
||||
|
$hoa_lib_dir = $ENV{HOA_LIB}; |
||||
|
} |
||||
|
|
||||
|
if (!open(IN, "<", $formula_file)) { |
||||
|
print "Can not file '$formula_file' for reading formula: $!\n"; exit(1); |
||||
|
} |
||||
|
my $formula = <IN>; |
||||
|
if (!defined $formula) { |
||||
|
print "No formula read from file '$formula_file'\n"; exit(1); |
||||
|
} |
||||
|
while (<IN>) { |
||||
|
chomp(); # remove \n at end of line |
||||
|
next if (/^\s*$/); # ok if there is only whitespace |
||||
|
print "Garbage at end of formula file '$formula_file': $_"; exit(1); |
||||
|
} |
||||
|
|
||||
|
chomp($formula); |
||||
|
$formula =~ s/\s+/ /g; # multiple whitspace -> single space |
||||
|
$formula =~ s/^\s*//; # trim whitespace in front |
||||
|
$formula =~ s/\s*//; # trim whitespace in back |
||||
|
|
||||
|
my $filename = $formula; |
||||
|
$filename =~ s/ /_/g; # replace spaces with _ |
||||
|
$filename.='.hoa'; # append .hoa suffix |
||||
|
|
||||
|
$filename = File::Spec->catfile($hoa_lib_dir, $filename); |
||||
|
|
||||
|
if (-f $filename) { |
||||
|
if (!open(IN, "<", $filename)) { |
||||
|
print "Can not open file '$filename' for formula '$formula': $!\n"; exit(1); |
||||
|
} |
||||
|
if (!open(OUT, ">", $output_file)) { |
||||
|
print "Can not open file '$output_file' for writing the automaton: $!\n"; exit(1); |
||||
|
} |
||||
|
while (<IN>) { |
||||
|
print OUT $_; |
||||
|
} |
||||
|
close(IN); |
||||
|
close(OUT); |
||||
|
exit(0); |
||||
|
} else { |
||||
|
print "Can not find file '$filename' corresponding to formula '$formula': $!\n"; |
||||
|
exit(1); |
||||
|
} |
||||
|
|
||||
|
|
||||
|
|
||||
|
__END__ |
||||
|
|
||||
|
=head1 NAME |
||||
|
|
||||
|
hoa-library-for-prism - Script to lookup formulas from a library and return a HOA automaton |
||||
|
|
||||
|
=head1 SYNOPSIS |
||||
|
|
||||
|
hoa-library-for-prism formula-file output-file |
||||
|
|
||||
|
Reads a single-line formula from I<formula-file>, transforms the |
||||
|
formula (in LBT format) into a filename and looks for a corresponding |
||||
|
.hoa file in the I<library directory>. If this file exists, the |
||||
|
content is written to I<output-file> and the script exits with exit |
||||
|
value 0. |
||||
|
|
||||
|
By default, the I<library-directory> is I<hoa-lib>. The directory can |
||||
|
be set to a custom value by setting the environment variable HOA_LIB, |
||||
|
e.g., |
||||
|
|
||||
|
export HOA_LIB=path/to/library |
||||
|
|
||||
|
The formula is transformed to a filename as follows. First, all |
||||
|
whitespace in front and in the back is stripped and multiple |
||||
|
whitespace characters are combined to a single one. Then, all |
||||
|
whitespaces are replaced by underscore (_) characters. Finally, the |
||||
|
suffix '.hoa' is appended. As an example, the formula |
||||
|
|
||||
|
G F U p0 p1 |
||||
|
|
||||
|
is transformed to the filename |
||||
|
|
||||
|
G_F_U_p0_p1.hoa |
||||
|
|
||||
|
|
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue