4 for my $opname (@order) {
5 my ($op) = $ops{$opname};
7 if (!$op->{OPTIMIZABLE} || $op->{UNIMPLEMENTED}) {
8 print "case $opname:\n";
9 print " NOT_REACHED ();\n\n";
15 for my $arg (@{$op->{ARGS}}) {
17 my ($name) = $arg->{NAME};
18 my ($type) = $arg->{TYPE};
19 my ($ctype) = c_type ($type);
20 my ($idx) = $arg->{IDX};
21 if (!defined ($idx)) {
22 my ($func) = "get_$type->{ATOM}_arg";
23 push (@decls, "${ctype}arg_$name = $func (node, $arg_idx)");
25 my ($decl) = "size_t arg_$idx = node->arg_cnt";
26 $decl .= " - $arg_idx" if $arg_idx;
29 push (@decls, "${ctype}*arg_$name = "
30 . "get_$type->{ATOM}_args "
31 . " (node, $arg_idx, arg_$idx, e)");
36 my ($sysmis_cond) = make_sysmis_decl ($op, "node->min_valid");
37 push (@decls, $sysmis_cond) if defined $sysmis_cond;
40 for my $arg (@{$op->{ARGS}}) {
41 push (@args, "arg_$arg->{NAME}");
42 if (defined $arg->{IDX}) {
43 my ($idx) = "arg_$arg->{IDX}";
44 $idx .= " / $arg->{TIMES}" if $arg->{TIMES} != 1;
48 for my $aux (@{$op->{AUX}}) {
49 my ($type) = $aux->{TYPE};
50 if ($type->{ROLE} eq 'leaf') {
51 my ($func) = "get_$type->{ATOM}_arg";
52 push (@args, "$func (node, $arg_idx)");
54 } elsif ($type->{ROLE} eq 'fixed') {
55 push (@args, $type->{FIXED_VALUE});
61 my ($result) = "eval_$op->{OPNAME} (" . join (', ', @args) . ")";
62 if (@decls && defined ($sysmis_cond)) {
63 my ($miss_ret) = $op->{RETURNS}{MISSING_VALUE};
64 push (@decls, c_type ($op->{RETURNS}) . "result = "
65 . "force_sysmis ? $miss_ret : $result");
69 print "case $opname:\n";
70 my ($alloc_func) = "expr_allocate_$op->{RETURNS}{NAME}";
73 print " $_;\n" foreach @decls;
74 print " return $alloc_func (e, $result);\n";
77 print " return $alloc_func (e, $result);\n";