mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-03 23:04:08 +01:00
merge changes 1895 and 1899 for allowing ifdefs in funcfile.txt
This commit is contained in:
parent
ef4d986a45
commit
5204fd4c23
1 changed files with 89 additions and 21 deletions
110
palm/gen_pace.pl
110
palm/gen_pace.pl
|
@ -21,11 +21,15 @@ use File::Basename;
|
||||||
my %funcInfo;
|
my %funcInfo;
|
||||||
my %fileNames;
|
my %fileNames;
|
||||||
my %contents;
|
my %contents;
|
||||||
|
my @ifdefs;
|
||||||
|
my @minusDs;
|
||||||
|
|
||||||
sub usage() {
|
sub usage() {
|
||||||
print STDERR "$0 \\\n" .
|
print STDERR "$0 \\\n" .
|
||||||
"\t[-oh out.h] \\\n" .
|
"\t[-oh out.h] \\\n" .
|
||||||
"\t[-oc out.c] \\\n" .
|
"\t[-oc out.c] \\\n" .
|
||||||
|
"\t[-os out.s] \\\n" .
|
||||||
|
"\t[-D<define0> ... -D<defineN>] \\\n" .
|
||||||
"\t[-file palmheader.h|palm_header_dir] (can repeat) \\\n" .
|
"\t[-file palmheader.h|palm_header_dir] (can repeat) \\\n" .
|
||||||
"\t[-func func_name_or_list_file] (can repeat)\n";
|
"\t[-func func_name_or_list_file] (can repeat)\n";
|
||||||
|
|
||||||
|
@ -43,13 +47,37 @@ sub makeFuncList($) {
|
||||||
while ( <LIST> ) {
|
while ( <LIST> ) {
|
||||||
chomp;
|
chomp;
|
||||||
|
|
||||||
|
# ifdef/endif pairs
|
||||||
|
if ( m/^\#\s*ifdef\s+(\w+)\s*$/ ) {
|
||||||
|
# print STDERR "looking for $1 in ", join( ",", @minusDs), "\n";
|
||||||
|
if ( 0 == grep( {$1 eq $_} @minusDs ) ) {
|
||||||
|
# print STDERR "adding $1 to skippers\n";
|
||||||
|
push( @ifdefs, $1 );
|
||||||
|
} else {
|
||||||
|
# print STDERR "NOT adding $1 to skippers\n";
|
||||||
|
}
|
||||||
|
next;
|
||||||
|
} elsif ( m/^\#\s*endif\s+(\w+)\s*$/ ) {
|
||||||
|
if ( 0 == grep( {$1 eq $_} @minusDs ) ) {
|
||||||
|
die "$1 not most recently defined" if $1 ne pop(@ifdefs);
|
||||||
|
}
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
next if @ifdefs > 0;
|
||||||
|
|
||||||
# comments?
|
# comments?
|
||||||
s/\#.*$//;
|
s/\#.*$//;
|
||||||
# white space
|
# white space
|
||||||
s/\s*(\w+)\s*/$1/;
|
s/^\s*//;
|
||||||
next if ! length;
|
s/\s*$//;
|
||||||
|
|
||||||
push( @result, $_ );
|
if ( m,^(\w+)\s+(-?\d+)\s+(0x\w+)$, ) {
|
||||||
|
push( @result, [ $1, $2, $3 ] );
|
||||||
|
} elsif ( m,^(\w+)$, ) {
|
||||||
|
push( @result, [ $1 ] );
|
||||||
|
} else {
|
||||||
|
next;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
close LIST;
|
close LIST;
|
||||||
} else {
|
} else {
|
||||||
|
@ -69,6 +97,7 @@ sub makeFileList($) {
|
||||||
my @funcList;
|
my @funcList;
|
||||||
my @pathList;
|
my @pathList;
|
||||||
my $dot_c;
|
my $dot_c;
|
||||||
|
my $dot_s;
|
||||||
my $dot_h;
|
my $dot_h;
|
||||||
|
|
||||||
# A list of types seen in the header files. The idea is to use these
|
# A list of types seen in the header files. The idea is to use these
|
||||||
|
@ -524,47 +553,86 @@ sub funcId($$) {
|
||||||
return $id;
|
return $id;
|
||||||
} # funcId
|
} # funcId
|
||||||
|
|
||||||
|
sub genStub($$$) {
|
||||||
|
my( $func, $r9off, $off ) = @_;
|
||||||
|
my $result;
|
||||||
|
|
||||||
|
if ( $func && $r9off && $off ) {
|
||||||
|
$result .= "\t\t.type $func, %function\n";
|
||||||
|
$result .= "\t\t.globl $func\n";
|
||||||
|
$result .= "$func:\n";
|
||||||
|
$result .= "\tldr ip, [r9, #$r9off]\n";
|
||||||
|
my $intoff = 4 * hex($off);
|
||||||
|
$result .= "\tldr pc, [ip, #$intoff]\n";
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
###########################################################################
|
###########################################################################
|
||||||
# Main
|
# Main
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
|
my @paths;
|
||||||
|
my @funcs;
|
||||||
while ( my $arg = shift(@ARGV) ) {
|
while ( my $arg = shift(@ARGV) ) {
|
||||||
if ( $arg eq "-oh" ) {
|
if ( $arg eq "-oh" ) {
|
||||||
$dot_h = shift(@ARGV);
|
$dot_h = shift(@ARGV);
|
||||||
} elsif ( $arg eq "-oc" ) {
|
} elsif ( $arg eq "-oc" ) {
|
||||||
$dot_c = shift(@ARGV);
|
$dot_c = shift(@ARGV);
|
||||||
|
} elsif ( $arg eq "-os" ) {
|
||||||
|
$dot_s = shift(@ARGV);
|
||||||
} elsif ( $arg eq "-file" ) {
|
} elsif ( $arg eq "-file" ) {
|
||||||
push( @pathList, makeFileList(shift(@ARGV)) );
|
push( @paths, shift(@ARGV));
|
||||||
} elsif ( $arg eq "-func" ) {
|
} elsif ( $arg eq "-func" ) {
|
||||||
push( @funcList, makeFuncList(shift(@ARGV)) );
|
push( @funcs, shift(@ARGV));
|
||||||
|
} elsif ( $arg =~ m|^-D(\w+)$| ) {
|
||||||
|
push( @minusDs, $1 );
|
||||||
} else {
|
} else {
|
||||||
usage();
|
usage();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach my $func (@funcList) {
|
map { push( @pathList, makeFileList($_) ); } @paths;
|
||||||
|
map { push( @funcList, makeFuncList($_) ); } @funcs;
|
||||||
|
|
||||||
# print STDERR "looking for $func\n";
|
my $dot_s_out = "\t.text\n";
|
||||||
|
foreach my $fref (@funcList) {
|
||||||
my $found = 0;
|
if ( $dot_s ) {
|
||||||
my $path;
|
$dot_s_out .= genStub( $$fref[0], $$fref[1], $$fref[2] );
|
||||||
foreach my $path (@pathList) {
|
|
||||||
if ( -d $path ) {
|
|
||||||
$found = searchOneDir( $path, $func );
|
|
||||||
last if $found;
|
|
||||||
} elsif ( -e $path ) {
|
|
||||||
$found = searchOneFile( $path, $func );
|
|
||||||
last if $found;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
die "unable to find declaration of $func\n" if ! $found;
|
if ( $dot_c ) {
|
||||||
close PATHS;
|
my $func = $$fref[0];
|
||||||
|
my $found = 0;
|
||||||
|
my $path;
|
||||||
|
foreach my $path (@pathList) {
|
||||||
|
if ( -d $path ) {
|
||||||
|
$found = searchOneDir( $path, $func );
|
||||||
|
last if $found;
|
||||||
|
} elsif ( -e $path ) {
|
||||||
|
$found = searchOneFile( $path, $func );
|
||||||
|
last if $found;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
die "unable to find declaration of $func\n" if ! $found;
|
||||||
|
}
|
||||||
|
# close PATHS;
|
||||||
}
|
}
|
||||||
|
|
||||||
my $outRef;
|
my $outRef;
|
||||||
|
|
||||||
|
if ( $dot_s ) {
|
||||||
|
if ( $dot_s eq "-" ) {
|
||||||
|
$outRef = *STDOUT{IO};
|
||||||
|
} else {
|
||||||
|
open DOT, "> $dot_s";
|
||||||
|
$outRef = *DOT{IO};
|
||||||
|
}
|
||||||
|
print $outRef $dot_s_out;
|
||||||
|
if ( $dot_c ne "-" ) {
|
||||||
|
close DOT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ( $dot_c ) {
|
if ( $dot_c ) {
|
||||||
if ( $dot_c eq "-" ) {
|
if ( $dot_c eq "-" ) {
|
||||||
$outRef = *STDOUT{IO};
|
$outRef = *STDOUT{IO};
|
||||||
|
|
Loading…
Reference in a new issue