8 my ($mac_file, $xref_file) = @ARGV;
10 open(IN, $mac_file) || die "Can't open $mac_file, $!\n";
12 # Read in OID nid values for a lookup table.
17 my ($name, $num) = /^(\S+)\s+(\S+)$/;
18 $oid_tbl{$name} = $num;
22 open(IN, $xref_file) || die "Can't open $xref_file, $!\n";
31 my ($xr, $p1, $p2) = /^(\S+)\s+(\S+)\s+(\S+)/;
35 $xref_tbl{$xr} = [$p1, $p2, $ln];
38 my @xrkeys = keys %xref_tbl;
40 my @srt1 = sort { $oid_tbl{$a} <=> $oid_tbl{$b}} @xrkeys;
43 for($i = 0; $i <= $#srt1; $i++)
45 $xref_tbl{$srt1[$i]}[2] = $i;
50 my$ap1 = $oid_tbl{$xref_tbl{$a}[0]};
51 my$bp1 = $oid_tbl{$xref_tbl{$b}[0]};
52 return $ap1 - $bp1 if ($ap1 != $bp1);
53 my$ap2 = $oid_tbl{$xref_tbl{$a}[1]};
54 my$bp2 = $oid_tbl{$xref_tbl{$b}[1]};
63 /* AUTOGENERATED BY $pname, DO NOT EDIT */
71 DEFINE_STACK_OF(nid_triple)
73 static const nid_triple sigoid_srt[] = {
79 my ($p1, $p2) = @{$xref_tbl{$_}};
80 my $o1 = " {NID_$xr, NID_$p1,";
82 if (length("$o1 $o2") < 78)
96 static const nid_triple *const sigoid_srt_xref[] = {
101 my ($p1, $p2, $x) = @{$xref_tbl{$_}};
102 # If digest or signature algorithm is "undef" then the algorithm
103 # needs special handling and is excluded from the cross reference table.
104 next if $p1 eq "undef" || $p2 eq "undef";
105 print " \&sigoid_srt\[$x\],\n";
113 if (!exists $oid_tbl{$chk})
115 die "Can't find \"$chk\", $!\n";