-
Notifications
You must be signed in to change notification settings - Fork 84
/
Copy pathpkcstv2c.awk
executable file
·112 lines (100 loc) · 2.39 KB
/
pkcstv2c.awk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#! /usr/bin/awk -f
# pkcstv2c.awk - Convert pkcs1 test vectors into a C table.
# Copyright 2011 Free Software Foundation, Inc.
#
# This file is free software; as a special exception the author gives
# unlimited permission to copy and/or distribute it, with or without
# modifications, as long as this notice is preserved.
#
# This file is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#
BEGIN {
in_key = 0;
in_item = 0;
in_number = 0;
no_comma = 0;
printf " static struct {\n";
printf " const char *desc;\n";
printf " const char *n, *e, *d;\n";
printf " struct {\n";
printf " const char *desc;\n";
printf " const char *mesg;\n";
printf " const char *seed;\n";
printf " const char *encr;\n";
printf " } m[20];\n";
printf " } tbl[] =\n";
printf " {\n";
}
{ sub (/\r/,""); }
/^# Public key/ { skip_pub = 1; }
/^# Private key/ { skip_pub = 0; }
skip_pub { next }
in_number && ! /^[0-9a-f]/ {
if (in_number == 2)
printf "\"";
if (no_comma)
no_comma = 0;
else
printf ","
printf "\n";
in_number = 0;
}
in_number == 3 {
printf "\n";
in_number = 1;
}
in_number == 1 {
gsub (/ /,"")
printf "%*s\"%s", indent, "", $0;
in_number = 2;
next;
}
in_number == 2 {
gsub (/ /,"")
printf "%s\"", $0;
in_number = 3;
next;
}
/^#.*Example.*key pair/ {
if (in_item) {
printf " }\n }\n },\n";
in_item = 0;
}
in_key = 1;
indent = 6;
printf " {\n \"%s\",\n", gensub(/.*: (A .*)/, "\\1", "g");
next
}
/^# PKCS#1 .*Example/ {
if (in_key) {
printf " {\n";
in_key = 0;
}
if (in_item)
printf " },{\n";
else
printf " {\n";
in_item = 1;
indent = 10;
printf " \"%s\",\n", gensub(/^# (.*)/, "\\1", "g");
next
}
(in_key || in_item) && /^# (Modulus|Public|Exponent|Message|Seed)/ {
# printf "/* %s */\n", $0;
in_number = 1;
next
}
(in_key || in_item) && /^# (Signature|Encryption)/ {
# printf "/* %s */\n", $0;
in_number = 1;
no_comma = 1;
next
}
END {
if (in_item) {
printf " }\n }\n }\n };\n";
in_item = 0;
}
}