| Server IP : 85.214.239.14 / Your IP : 216.73.216.178 Web Server : Apache/2.4.65 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Mon Sep 30 15:36:27 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 8.2.29 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/self/root/usr/share/doc/libparse-recdescent-perl/examples/ |
Upload File : |
#!/usr/bin/perl -sw
# PARSE LOGICAL EXPRESSIONS TO A "list of lists" PARSE TREE
sub printtree
{
print " " x $_[0];
print "$_[1]:\n";
foreach ( @_[2..$#_] )
{
if (ref($_)) { printtree($_[0]+1,@$_); }
else { print " " x $_[0], "$_\n" }
}
print "\n";
}
use Parse::RecDescent;
$RD_AUTOACTION = q{ [@item] };
$grammar =
q{
expr : disj
disj : conj 'or' disj | conj
conj : unary 'and' conj | unary
unary : 'not' atom
| '(' expr ')'
| atom
atom : /[a-z]+/i
};
$parse = new Parse::RecDescent ($grammar);
while (<DATA>)
{
my $tree = $parse->expr($_);
printtree(0,@$tree) if $tree;
}
__DATA__
a and b and not c
(c or d) and f