pyldb: avoid segfault when adding an element with no name
[kai/samba-autobuild/.git] / pidl / lib / Parse / Pidl / Samba3 / Template.pm
1 ###################################################
2 # server template function generator
3 # Copyright tridge@samba.org 2003
4 # released under the GNU GPL
5
6 package Parse::Pidl::Samba3::Template;
7
8 use vars qw($VERSION);
9 $VERSION = '0.01';
10
11 use Parse::Pidl::Util qw(genpad);
12
13 use strict;
14
15 my($res);
16
17 #####################################################################
18 # produce boilerplate code for a interface
19 sub Template($)
20 {
21         my($interface) = shift;
22         my($data) = $interface->{DATA};
23         my $name = $interface->{NAME};
24
25         $res .=
26 "/*
27    Unix SMB/CIFS implementation.
28
29    endpoint server for the $name pipe
30
31    Copyright (C) YOUR NAME HERE YEAR
32
33    This program is free software; you can redistribute it and/or modify
34    it under the terms of the GNU General Public License as published by
35    the Free Software Foundation; either version 3 of the License, or
36    (at your option) any later version.
37
38    This program is distributed in the hope that it will be useful,
39    but WITHOUT ANY WARRANTY; without even the implied warranty of
40    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
41    GNU General Public License for more details.
42
43    You should have received a copy of the GNU General Public License
44    along with this program.  If not, see <http://www.gnu.org/licenses/>.
45 */
46
47 #include \"includes.h\"
48 #include \"ntdomain.h\"
49 #include \"../librpc/gen_ndr/srv_$name.h\"
50
51 ";
52
53         foreach my $d (@{$data}) {
54                 if ($d->{TYPE} eq "FUNCTION") {
55                         my $fname = $d->{NAME};
56                         my $pad = genpad("$d->{RETURN_TYPE} _$fname");
57                         $res .=
58 "
59 /****************************************************************
60  _$fname
61 ****************************************************************/
62
63 $d->{RETURN_TYPE} _$fname(struct pipes_struct *p,
64 $pad"."struct $fname *r)
65 {
66 ";
67
68         $res .= "\tp->fault_state = DCERPC_FAULT_OP_RNG_ERROR;\n";
69         if ($d->{RETURN_TYPE} eq "NTSTATUS") {
70                 $res .= "\treturn NT_STATUS_NOT_IMPLEMENTED;\n";
71         } elsif ($d->{RETURN_TYPE} eq "WERROR") {
72                 $res .= "\treturn WERR_NOT_SUPPORTED;\n";
73         } elsif ($d->{RETURN_TYPE} eq "HRESULT") {
74                 $res .= "\treturn HRES_ERROR_NOT_SUPPORTED;\n";
75         }
76
77         $res .= "}
78
79 ";
80                 }
81         }
82 }
83
84
85 #####################################################################
86 # parse a parsed IDL structure back into an IDL file
87 sub Parse($)
88 {
89         my($idl) = shift;
90         $res = "";
91         foreach my $x (@{$idl}) {
92                 ($x->{TYPE} eq "INTERFACE") &&
93                     Template($x);
94         }
95         return $res;
96 }
97
98 1;