mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-25 19:44:26 +01:00
compiler_vm: Improve extraction of function parameters containing parentheses
This commit is contained in:
parent
3f771df8bc
commit
1d7791d9a5
@ -13,8 +13,8 @@ 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 => 393,
|
BUILD_REVISION => 394,
|
||||||
BUILD_DATE => "2012-11-14",
|
BUILD_DATE => "2012-11-18",
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -751,13 +751,14 @@ if($lang eq 'C' or $lang eq 'C99' or $lang eq 'C11' or $lang eq 'C++') {
|
|||||||
|
|
||||||
print "looking for functions, has main: $has_main\n" if $debug >= 2;
|
print "looking for functions, has main: $has_main\n" if $debug >= 2;
|
||||||
|
|
||||||
my $func_regex = qr/^([ a-zA-Z0-9_*\[\]]+)\s+([a-zA-Z0-9_*]+)\s*\(([^)]*)\)\s*(\{.*)/ms;
|
my $func_regex = qr/^([ a-zA-Z0-9_*]+)\s+([a-zA-Z0-9_*]+)\s*\(([^{]*)\s*({.*)/ms;
|
||||||
|
|
||||||
# look for potential functions to extract
|
# look for potential functions to extract
|
||||||
while($preprecode =~ /$func_regex/ms) {
|
while($preprecode =~ /$func_regex/ms) {
|
||||||
my ($pre_ret, $pre_ident, $pre_params, $pre_potential_body) = ($1, $2, $3, $4);
|
my ($pre_ret, $pre_ident, $pre_params, $pre_potential_body) = ($1, $2, $3, $4);
|
||||||
|
$pre_params =~ s/\)\s*$//;
|
||||||
|
|
||||||
print "looking for functions, found [$pre_ret][$pre_ident][$pre_params][$pre_potential_body], has main: $has_main\n" if $debug >= 2;
|
print "looking for functions, found [$pre_ret][$pre_ident][$pre_params][$pre_potential_body], has main: $has_main\n" if $debug >= 1;
|
||||||
|
|
||||||
# find the pos at which this function lives, for extracting from precode
|
# find the pos at which this function lives, for extracting from precode
|
||||||
$preprecode =~ m/(\Q$pre_ret\E\s+\Q$pre_ident\E\s*\(\s*\Q$pre_params\E\s*\)\s*\Q$pre_potential_body\E)/g;
|
$preprecode =~ m/(\Q$pre_ret\E\s+\Q$pre_ident\E\s*\(\s*\Q$pre_params\E\s*\)\s*\Q$pre_potential_body\E)/g;
|
||||||
@ -775,6 +776,7 @@ if($lang eq 'C' or $lang eq 'C99' or $lang eq 'C11' or $lang eq 'C++') {
|
|||||||
|
|
||||||
$tmpcode =~ m/$func_regex/ms;
|
$tmpcode =~ m/$func_regex/ms;
|
||||||
my ($ret, $ident, $params, $potential_body) = ($1, $2, $3, $4);
|
my ($ret, $ident, $params, $potential_body) = ($1, $2, $3, $4);
|
||||||
|
$params =~ s/\)\s*$//;
|
||||||
|
|
||||||
print "1st extract: [$ret][$ident][$params][$potential_body]\n" if $debug;
|
print "1st extract: [$ret][$ident][$params][$potential_body]\n" if $debug;
|
||||||
|
|
||||||
@ -828,6 +830,7 @@ $code =~ s/\|n/\n/g;
|
|||||||
$code =~ s/^\s+//;
|
$code =~ s/^\s+//;
|
||||||
$code =~ s/\s+$//;
|
$code =~ s/\s+$//;
|
||||||
$code =~ s/;\s*;\n/;\n/gs;
|
$code =~ s/;\s*;\n/;\n/gs;
|
||||||
|
$code =~ s/({|})\n\s*;\n/$1\n/gs;
|
||||||
$code =~ s/(?:\n\n)+/\n\n/g;
|
$code =~ s/(?:\n\n)+/\n\n/g;
|
||||||
|
|
||||||
print "final code: [$code]\n" if $debug;
|
print "final code: [$code]\n" if $debug;
|
||||||
@ -942,7 +945,8 @@ unless($got_run) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(defined $got_paste or (defined $got_run and $got_run eq "paste")) {
|
if(defined $got_paste or (defined $got_run and $got_run eq "paste")) {
|
||||||
$code .= "\n\n/************* OUTPUT *************\n$output************** OUTPUT **************/\n";
|
$output =~ s/[\r\n]+$//;
|
||||||
|
$code .= "\n\n/************* OUTPUT *************\n$output\n************** OUTPUT **************/\n";
|
||||||
my $uri = paste_sprunge(pretty($code));
|
my $uri = paste_sprunge(pretty($code));
|
||||||
print "$nick: $uri\n";
|
print "$nick: $uri\n";
|
||||||
exit 0;
|
exit 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user