Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

obj_xref.pl 2.0 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #!/usr/bin/env perl
  2. use strict;
  3. if (scalar @ARGV != 2)
  4. {
  5. print "Usage: perl obj_xref.pl obj_mac.num obj_xref.txt > obj_xref.h\n";
  6. exit 1;
  7. }
  8. my %xref_tbl;
  9. my %oid_tbl;
  10. my ($mac_file, $xref_file) = @ARGV;
  11. open(IN, $mac_file) || die "Can't open $mac_file";
  12. # Read in OID nid values for a lookup table.
  13. while (<IN>)
  14. {
  15. chomp;
  16. my ($name, $num) = /^(\S+)\s+(\S+)$/;
  17. $oid_tbl{$name} = $num;
  18. }
  19. close IN;
  20. open(IN, $xref_file) || die "Can't open $xref_file";
  21. my $ln = 1;
  22. while (<IN>)
  23. {
  24. chomp;
  25. s/#.*$//;
  26. next if (/^\S*$/);
  27. my ($xr, $p1, $p2) = /^(\S+)\s+(\S+)\s+(\S+)/;
  28. check_oid($xr);
  29. check_oid($p1);
  30. check_oid($p2);
  31. $xref_tbl{$xr} = [$p1, $p2, $ln];
  32. }
  33. my @xrkeys = keys %xref_tbl;
  34. my @srt1 = sort { $oid_tbl{$a} <=> $oid_tbl{$b}} @xrkeys;
  35. for(my $i = 0; $i <= $#srt1; $i++)
  36. {
  37. $xref_tbl{$srt1[$i]}[2] = $i;
  38. }
  39. my @srt2 = sort
  40. {
  41. my$ap1 = $oid_tbl{$xref_tbl{$a}[0]};
  42. my$bp1 = $oid_tbl{$xref_tbl{$b}[0]};
  43. return $ap1 - $bp1 if ($ap1 != $bp1);
  44. my$ap2 = $oid_tbl{$xref_tbl{$a}[1]};
  45. my$bp2 = $oid_tbl{$xref_tbl{$b}[1]};
  46. return $ap2 - $bp2;
  47. } @xrkeys;
  48. my $pname = $0;
  49. $pname =~ s|^.[^/]/||;
  50. print <<EOF;
  51. /* THIS FILE IS GENERATED FROM obj_xref.txt by obj_xref.pl via the
  52. * following command:
  53. * perl obj_xref.pl obj_mac.num obj_xref.txt > obj_xref.h */
  54. typedef struct
  55. {
  56. int sign_id;
  57. int hash_id;
  58. int pkey_id;
  59. } nid_triple;
  60. static const nid_triple sigoid_srt[] =
  61. {
  62. EOF
  63. foreach (@srt1)
  64. {
  65. my $xr = $_;
  66. my ($p1, $p2) = @{$xref_tbl{$_}};
  67. print "\t{NID_$xr, NID_$p1, NID_$p2},\n";
  68. }
  69. print "\t};";
  70. print <<EOF;
  71. static const nid_triple * const sigoid_srt_xref[] =
  72. {
  73. EOF
  74. foreach (@srt2)
  75. {
  76. my ($p1, $p2, $x) = @{$xref_tbl{$_}};
  77. # If digest or signature algorithm is "undef" then the algorithm
  78. # needs special handling and is excluded from the cross reference table.
  79. next if $p1 eq "undef" || $p2 eq "undef";
  80. print "\t\&sigoid_srt\[$x\],\n";
  81. }
  82. print "\t};\n\n";
  83. sub check_oid
  84. {
  85. my ($chk) = @_;
  86. if (!exists $oid_tbl{$chk})
  87. {
  88. die "Not Found \"$chk\"\n";
  89. }
  90. }