mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-11 12:32:37 +01:00
CGrammar: Fix ordering of statement vs conditional/expression due to concatenated context
This commit is contained in:
parent
d6c20bc051
commit
34def4f9ad
@ -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 => 688,
|
BUILD_REVISION => 689,
|
||||||
BUILD_DATE => "2014-07-01",
|
BUILD_DATE => "2014-07-01",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -424,110 +424,110 @@ conditional_ternary_expression:
|
|||||||
assignment_operator:
|
assignment_operator:
|
||||||
'='
|
'='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Assign to^L', 'the value^L' ];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['assigning to^L', 'the value^L' ];
|
$return = ['assigning to^L', 'the value^L' ];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Assign to^L', 'the value^L' ];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is assigned to be^L';
|
$return = 'which is assigned to be^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '+='
|
| '+='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Increment^L','by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['incrementing^L','by^L'];
|
$return = ['incrementing^L','by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Increment^L','by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is incremented by^L';
|
$return = 'which is incremented by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '-='
|
| '-='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Decrement^L', 'by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['decrementing^L' , 'by^L'];
|
$return = ['decrementing^L' , 'by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Decrement^L', 'by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is decremented by^L';
|
$return = 'which is decremented by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '*='
|
| '*='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Multiply^L' , 'by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['multiplying^L' , 'by^L'];
|
$return = ['multiplying^L' , 'by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Multiply^L' , 'by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is multiplied by^L';
|
$return = 'which is multiplied by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '/='
|
| '/='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Divide^L' , 'by^L' ];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['dividing^L' , 'by^L' ];
|
$return = ['dividing^L' , 'by^L' ];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Divide^L' , 'by^L' ];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is divided by^L';
|
$return = 'which is divided by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '%='
|
| '%='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Reduce^L', 'to modulo ^L'] ;
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['reducing^L', 'to modulo ^L'] ;
|
$return = ['reducing^L', 'to modulo ^L'] ;
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Reduce^L', 'to modulo ^L'] ;
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is reduced to modulo^L';
|
$return = 'which is reduced to modulo^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '<<='
|
| '<<='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Bit-shift^L', 'left by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['bit-shifting^L', 'left by^L'];
|
$return = ['bit-shifting^L', 'left by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Bit-shift^L', 'left by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is bit-shifted left by^L';
|
$return = 'which is bit-shifted left by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '>>='
|
| '>>='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Bit-shift^L', 'right by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['bit-shifting^L', 'right by^L'];
|
$return = ['bit-shifting^L', 'right by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Bit-shift^L', 'right by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is bit-shifted right by^L';
|
$return = 'which is bit-shifted right by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '&='
|
| '&='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Bit-wise ANDed^L', 'by^L' ];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['bit-wise ANDing^L', 'by^L' ];
|
$return = ['bit-wise ANDing^L', 'by^L' ];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Bit-wise ANDed^L', 'by^L' ];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is bit-wise ANDed by^L';
|
$return = 'which is bit-wise ANDed by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '^='
|
| '^='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Exclusive-OR^L','by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['exclusive-ORing^L','by^L'];
|
$return = ['exclusive-ORing^L','by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Exclusive-OR^L','by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is exclusive-ORed by^L';
|
$return = 'which is exclusive-ORed by^L';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '|='
|
| '|='
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = ['Bit-wise ORed^L', 'by^L'];
|
|
||||||
} elsif ($arg{context} eq 'for init') {
|
|
||||||
$return = ['bit-wise ORing^L', 'by^L'];
|
$return = ['bit-wise ORing^L', 'by^L'];
|
||||||
|
} elsif ($arg{context} =~ /statement$/) {
|
||||||
|
$return = ['Bit-wise ORed^L', 'by^L'];
|
||||||
} else {
|
} else {
|
||||||
$return = 'which is bit-wise ORed by^L';
|
$return = 'which is bit-wise ORed by^L';
|
||||||
}
|
}
|
||||||
@ -839,26 +839,30 @@ unary_expression:
|
|||||||
{ $return = $item{postfix_expression}; }
|
{ $return = $item{postfix_expression}; }
|
||||||
| '++' unary_expression
|
| '++' unary_expression
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/ ) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = "pre-increment $item{unary_expression}";
|
$return = "pre-incrementing $item{unary_expression}";
|
||||||
} else {
|
} elsif ($arg{context} =~ /(conditional|expression)/) {
|
||||||
if ($item{unary_expression} =~ s/^the member//) {
|
if ($item{unary_expression} =~ s/^the member//) {
|
||||||
$return = "the pre-incremented member $item{unary_expression}";
|
$return = "the pre-incremented member $item{unary_expression}";
|
||||||
} else {
|
} else {
|
||||||
$return = "pre-incremented $item{unary_expression}";
|
$return = "pre-incremented $item{unary_expression}";
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
$return = "pre-increment $item{unary_expression}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| '--' unary_expression
|
| '--' unary_expression
|
||||||
{
|
{
|
||||||
if ($arg{context} =~ /statement$/ ) {
|
if ($arg{context} =~ /for init/) {
|
||||||
$return = "Pre-decrement $item{unary_expression}";
|
$return = "pre-decrementing $item{unary_expression}";
|
||||||
} else {
|
} elsif ($arg{context} =~ /(conditional|expression)/) {
|
||||||
if ($item{unary_expression} =~ s/^the member//) {
|
if ($item{unary_expression} =~ s/^the member//) {
|
||||||
$return = "the pre-decremented member $item{unary_expression}";
|
$return = "the pre-decremented member $item{unary_expression}";
|
||||||
} else {
|
} else {
|
||||||
$return = "pre-decremented $item{unary_expression}";
|
$return = "pre-decremented $item{unary_expression}";
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
$return = "Pre-decrement $item{unary_expression}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
| unary_operator cast_expression
|
| unary_operator cast_expression
|
||||||
@ -1025,10 +1029,12 @@ postfix_productions:
|
|||||||
} else {
|
} else {
|
||||||
$return = "post-increment";
|
$return = "post-increment";
|
||||||
}
|
}
|
||||||
} elsif ($arg{context} =~ /statement/) {
|
} elsif ($arg{context} =~ /for init/) {
|
||||||
$return = ['increment', 'by one'];
|
$return = ['incrementing', 'by one'];
|
||||||
} else {
|
} elsif ($arg{context} =~ /(conditional|expression)/) {
|
||||||
$return = "post-incremented $arg{primary_expression}";
|
$return = "post-incremented $arg{primary_expression}";
|
||||||
|
} else {
|
||||||
|
$return = ['increment', 'by one'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1042,11 +1048,13 @@ postfix_productions:
|
|||||||
} else {
|
} else {
|
||||||
$return = "post-decrement";
|
$return = "post-decrement";
|
||||||
}
|
}
|
||||||
} elsif ($arg{context} =~ /statement/) {
|
} elsif ($arg{context} =~ /for init/) {
|
||||||
$return = ['decrement', 'by one'];
|
$return = ['decrementing', 'by one'];
|
||||||
} else {
|
} elsif ($arg{context} =~ /(conditional|expression)/) {
|
||||||
$return = "post-decremented $arg{primary_expression}";
|
$return = "post-decremented $arg{primary_expression}";
|
||||||
}
|
} else {
|
||||||
|
$return = ['decrement', 'by one'];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
# having done the simplest cases, we go to the catch all for left recursions.
|
# having done the simplest cases, we go to the catch all for left recursions.
|
||||||
@ -1103,7 +1111,7 @@ narrow_closure:
|
|||||||
';' | ',' | '->'
|
';' | ',' | '->'
|
||||||
|
|
||||||
primary_expression:
|
primary_expression:
|
||||||
'(' expression ')' (...narrow_closure)(?)
|
'(' expression[context => "$arg{context}|expression"] ')' (...narrow_closure)(?)
|
||||||
{
|
{
|
||||||
my $expression = $item{expression} ;
|
my $expression = $item{expression} ;
|
||||||
my $repeats = 1;
|
my $repeats = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user