mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-11 04:22:35 +01:00
Preserve comments in code/paste
This commit is contained in:
parent
522b9770dd
commit
a6a3129171
@ -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 => 426,
|
BUILD_REVISION => 427,
|
||||||
BUILD_DATE => "2013-08-26",
|
BUILD_DATE => "2013-08-27",
|
||||||
};
|
};
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -774,23 +774,21 @@ if($lang eq 'C89' or $lang eq 'C99' or $lang eq 'C11' or $lang eq 'C++') {
|
|||||||
|
|
||||||
print "*** prelude: [$prelude]\n precode: [$precode]\n" if $debug;
|
print "*** prelude: [$prelude]\n precode: [$precode]\n" if $debug;
|
||||||
|
|
||||||
# strip C and C++ style comments
|
|
||||||
if($lang eq 'C89' or $args =~ m/-std=(gnu89|c89)/i) {
|
|
||||||
$precode =~ s#/\*[^*]*\*+([^/*][^*]*\*+)*/# #gs;
|
|
||||||
$precode =~ s#|//([^\\]|[^\n][\n]?)*?\n|("(\\.|[^"\\])*"|'(\\.|[^'\\])*'|.[^/"'\\]*)#defined $2 ? $2 : " "#gse;
|
|
||||||
} else {
|
|
||||||
$precode =~ s#|//([^\\]|[^\n][\n]?)*?\n|("(\\.|[^"\\])*"|'(\\.|[^'\\])*'|.[^/"'\\]*)#defined $2 ? $2 : " "#gse;
|
|
||||||
$precode =~ s#/\*[^*]*\*+([^/*][^*]*\*+)*/# #gs;
|
|
||||||
}
|
|
||||||
|
|
||||||
print " precode: [$precode]\n" if $debug;
|
|
||||||
|
|
||||||
my $preprecode = $precode;
|
my $preprecode = $precode;
|
||||||
|
|
||||||
# white-out contents of quoted literals
|
# white-out contents of quoted literals
|
||||||
$preprecode =~ s/(?:\"((?:\\\"|(?!\").)*)\")/'"' . ('-' x length $1) . '"'/ge;
|
$preprecode =~ s/(?:\"((?:\\\"|(?!\").)*)\")/'"' . ('-' x length $1) . '"'/ge;
|
||||||
$preprecode =~ s/(?:\'((?:\\\'|(?!\').)*)\')/"'" . ('-' x length $1) . "'"/ge;
|
$preprecode =~ s/(?:\'((?:\\\'|(?!\').)*)\')/"'" . ('-' x length $1) . "'"/ge;
|
||||||
|
|
||||||
|
# strip C and C++ style comments
|
||||||
|
if($lang eq 'C89' or $args =~ m/-std=(gnu89|c89)/i) {
|
||||||
|
$preprecode =~ s#/\*[^*]*\*+([^/*][^*]*\*+)*/# #gs;
|
||||||
|
$preprecode =~ s#|//([^\\]|[^\n][\n]?)*?\n|("(\\.|[^"\\])*"|'(\\.|[^'\\])*'|.[^/"'\\]*)#defined $2 ? $2 : ""#gse;
|
||||||
|
} else {
|
||||||
|
$preprecode =~ s#|//([^\\]|[^\n][\n]?)*?\n|("(\\.|[^"\\])*"|'(\\.|[^'\\])*'|.[^/"'\\]*)#defined $2 ? $2 : ""#gse;
|
||||||
|
$preprecode =~ s#/\*[^*]*\*+([^/*][^*]*\*+)*/# #gs;
|
||||||
|
}
|
||||||
|
|
||||||
print "preprecode: [$preprecode]\n" if $debug;
|
print "preprecode: [$preprecode]\n" if $debug;
|
||||||
|
|
||||||
print "looking for functions, has main: $has_main\n" if $debug >= 2;
|
print "looking for functions, has main: $has_main\n" if $debug >= 2;
|
||||||
@ -881,6 +879,8 @@ $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/;(\s*\/\*.*?\*\/\s*);\n/;$1/gs;
|
||||||
|
$code =~ s/;(\s*\/\/.*?\s*);\n/;$1/gs;
|
||||||
$code =~ s/({|})\n\s*;\n/$1\n/gs;
|
$code =~ s/({|})\n\s*;\n/$1\n/gs;
|
||||||
$code =~ s/(?:\n\n)+/\n\n/g;
|
$code =~ s/(?:\n\n)+/\n\n/g;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user