Detect more errors.
Change assignment strategy: rathern than using max+r for new codes, find first hole in list of existing codes.
This commit is contained in:
parent
52cc46a237
commit
2adc42e43e
@ -65,6 +65,8 @@ while(<IN>)
|
|||||||
$csrc{$1} = $3;
|
$csrc{$1} = $3;
|
||||||
$fmax{$1} = 99;
|
$fmax{$1} = 99;
|
||||||
$rmax{$1} = 99;
|
$rmax{$1} = 99;
|
||||||
|
$fassigned{$1} = ":";
|
||||||
|
$rassigned{$1} = ":";
|
||||||
$fnew{$1} = 0;
|
$fnew{$1} = 0;
|
||||||
$rnew{$1} = 0;
|
$rnew{$1} = 0;
|
||||||
}
|
}
|
||||||
@ -171,7 +173,7 @@ while (($hdr, $lib) = each %libinc)
|
|||||||
# maximum code used.
|
# maximum code used.
|
||||||
|
|
||||||
if ($gotfile) {
|
if ($gotfile) {
|
||||||
while(<IN>) {
|
while(<IN>) {
|
||||||
if(/^\#define\s+(\S+)\s+(\S+)/) {
|
if(/^\#define\s+(\S+)\s+(\S+)/) {
|
||||||
$name = $1;
|
$name = $1;
|
||||||
$code = $2;
|
$code = $2;
|
||||||
@ -182,26 +184,40 @@ while (($hdr, $lib) = each %libinc)
|
|||||||
}
|
}
|
||||||
if($1 eq "R") {
|
if($1 eq "R") {
|
||||||
$rcodes{$name} = $code;
|
$rcodes{$name} = $code;
|
||||||
|
if ($rassigned{$lib} =~ /:$code:/) {
|
||||||
|
print STDERR "!! ERROR: $lib reason code $code assigned twice\n";
|
||||||
|
}
|
||||||
|
$rassigned{$lib} .= "$code:";
|
||||||
if(!(exists $rextra{$name}) &&
|
if(!(exists $rextra{$name}) &&
|
||||||
($code > $rmax{$lib}) ) {
|
($code > $rmax{$lib}) ) {
|
||||||
$rmax{$lib} = $code;
|
$rmax{$lib} = $code;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if ($fassigned{$lib} =~ /:$code:/) {
|
||||||
|
print STDERR "!! ERROR: $lib function code $code assigned twice\n";
|
||||||
|
}
|
||||||
|
$fassigned{$lib} .= "$code:";
|
||||||
if($code > $fmax{$lib}) {
|
if($code > $fmax{$lib}) {
|
||||||
$fmax{$lib} = $code;
|
$fmax{$lib} = $code;
|
||||||
}
|
}
|
||||||
$fcodes{$name} = $code;
|
$fcodes{$name} = $code;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($debug) {
|
if ($debug) {
|
||||||
if (defined($rmax{$lib})) {
|
|
||||||
print STDERR "Max reason code rmax" . "{" . "$lib" . "} = $rmax{$lib}\n";
|
|
||||||
}
|
|
||||||
if (defined($fmax{$lib})) {
|
if (defined($fmax{$lib})) {
|
||||||
print STDERR "Max function code fmax" . "{" . "$lib" . "} = $fmax{$lib}\n";
|
print STDERR "Max function code fmax" . "{" . "$lib" . "} = $fmax{$lib}\n";
|
||||||
|
$fassigned{$lib} =~ m/^:(.*):$/;
|
||||||
|
@fassigned = sort {$a <=> $b} split(":", $1);
|
||||||
|
print STDERR " @fassigned\n";
|
||||||
|
}
|
||||||
|
if (defined($rmax{$lib})) {
|
||||||
|
print STDERR "Max reason code rmax" . "{" . "$lib" . "} = $rmax{$lib}\n";
|
||||||
|
$rassigned{$lib} =~ m/^:(.*):$/;
|
||||||
|
@rassigned = sort {$a <=> $b} split(":", $1);
|
||||||
|
print STDERR " @rassigned\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,7 +397,16 @@ EOF
|
|||||||
foreach $i (@function) {
|
foreach $i (@function) {
|
||||||
$z=6-int(length($i)/8);
|
$z=6-int(length($i)/8);
|
||||||
if($fcodes{$i} eq "X") {
|
if($fcodes{$i} eq "X") {
|
||||||
$fcodes{$i} = ++$fmax{$lib};
|
$fassigned{$lib} =~ m/^:([^:]*):/;
|
||||||
|
$findcode = $1;
|
||||||
|
if (!defined($findcode)) {
|
||||||
|
$findcode = $fmax{$lib};
|
||||||
|
}
|
||||||
|
while ($fassigned{$lib} =~ m/:$findcode:/) {
|
||||||
|
$findcode++;
|
||||||
|
}
|
||||||
|
$fcodes{$i} = $findcode;
|
||||||
|
$fassigned{$lib} .= "$findcode:";
|
||||||
print STDERR "New Function code $i\n" if $debug;
|
print STDERR "New Function code $i\n" if $debug;
|
||||||
}
|
}
|
||||||
printf OUT "#define $i%s $fcodes{$i}\n","\t" x $z;
|
printf OUT "#define $i%s $fcodes{$i}\n","\t" x $z;
|
||||||
@ -392,7 +417,16 @@ EOF
|
|||||||
foreach $i (@reasons) {
|
foreach $i (@reasons) {
|
||||||
$z=6-int(length($i)/8);
|
$z=6-int(length($i)/8);
|
||||||
if($rcodes{$i} eq "X") {
|
if($rcodes{$i} eq "X") {
|
||||||
$rcodes{$i} = ++$rmax{$lib};
|
$rassigned{$lib} =~ m/^:([^:]*):/;
|
||||||
|
$findcode = $1;
|
||||||
|
if (!defined($findcode)) {
|
||||||
|
$findcode = $rmax{$lib};
|
||||||
|
}
|
||||||
|
while ($rassigned{$lib} =~ m/:$findcode:/) {
|
||||||
|
$findcode++;
|
||||||
|
}
|
||||||
|
$rcodes{$i} = $findcode;
|
||||||
|
$rassigned{$lib} .= "$findcode:";
|
||||||
print STDERR "New Reason code $i\n" if $debug;
|
print STDERR "New Reason code $i\n" if $debug;
|
||||||
}
|
}
|
||||||
printf OUT "#define $i%s $rcodes{$i}\n","\t" x $z;
|
printf OUT "#define $i%s $rcodes{$i}\n","\t" x $z;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user