lib/asn1: Add extern to declaration of fuzzer string in gen_locl.h
[heimdal.git] / cf / roken-h-process.pl
blobe797dd224e339660cd1e74651f184f8501fd5fe0
1 #!/usr/bin/perl
3 use Getopt::Std;
5 my $debug = 0;
7 getopts('dc:p:o:') || die "foo";
9 if ($opt_d) {
10 $debug = 1;
13 die "missing arg" if (!defined $opt_c || !defined $opt_p || !defined $opt_o);
15 my %defines;
16 my $IN;
17 my $OUT;
19 print "parse config.h\n" if ($debug);
21 open IN, $opt_c || die "failed open ${opt_c}";
23 my @nesting;
25 push @nesting, 1;
27 while (<IN>) {
28 if (m/\s*#ifdef\s+(.*)/) {
29 my $var = $1;
30 if (defined $defines{$var}) {
31 push @nesting, 1;
32 } else {
33 push @nesting, 0;
35 next;
36 } elsif (m/\s*#ifndef\s+(.*)/) {
37 my $var = $1;
38 if (defined $defines{$var}) {
39 push @nesting, 0;
40 } else {
41 push @nesting, 1;
43 next;
44 } elsif (m/\s*#else/) {
45 my $var = pop @nesting;
46 $var = !$var;
47 push @nesting, $var;
48 next;
49 } elsif ($nesting[$#nesting] and m/\s*#define\s+(\w+)\s+(\S+)/) {
50 my $res = $2;
51 $res = 1 if (!defined $res);
52 $defines{$1} = $res;
56 close IN;
58 if ($debug) {
59 foreach my $i (keys %defines) {
60 print "k: $i v: $defines{$i}\n";
64 open IN, "$opt_p" || die "failed open ${opt_p}";
65 open OUT, ">$opt_o" || die "failed open ${opt_o}";
67 print "parse roken.h.in\n" if ($debug);
69 print OUT "/* This is an OS dependent, generated file */\n";
70 print OUT "\n";
71 print OUT "\n";
72 print OUT "#ifndef __ROKEN_H__\n";
73 print OUT "#define __ROKEN_H__\n";
74 print OUT "\n";
76 @nesting = (1);
78 while (<IN>) {
79 if (m/\s*#ifdef\s+(.*)/) {
80 my $var = $1;
81 if (defined $defines{$var}) {
82 push @nesting, 1;
83 } else {
84 push @nesting, 0;
86 next;
87 } elsif (m/\s*#ifndef\s+(.*)/) {
88 my $var = $1;
89 if (defined $defines{$var}) {
90 push @nesting, 0;
91 } else {
92 push @nesting, 1;
94 next;
95 } elsif (m/\s*#if\s+(.*)/) {
96 my $res = parse_if($1);
97 print "line = $res: $1\n" if ($debug);
98 push @nesting, $res;
99 next;
100 } elsif (m/\s*#elif\s+(.*)/) {
101 my $res = pop @nesting;
102 if ($res gt 0) {
103 $res = -1;
104 } else {
105 my $res = parse_if($1);
107 push @nesting, $res;
108 next;
109 } elsif (m/\s*#else/) {
110 my $var = pop @nesting;
111 $var = !$var;
112 push @nesting, $var;
113 next;
114 } elsif (m/\s*#endif/) {
115 pop @nesting;
116 next;
118 print "line: $_\n" if ($debug);
119 print "nesting dep $#{nesting}\n" if ($debug);
120 my $i = 0, $t = 1;
121 while ($i le $#nesting) {
122 $t = 0 if ($nesting[$i] le 0);
123 print "nesting $i val $nesting[$i] -> $t\n" if ($debug);
124 $i++;
126 if ($t) {
127 print OUT;
131 print OUT "\n";
132 print OUT "#endif /* __ROKEN_H__ */\n";
135 close IN;
137 exit 0;
139 sub parse_if
141 my ($neg, $var);
143 $_ = shift;
145 if (m/^\s*$/) {
146 print "end $_\n" if ($debug);
147 return 1;
148 } elsif (m/^\(([^&]+)\&\&(.*)\)\s*\|\|\s*\(([^&]+)\&\&(.*)\)$/) {
149 print "($1 and $2) or ($3 and $4)\n" if ($debug);
150 return ((parse_if($1) and parse_if($2)) or (parse_if($3) and parse_if($4)));
151 } elsif (m/^([^&]+)\&\&(.*)$/) {
152 print "$1 and $2\n" if ($debug);
153 return parse_if($1) and parse_if($2);
154 } elsif (m/^([^\|]+)\|\|(.*)$/) {
155 print "$1 or $2\n" if ($debug);
156 return (parse_if($1) or parse_if($2));
157 } elsif (m/^\s*(\!)?\s*defined\((\w+)\)/) {
158 ($neg, $var) = ($1, $2);
159 print "def: ${neg}-defined(${var})\n" if ($debug);
160 my $res = defined $defines{$var};
161 if ($neg eq "!") {
162 if ($res) {
163 $res = 0;
164 } else {
165 $res = 1;
168 print "res: $res\n" if ($debug);
169 return $res;
170 } elsif (m/^\s*(\!)?(\w+)/) {
171 ($neg, $var) = ($1, $2);
172 print "var: $neg $var\n" if ($debug);
173 my $res;
174 if (defined $defines{$var}) {
175 $res = $defines{$var};
176 } else {
177 $res = 0;
179 $res = ! $res if ($neg =~ m/!/);
180 print "res: $res\n" if ($debug);
181 return $res;
183 die "failed parse: $_\n";