2 ################################################################################
4 # apicheck.pl -- generate C source for automated API check
6 ################################################################################
10 # $Date: 2006/07/25 19:14:07 +0200 $
12 ################################################################################
14 # Version 3.x, Copyright (C) 2004-2006, Marcus Holland-Moritz.
15 # Version 2.x, Copyright (C) 2001, Paul Marquess.
16 # Version 1.x, Copyright (C) 1999, Kenneth Albanowski.
18 # This program is free software; you can redistribute it and/or
19 # modify it under the same terms as Perl itself.
21 ################################################################################
24 require 'parts/ppptools.pl';
28 open OUT, ">$file" or die "$file: $!\n";
34 my @f = parse_embed(qw( parts/embed.fnc parts/apidoc.fnc ));
36 my %todo = %{&parse_todo};
89 ORIGMARK => ['dORIGMARK;'],
90 POPpx => ['STRLEN n_a;'],
91 POPpbytex => ['STRLEN n_a;'],
100 UNDERBAR => ['dUNDERBAR;'],
101 XCPT_TRY_START => ['dXCPT;'],
102 XCPT_TRY_END => ['dXCPT;'],
103 XCPT_CATCH => ['dXCPT;'],
104 XCPT_RETHROW => ['dXCPT;'],
108 map { ($_ => 1) } qw(
123 * !!!!!!! DO NOT EDIT THIS FILE !!!!!!!
124 * This file is built by $0.
125 * Any changes made here will be lost!
134 #ifdef DPPP_APICHECK_NO_PPPORT_H
136 /* This is just to avoid too many baseline failures with perls < 5.6.0 */
139 # define dTHX extern int Perl___notused
145 #define NEED_grok_bin
146 #define NEED_grok_hex
147 #define NEED_grok_number
148 #define NEED_grok_numeric_radix
149 #define NEED_grok_oct
150 #define NEED_my_snprintf
151 #define NEED_my_strlcat
152 #define NEED_my_strlcpy
153 #define NEED_newCONSTSUB
154 #define NEED_newRV_noinc
155 #define NEED_sv_2pv_nolen
156 #define NEED_sv_2pvbyte
157 #define NEED_sv_catpvf_mg
158 #define NEED_sv_catpvf_mg_nocontext
159 #define NEED_sv_setpvf_mg
160 #define NEED_sv_setpvf_mg_nocontext
161 #define NEED_vnewSVpvf
169 static char *VARarg2;
170 static double VARarg3;
175 my %want = map { ($_ => 0) } @ARGV;
176 @f = grep { exists $want{$_->{name}} } @f;
177 for (@f) { $want{$_->{name}}++ }
179 die "nothing found for '$_'\n" unless $want{$_};
185 $ignore{$f->{name}} and next;
186 $f->{flags}{A} or next; # only public API members
188 $ignore{$f->{name}} = 1; # ignore duplicates
190 my $Perl_ = $f->{flags}{p} ? 'Perl_' : '';
199 for $ca (@{$f->{args}}) {
203 push @arg, qw(VARarg1 VARarg2 VARarg3);
206 my($n, $p, $d) = $a =~ /^ (\w+(?:\s+\w+)*)\s* # type name => $n
207 (\**) # pointer => $p
208 (?:\s*const\s*)? # const
209 ((?:\[[^\]]*\])*) # dimension => $d
211 or die "$0 - cannot parse argument: [$a]\n";
212 if (exists $amap{$n}) {
213 push @arg, $amap{$n};
216 $n = $tmap{$n} || $n;
217 if ($n eq 'const char' and $p eq '*' and !$f->{flags}{f}) {
221 my $v = 'arg' . $i++;
223 $stack .= " static $n $p$v$d;\n";
227 unless ($f->{flags}{n} || $f->{flags}{'m'}) {
228 $stack = " dTHX;\n$stack";
229 $aTHX = @arg ? 'aTHX_ ' : 'aTHX';
232 if ($stack{$f->{name}}) {
234 for (@{$stack{$f->{name}}}) {
240 my $args = join ', ', @arg;
241 my $rvt = $f->{ret} || 'void';
244 $ret = $castvoid{$f->{name}} ? '(void) ' : '';
247 $stack .= " $rvt rval;\n";
248 $ret = $ignorerv{$f->{name}} ? '(void) ' : "rval = ";
250 my $aTHX_args = "$aTHX$args";
252 unless ($f->{flags}{'m'} and @arg == 0) {
254 $aTHX_args = "($aTHX_args)";
258 /******************************************************************************
262 ******************************************************************************/
266 if ($todo{$f->{name}}) {
267 my($ver,$sub) = $todo{$f->{name}} =~ /^5\.(\d{3})(\d{3})$/ or die;
271 if ($ver < 6 && $sub > 0) {
272 $sub =~ s/0$// or die;
274 print OUT "#if PERL_VERSION > $ver || (PERL_VERSION == $ver && PERL_SUBVERSION >= $sub) /* TODO */\n";
278 ? "$Perl_$f->{name}$aTHX_args"
281 $f->{cond} and print OUT "#if $f->{cond}\n";
284 void _DPPP_test_$f->{name} (void)
298 $ret$Perl_$f->{name}$aTHX_args;
304 $f->{cond} and print OUT "#endif\n";
305 $todo{$f->{name}} and print OUT "#endif\n";