source: trunk/idl-compiler/c/emitter.c@ 280

Last change on this file since 280 was 280, checked in by cinc, 18 years ago

A load of fixes.

File size: 3.8 KB
Line 
1/* ***** BEGIN LICENSE BLOCK *****
2* Version: CDDL 1.0/LGPL 2.1
3*
4* The contents of this file are subject to the COMMON DEVELOPMENT AND
5* DISTRIBUTION LICENSE (CDDL) Version 1.0 (the "License"); you may not use
6* this file except in compliance with the License. You may obtain a copy of
7* the License at http://www.sun.com/cddl/
8*
9* Software distributed under the License is distributed on an "AS IS" basis,
10* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11* for the specific language governing rights and limitations under the
12* License.
13*
14* The Original Code is "NOM" Netlabs Object Model
15*
16* The Initial Developer of the Original Code is
17* netlabs.org: Chris Wohlgemuth <cinc-ml@netlabs.org>.
18* Portions created by the Initial Developer are Copyright (C) 2007
19* the Initial Developer. All Rights Reserved.
20*
21* Contributor(s):
22*
23* Alternatively, the contents of this file may be used under the terms of
24* the GNU Lesser General Public License Version 2.1 (the "LGPL"), in which
25* case the provisions of the LGPL are applicable instead of those above. If
26* you wish to allow use of your version of this file only under the terms of
27* the LGPL, and not to allow others to use your version of this file under
28* the terms of the CDDL, indicate your decision by deleting the provisions
29* above and replace them with the notice and other provisions required by the
30* LGPL. If you do not delete the provisions above, a recipient may use your
31* version of this file under the terms of any one of the CDDL or the LGPL.
32*
33* ***** END LICENSE BLOCK ***** */
34#include <os2.h>
35#include <stdlib.h>
36#include <string.h>
37
38#include <glib.h>
39#include <glib/gprintf.h>
40
41#define INCL_FILE
42#include "parser.h"
43
44
45/*
46 \param pArray Pointer to the list of parameters.
47 */
48void emitMethodParams(PPARSEINFO pLocalPI, PINTERFACE pif, GPtrArray *pArray)
49{
50 FILE* fh=pLocalPI->outFile;
51 int a;
52
53 for(a=0;a<pArray->len;a++)
54 {
55 int b;
56 gchar *chrType;
57 PMETHODPARAM pm=(PMETHODPARAM)g_ptr_array_index(pArray, a);
58
59 chrType= pm->chrType;
60
61 /* For old IDL files using orbit IDL compiler */
62 if(!strcmp(pm->chrType, "string"))
63 chrType="CORBA_char*";
64 if(!strcmp(pm->chrType, "long"))
65 chrType="CORBA_long";
66
67 switch(pm->uiDirection)
68 {
69 case PARM_DIRECTION_IN:
70 fprintf(fh, " const %s", chrType);
71 break;
72 case PARM_DIRECTION_OUT:
73 fprintf(fh, " %s*", chrType);
74 break;
75 case PARM_DIRECTION_INOUT:
76 fprintf(fh, " %s*", chrType);
77 break;
78 default:
79
80 break;
81 }
82 for(b=0;b<pm->uiStar;b++)
83 fprintf(fh, "*");
84 fprintf(fh, " %s,\n", pm->chrName);
85 }
86}
87
88/*
89 \param pArray Pointer to the list of parameters.
90 */
91void emitMethodParamsNoTypes(PPARSEINFO pLocalPI, PINTERFACE pif, GPtrArray *pArray)
92{
93 FILE* fh=pLocalPI->outFile;
94 int a;
95
96 for(a=0;a<pArray->len;a++)
97 {
98 PMETHODPARAM pm=(PMETHODPARAM)g_ptr_array_index(pArray, a);
99 fprintf(fh, " %s,", pm->chrName);
100 }
101}
102
103/**
104 This function emits the return type of a method. It translates CORBA identifiers
105 into another representation e.g. long->glong. At the moment it's used to be compatible
106 with old source written using the orbit IDL compiler.
107 */
108void emitReturnType(PPARSEINFO pLocalPI, PINTERFACE pif, PMETHOD pm)
109{
110 FILE* fh=pLocalPI->outFile;
111 int b;
112 gchar* chrType;
113
114 chrType= pm->mpReturn.chrType;
115
116 /* Support for orbit IDL files */
117 if(!strcmp(pm->mpReturn.chrType, "long"))
118 chrType="CORBA_long";
119 else if(!strcmp(pm->mpReturn.chrType, "boolean"))
120 chrType="CORBA_boolean";
121
122 fprintf(fh, "%s", chrType);
123 for(b=0;b<pm->mpReturn.uiStar;b++)
124 fprintf(fh, "*");
125}
Note: See TracBrowser for help on using the repository browser.