2007-06-11 11:36:17 +00:00
|
|
|
# Fix XDR code (generated by rpcgen) so that it compiles
|
|
|
|
# with warnings turned on.
|
|
|
|
#
|
|
|
|
# This code is evil. Arguably better would be just to compile
|
|
|
|
# without -Werror. Update: The IXDR_PUT_LONG replacements are
|
|
|
|
# actually fixes for 64 bit, so this file is necessary. Arguably
|
|
|
|
# so is the type-punning fix.
|
|
|
|
#
|
|
|
|
# Copyright (C) 2007 Red Hat, Inc.
|
|
|
|
#
|
|
|
|
# See COPYING for the license of this software.
|
|
|
|
#
|
|
|
|
# Richard Jones <rjones@redhat.com>
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
my $in_function = 0;
|
|
|
|
my @function = ();
|
|
|
|
|
|
|
|
while (<>) {
|
|
|
|
if (m/^{/) {
|
|
|
|
$in_function = 1;
|
|
|
|
print;
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
|
2008-05-22 15:20:25 +00:00
|
|
|
s/\t/ /g;
|
|
|
|
|
2007-06-11 11:36:17 +00:00
|
|
|
if (m/^}/) {
|
|
|
|
$in_function = 0;
|
|
|
|
|
|
|
|
# Note: The body of the function is in @function.
|
|
|
|
|
|
|
|
# Remove decl of buf, if buf isn't used in the function.
|
|
|
|
my @uses = grep /\bbuf\b/, @function;
|
|
|
|
@function = grep !/\bbuf\b/, @function if @uses == 1;
|
|
|
|
|
|
|
|
# Remove decl of i, if i isn't used in the function.
|
|
|
|
@uses = grep /\bi\b/, @function;
|
|
|
|
@function = grep !/\bi\b/, @function if @uses == 1;
|
|
|
|
|
|
|
|
# (char **)&objp->... gives:
|
|
|
|
# warning: dereferencing type-punned pointer will break
|
|
|
|
# strict-aliasing rules
|
|
|
|
# so rewrite it.
|
|
|
|
my %uses = ();
|
|
|
|
my $i = 0;
|
|
|
|
foreach (@function) {
|
2008-05-23 07:59:00 +00:00
|
|
|
$uses{$1} = $i++ if m/\(char \*\*\)\&(objp->[a-z_.]+_val)/i;
|
2007-06-11 11:36:17 +00:00
|
|
|
}
|
|
|
|
if (keys %uses >= 1) {
|
|
|
|
my $i = 1;
|
|
|
|
|
|
|
|
foreach (keys %uses) {
|
|
|
|
$i = $uses{$_};
|
|
|
|
unshift @function,
|
2008-05-22 15:20:25 +00:00
|
|
|
(" char **objp_cpp$i = (char **) (void *) &$_;\n");
|
2007-06-11 11:36:17 +00:00
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
@function =
|
|
|
|
map { s{\(char \*\*\)\&(objp->[a-z_.]+_val)}
|
2008-05-23 07:59:00 +00:00
|
|
|
{objp_cpp$uses{$1}}gi; $_ } @function;
|
2007-06-11 11:36:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# The code uses 'IXDR_PUT_{U_,}LONG' but it's wrong in two
|
|
|
|
# ways: Firstly these functions are deprecated and don't
|
|
|
|
# work on 64 bit platforms. Secondly the return value should
|
|
|
|
# be ignored. Correct both these mistakes.
|
|
|
|
@function =
|
|
|
|
map { s/\bIXDR_PUT_((U_)?)LONG\b/(void)IXDR_PUT_$1INT32/; $_ }
|
|
|
|
@function;
|
|
|
|
|
|
|
|
print (join ("", @function));
|
|
|
|
@function = ();
|
|
|
|
}
|
|
|
|
|
|
|
|
unless ($in_function) {
|
|
|
|
print;
|
|
|
|
} else {
|
|
|
|
push @function, $_;
|
|
|
|
}
|
|
|
|
}
|