mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-11 12:32:37 +01:00
CGrammar: Improve "is true" placement
This commit is contained in:
parent
84ee56a15e
commit
9abf8b6e44
@ -13,7 +13,7 @@ use warnings;
|
|||||||
# These are set automatically by the build/commit script
|
# These are set automatically by the build/commit script
|
||||||
use constant {
|
use constant {
|
||||||
BUILD_NAME => "PBot",
|
BUILD_NAME => "PBot",
|
||||||
BUILD_REVISION => 672,
|
BUILD_REVISION => 673,
|
||||||
BUILD_DATE => "2014-06-23",
|
BUILD_DATE => "2014-06-23",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -220,16 +220,16 @@ iteration_statement:
|
|||||||
statement[context => 'for loop']
|
statement[context => 'for loop']
|
||||||
{
|
{
|
||||||
my $initialization = join('', @{$item{'for_initialization(?)'}});
|
my $initialization = join('', @{$item{'for_initialization(?)'}});
|
||||||
my $item_expression = join('',@{$item{'for_expression(?)'}});
|
my $expression = join('',@{$item{'for_expression(?)'}});
|
||||||
my $increment = join('',@{$item{'for_increment(?)'}});
|
my $increment = join('',@{$item{'for_increment(?)'}});
|
||||||
|
|
||||||
if ($initialization) {
|
if ($initialization) {
|
||||||
$return .= "Prepare a loop by ^L$initialization, then ^L";
|
$return .= "Prepare a loop by ^L$initialization, then ^L";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($item_expression) {
|
if ($expression) {
|
||||||
my $istrue = $item{expression} =~ /(greater|less|equal|false$)/ ? '' : ' is true';
|
my $expression = ::istrue $expression;
|
||||||
$return .= "For as long as ^L$item_expression$istrue, ^L";
|
$return .= "For as long as ^L$expression, ^L";
|
||||||
} else {
|
} else {
|
||||||
$return .= "Repeatedly ^L";
|
$return .= "Repeatedly ^L";
|
||||||
}
|
}
|
||||||
@ -250,8 +250,8 @@ iteration_statement:
|
|||||||
$return = "Repeatedly ^L";
|
$return = "Repeatedly ^L";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
my $istrue = $item{expression} =~ /(greater|less|equal|false$)/ ? '' : ' is true';
|
my $expression = ::istrue $item{expression};
|
||||||
$return = "While ^L$item{expression}$istrue, ^L";
|
$return = "While ^L$expression, ^L";
|
||||||
}
|
}
|
||||||
|
|
||||||
if($item{statement}) {
|
if($item{statement}) {
|
||||||
@ -271,8 +271,8 @@ iteration_statement:
|
|||||||
$return .= "Do this repeatedly.\n";
|
$return .= "Do this repeatedly.\n";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
my $istrue = $item{expression} =~ /(greater|less|equal|false$)/ ? '' : ' is true';
|
my $expression = ::istrue $item{expression};
|
||||||
$return .= "Do this as long as ^L$item{expression}$istrue.\n";
|
$return .= "Do this as long as ^L$expression.\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -295,8 +295,8 @@ selection_statement:
|
|||||||
$return = "Always ";
|
$return = "Always ";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
my $istrue = $item{expression} =~ /(greater|less|equal|false$)/ ? '' : ' is true';
|
my $expression = ::istrue $item{expression};
|
||||||
$return = "If ^L$item{expression}$istrue then ";
|
$return = "If ^L$expression then ";
|
||||||
}
|
}
|
||||||
$return .= "^L$item{statement}";
|
$return .= "^L$item{statement}";
|
||||||
}
|
}
|
||||||
@ -324,10 +324,10 @@ jump_statement:
|
|||||||
{ $return = "Return to the top of the current loop.\n"; }
|
{ $return = "Return to the top of the current loop.\n"; }
|
||||||
| 'return' <commit> expression[context => 'statement'](?) ';'
|
| 'return' <commit> expression[context => 'statement'](?) ';'
|
||||||
{
|
{
|
||||||
my $item_expression = join('', @{$item{'expression(?)'}});
|
my $expression = join('', @{$item{'expression(?)'}});
|
||||||
|
|
||||||
if (length $item_expression) {
|
if (length $expression) {
|
||||||
$return = "Return ^L$item_expression.\n";
|
$return = "Return ^L$expression.\n";
|
||||||
} else {
|
} else {
|
||||||
$return = "Return no value.\n";
|
$return = "Return no value.\n";
|
||||||
}
|
}
|
||||||
@ -341,15 +341,15 @@ jump_statement:
|
|||||||
expression_statement:
|
expression_statement:
|
||||||
expression[context => 'statement'](?) ';'
|
expression[context => 'statement'](?) ';'
|
||||||
{
|
{
|
||||||
my $item_expression = join('',@{$item[1]});
|
my $expression = join('',@{$item[1]});
|
||||||
if (!$item_expression) {
|
if (!$expression) {
|
||||||
if($arg{context} eq 'label') {
|
if($arg{context} eq 'label') {
|
||||||
return "";
|
return "";
|
||||||
} else {
|
} else {
|
||||||
$return = "Do nothing.\n";
|
$return = "Do nothing.\n";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$return = $item_expression.".\n" ;
|
$return = $expression.".\n" ;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -391,8 +391,8 @@ conditional_expression:
|
|||||||
if($item{conditional_ternary_expression}) {
|
if($item{conditional_ternary_expression}) {
|
||||||
my $op1 = $item{conditional_ternary_expression}->[0];
|
my $op1 = $item{conditional_ternary_expression}->[0];
|
||||||
my $op2 = $item{conditional_ternary_expression}->[1];
|
my $op2 = $item{conditional_ternary_expression}->[1];
|
||||||
my $istrue = $item{logical_OR_AND_expression} =~ /(greater|less|equal)/ ? '' : ' is true';
|
my $expression = ::istrue $item{logical_OR_AND_expression};
|
||||||
$return = "$op1 if $item{logical_OR_AND_expression}$istrue otherwise to $op2";
|
$return = "$op1 if $expression otherwise to $op2";
|
||||||
} else {
|
} else {
|
||||||
$return = $item{logical_OR_AND_expression};
|
$return = $item{logical_OR_AND_expression};
|
||||||
}
|
}
|
||||||
@ -885,37 +885,37 @@ postfix_productions:
|
|||||||
{ $return = $item{expression}; }
|
{ $return = $item{expression}; }
|
||||||
)(s) postfix_productions[context => 'array_address'](?)
|
)(s) postfix_productions[context => 'array_address'](?)
|
||||||
{
|
{
|
||||||
my $item_expression = '';
|
my $expression = '';
|
||||||
if (@{$item[-2]}) {
|
if (@{$item[-2]}) {
|
||||||
$item_expression = join(' and ', @{$item[-2]});
|
$expression = join(' and ', @{$item[-2]});
|
||||||
}
|
}
|
||||||
|
|
||||||
my $postfix = $item[-1]->[0];
|
my $postfix = $item[-1]->[0];
|
||||||
|
|
||||||
if (length $item_expression) {
|
if (length $expression) {
|
||||||
if($item_expression =~ /^\d+$/) {
|
if($expression =~ /^\d+$/) {
|
||||||
$item_expression++;
|
$expression++;
|
||||||
my ($last_digit) = $item_expression =~ /(\d)$/;
|
my ($last_digit) = $expression =~ /(\d)$/;
|
||||||
if($last_digit == 1) {
|
if($last_digit == 1) {
|
||||||
$item_expression .= 'st';
|
$expression .= 'st';
|
||||||
} elsif($last_digit == 2) {
|
} elsif($last_digit == 2) {
|
||||||
$item_expression .= 'nd';
|
$expression .= 'nd';
|
||||||
} elsif($last_digit == 3) {
|
} elsif($last_digit == 3) {
|
||||||
$item_expression .= 'rd';
|
$expression .= 'rd';
|
||||||
} else {
|
} else {
|
||||||
$item_expression .= 'th';
|
$expression .= 'th';
|
||||||
}
|
}
|
||||||
if($arg{context} eq 'function call') {
|
if($arg{context} eq 'function call') {
|
||||||
$return = "the $item_expression element of";
|
$return = "the $expression element of";
|
||||||
} else {
|
} else {
|
||||||
$return = "the $item_expression element of $arg{primary_expression}";
|
$return = "the $expression element of $arg{primary_expression}";
|
||||||
}
|
}
|
||||||
} elsif($item_expression =~ /^-\s*\d+$/) {
|
} elsif($expression =~ /^-\s*\d+$/) {
|
||||||
$item_expression *= -1;
|
$expression *= -1;
|
||||||
my $plural = $item_expression == 1 ? '' : 's';
|
my $plural = $expression == 1 ? '' : 's';
|
||||||
$return = "the location $item_expression element$plural backwards from where $arg{primary_expression} points";
|
$return = "the location $expression element$plural backwards from where $arg{primary_expression} points";
|
||||||
} else {
|
} else {
|
||||||
$return = "the element of $arg{primary_expression} at location $item_expression";
|
$return = "the element of $arg{primary_expression} at location $expression";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,3 +87,18 @@ sub precompile_grammar {
|
|||||||
sub flatten {
|
sub flatten {
|
||||||
map { ref eq 'ARRAY' ? flatten(@$_) : $_ } @_
|
map { ref eq 'ARRAY' ? flatten(@$_) : $_ } @_
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub istrue {
|
||||||
|
my @parts = split / and /, $_[0];
|
||||||
|
my ($result, $and) = ('', '');
|
||||||
|
foreach my $part (@parts) {
|
||||||
|
$result .= $and;
|
||||||
|
if($part !~ /(greater|less|equal|false$)/) {
|
||||||
|
$result .= "$part is true";
|
||||||
|
} else {
|
||||||
|
$result .= $part;
|
||||||
|
}
|
||||||
|
$and = ' and ';
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user