Since OID NIDs with 0.9.8.
[openssl.git] / crypto / objects / objxref.pl
1 #!/usr/local/bin/perl
2
3 open IN, "obj_mac.num";
4
5 # Read in OID nid values for a lookup table.
6
7 while (<IN>)
8         {
9         chomp;
10         my ($name, $num) = /^(\S+)\s+(\S+)$/;
11         $oid_tbl{$name} = $num;
12         }
13 close IN;
14
15 open IN, "obj_xref.txt";
16
17 my $ln = 1;
18
19 while (<IN>)
20         {
21         chomp;
22         s/#.*$//;
23         next if (/^\S*$/);
24         my ($xr, $p1, $p2) = /^(\S+)\s+(\S+)\s+(\S+)/;
25         check_oid($xr);
26         check_oid($p1);
27         check_oid($p2);
28         $xref_tbl{$xr} = [$p1, $p2, $ln];
29         }
30
31 my @xrkeys = keys %xref_tbl;
32
33 my @srt1 = sort { $oid_tbl{$a} <=> $oid_tbl{$b}} @xrkeys;
34
35 for(my $i = 0; $i <= $#srt1; $i++)
36         {
37         $xref_tbl{$srt1[$i]}[2] = $i;
38         }
39
40 my @srt2 = sort
41         {
42         my$ap1 = $oid_tbl{$xref_tbl{$a}[0]};
43         my$bp1 = $oid_tbl{$xref_tbl{$b}[0]};
44         return $ap1 - $bp1 if ($ap1 != $bp1);
45         my$ap2 = $oid_tbl{$xref_tbl{$a}[1]};
46         my$bp2 = $oid_tbl{$xref_tbl{$b}[1]};
47
48         return $ap2 - $bp2;
49         } @xrkeys;
50         
51
52 print <<EOF;
53
54 typedef int nid_triple[3];
55
56 static const nid_triple sigoid_srt[] =
57         {
58 EOF
59
60 foreach (@srt1)
61         {
62         my $xr = $_;
63         my ($p1, $p2) = @{$xref_tbl{$_}};
64         print "\t{NID_$xr, NID_$p1, NID_$p2},\n";
65         }
66
67 print "\t};";
68 print <<EOF;
69
70
71 static const nid_triple * const sigoid_srt_xref[] =
72         {
73 EOF
74
75 foreach (@srt2)
76         {
77         my $x = $xref_tbl{$_}[2];
78         print "\t\&sigoid_srt\[$x\],\n";
79         }
80
81 print "\t};\n\n";
82
83 sub check_oid
84         {
85         my ($chk) = @_;
86         if (!exists $oid_tbl{$chk})
87                 {
88                 die "Not Found \"$chk\"\n";
89                 }
90         }
91