2006-08-26 11:35:28 +00:00
|
|
|
#!/usr/bin/perl -w
|
|
|
|
######################################################################
|
|
|
|
#
|
2011-01-01 23:21:19 +00:00
|
|
|
# Copyright 2002-2011 by Wilson Snyder. Verilator is free software; you
|
2009-05-04 21:07:57 +00:00
|
|
|
# can redistribute it and/or modify it under the terms of either the GNU
|
|
|
|
# Lesser General Public License Version 3 or the Perl Artistic License
|
|
|
|
# Version 2.0.
|
2008-06-10 01:25:10 +00:00
|
|
|
#
|
2006-08-26 11:35:28 +00:00
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
2008-06-10 01:25:10 +00:00
|
|
|
#
|
2006-08-26 11:35:28 +00:00
|
|
|
######################################################################
|
|
|
|
|
2007-05-12 15:31:04 +00:00
|
|
|
# DESCRIPTION: Edits flex output to get around various broken flex issues.
|
2006-08-26 11:35:28 +00:00
|
|
|
|
2010-02-27 00:50:44 +00:00
|
|
|
my $Opt_Prefix = $ARGV[0] or die "%Error: No prefix specified,";
|
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
foreach my $line (<STDIN>) {
|
|
|
|
# Fix flex 2.5.4 namespace omission
|
|
|
|
$line =~ s/^class istream;/\#include <iostream>\nusing namespace std;\n/;
|
|
|
|
# Fix flex 2.5.31 redefinition
|
|
|
|
$line =~ s!(\#define\s+yyFlexLexer\s+yyFlexLexer)!//flexfix: $1!g;
|
|
|
|
# Fix flex 2.5.1 yytext_ptr undef
|
|
|
|
$line =~ s!(\#undef\s+yytext_ptr)!//flexfix: $1!g;
|
2007-05-12 15:31:04 +00:00
|
|
|
# Fix flex 2.5.4 and GCC 4.1.0 warn_unused_result
|
|
|
|
$line =~ s!\(void\) *fwrite\((.*)\)!if (fwrite($1)) {}!g;
|
|
|
|
# Fix flex 2.5.33 and GCC 4.1.2 "warning: comparison between signed and unsigned integer expressions" in YY_INPUT
|
|
|
|
$line =~ s!for \( n = 0; n < max_size && !for ( n = 0; ((size_t)n < (size_t)max_size) && !g;
|
2009-10-31 03:17:56 +00:00
|
|
|
# Fix flex 2.5.4 and GCC 4.0.2 under FLEX_DEBUG
|
|
|
|
$line =~ s!--accepting rule at line %d !--accepting rule at line %ld !g;
|
2010-02-27 00:50:44 +00:00
|
|
|
# Fix compiler warning filenames
|
|
|
|
$line =~ s!(#line \d+ ".*)_pretmp!$1!;
|
2009-10-31 03:17:56 +00:00
|
|
|
|
2006-08-26 11:35:28 +00:00
|
|
|
print "$line";
|
|
|
|
}
|