xref: /trunk/main/codemaker/source/idlmaker/idlmaker.cxx (revision cf6516809c57e1bb0a940545cca99cdad54d4ce2)
1ff7655f0SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3ff7655f0SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4ff7655f0SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5ff7655f0SAndrew Rist  * distributed with this work for additional information
6ff7655f0SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7ff7655f0SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8ff7655f0SAndrew Rist  * "License"); you may not use this file except in compliance
9ff7655f0SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
11ff7655f0SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
13ff7655f0SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14ff7655f0SAndrew Rist  * software distributed under the License is distributed on an
15ff7655f0SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16ff7655f0SAndrew Rist  * KIND, either express or implied.  See the License for the
17ff7655f0SAndrew Rist  * specific language governing permissions and limitations
18ff7655f0SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
20ff7655f0SAndrew Rist  *************************************************************/
21ff7655f0SAndrew Rist 
22ff7655f0SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
25cdf0e10cSrcweir #include "precompiled_codemaker.hxx"
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <stdio.h>
28cdf0e10cSrcweir 
29cdf0e10cSrcweir #include "sal/main.h"
30cdf0e10cSrcweir 
31cdf0e10cSrcweir #include <codemaker/typemanager.hxx>
32cdf0e10cSrcweir #include <codemaker/dependency.hxx>
33cdf0e10cSrcweir 
34cdf0e10cSrcweir #include "idloptions.hxx"
35cdf0e10cSrcweir #include "idltype.hxx"
36cdf0e10cSrcweir 
37cdf0e10cSrcweir using namespace rtl;
38cdf0e10cSrcweir 
produceAllTypes(const OString & typeName,TypeManager & typeMgr,TypeDependency & typeDependencies,IdlOptions * pOptions,sal_Bool bFullScope)39cdf0e10cSrcweir sal_Bool produceAllTypes(const OString& typeName,
40cdf0e10cSrcweir                          TypeManager& typeMgr,
41cdf0e10cSrcweir                          TypeDependency& typeDependencies,
42cdf0e10cSrcweir                          IdlOptions* pOptions,
43cdf0e10cSrcweir                          sal_Bool bFullScope)
44cdf0e10cSrcweir     throw( CannotDumpException )
45cdf0e10cSrcweir {
46cdf0e10cSrcweir     if (!produceType(typeName, typeMgr, typeDependencies, pOptions))
47cdf0e10cSrcweir     {
48cdf0e10cSrcweir         fprintf(stderr, "%s ERROR: %s\n",
49cdf0e10cSrcweir                 pOptions->getProgramName().getStr(),
50cdf0e10cSrcweir                 OString("cannot dump Type '" + typeName + "'").getStr());
51cdf0e10cSrcweir         exit(99);
52cdf0e10cSrcweir     }
53cdf0e10cSrcweir 
54cdf0e10cSrcweir     RegistryKey typeKey = typeMgr.getTypeKey(typeName);
55cdf0e10cSrcweir     RegistryKeyNames subKeys;
56cdf0e10cSrcweir 
57cdf0e10cSrcweir     if (typeKey.getKeyNames(OUString(), subKeys))
58cdf0e10cSrcweir         return sal_False;
59cdf0e10cSrcweir 
60cdf0e10cSrcweir     OString tmpName;
61cdf0e10cSrcweir     for (sal_uInt32 i=0; i < subKeys.getLength(); i++)
62cdf0e10cSrcweir     {
63cdf0e10cSrcweir         tmpName = OUStringToOString(subKeys.getElement(i), RTL_TEXTENCODING_UTF8);
64cdf0e10cSrcweir 
65cdf0e10cSrcweir         if (pOptions->isValid("-B"))
66cdf0e10cSrcweir             tmpName = tmpName.copy(tmpName.indexOf('/', 1) + 1);
67cdf0e10cSrcweir         else
68cdf0e10cSrcweir             tmpName = tmpName.copy(1);
69cdf0e10cSrcweir 
70cdf0e10cSrcweir         if (bFullScope)
71cdf0e10cSrcweir         {
72cdf0e10cSrcweir             if (!produceAllTypes(tmpName, typeMgr, typeDependencies, pOptions, sal_True))
73cdf0e10cSrcweir                 return sal_False;
74cdf0e10cSrcweir         } else
75cdf0e10cSrcweir         {
76cdf0e10cSrcweir             if (!produceType(tmpName, typeMgr, typeDependencies, pOptions))
77cdf0e10cSrcweir                 return sal_False;
78cdf0e10cSrcweir         }
79cdf0e10cSrcweir     }
80cdf0e10cSrcweir 
81cdf0e10cSrcweir     return sal_True;
82cdf0e10cSrcweir }
83cdf0e10cSrcweir 
SAL_IMPLEMENT_MAIN_WITH_ARGS(argc,argv)84cdf0e10cSrcweir SAL_IMPLEMENT_MAIN_WITH_ARGS(argc, argv)
85cdf0e10cSrcweir {
86cdf0e10cSrcweir     IdlOptions options;
87cdf0e10cSrcweir 
88cdf0e10cSrcweir     try
89cdf0e10cSrcweir     {
90cdf0e10cSrcweir         if (!options.initOptions(argc, argv))
91cdf0e10cSrcweir         {
92cdf0e10cSrcweir             exit(1);
93cdf0e10cSrcweir         }
94cdf0e10cSrcweir     }
95cdf0e10cSrcweir     catch( IllegalArgument& e)
96cdf0e10cSrcweir     {
97cdf0e10cSrcweir         fprintf(stderr, "Illegal option: %s\n", e.m_message.getStr());
98cdf0e10cSrcweir         exit(99);
99cdf0e10cSrcweir     }
100cdf0e10cSrcweir 
101cdf0e10cSrcweir     RegistryTypeManager typeMgr;
102cdf0e10cSrcweir     TypeDependency      typeDependencies;
103cdf0e10cSrcweir 
104cdf0e10cSrcweir     if (!typeMgr.init(!options.isValid("-T"), options.getInputFiles()))
105cdf0e10cSrcweir     {
106cdf0e10cSrcweir         fprintf(stderr, "%s : init registries failed, check your registry files.\n", options.getProgramName().getStr());
107cdf0e10cSrcweir         exit(99);
108cdf0e10cSrcweir     }
109cdf0e10cSrcweir 
110cdf0e10cSrcweir     if (options.isValid("-B"))
111cdf0e10cSrcweir     {
112cdf0e10cSrcweir         typeMgr.setBase(options.getOption("-B"));
113cdf0e10cSrcweir     }
114cdf0e10cSrcweir 
115cdf0e10cSrcweir     try
116cdf0e10cSrcweir     {
117cdf0e10cSrcweir         if (options.isValid("-T"))
118cdf0e10cSrcweir         {
119cdf0e10cSrcweir             OString tOption(options.getOption("-T"));
120cdf0e10cSrcweir 
121cdf0e10cSrcweir             OString typeName, tmpName;
122cdf0e10cSrcweir             sal_Bool ret = sal_False;
123cdf0e10cSrcweir             sal_Int32 nIndex = 0;
124cdf0e10cSrcweir             do
125cdf0e10cSrcweir             {
126cdf0e10cSrcweir                 typeName = tOption.getToken(0, ';', nIndex);
127cdf0e10cSrcweir 
128cdf0e10cSrcweir                 sal_Int32 nPos = typeName.lastIndexOf( '.' );
129cdf0e10cSrcweir                 tmpName = typeName.copy( nPos != -1 ? nPos+1 : 0 );
130cdf0e10cSrcweir                 if (tmpName == "*")
131cdf0e10cSrcweir                 {
132cdf0e10cSrcweir                     // produce this type and his scope, but the scope is not recursively  generated.
133cdf0e10cSrcweir                     if (typeName.equals("*"))
134cdf0e10cSrcweir                     {
135cdf0e10cSrcweir                         tmpName = "/";
136cdf0e10cSrcweir                     } else
137cdf0e10cSrcweir                     {
138cdf0e10cSrcweir                         tmpName = typeName.copy(0, typeName.lastIndexOf('.')).replace('.', '/');
139*9d8e7fbaSHerbert Dürr                         if ( tmpName.isEmpty() )
140cdf0e10cSrcweir                             tmpName = "/";
141cdf0e10cSrcweir                         else
142cdf0e10cSrcweir                             tmpName.replace('.', '/');
143cdf0e10cSrcweir                     }
144cdf0e10cSrcweir                     ret = produceAllTypes(tmpName, typeMgr, typeDependencies, &options, sal_False);
145cdf0e10cSrcweir                 } else
146cdf0e10cSrcweir                 {
147cdf0e10cSrcweir                     // produce only this type
148cdf0e10cSrcweir                     ret = produceType(typeName.replace('.', '/'), typeMgr, typeDependencies, &options);
149cdf0e10cSrcweir                 }
150cdf0e10cSrcweir 
151cdf0e10cSrcweir                 if (!ret)
152cdf0e10cSrcweir                 {
153cdf0e10cSrcweir                     fprintf(stderr, "%s ERROR: %s\n",
154cdf0e10cSrcweir                             options.getProgramName().getStr(),
155cdf0e10cSrcweir                             OString("cannot dump Type '" + typeName + "'").getStr());
156cdf0e10cSrcweir                     exit(99);
157cdf0e10cSrcweir                 }
158cdf0e10cSrcweir             } while( nIndex != -1 );
159cdf0e10cSrcweir         } else
160cdf0e10cSrcweir         {
161cdf0e10cSrcweir             // produce all types
162cdf0e10cSrcweir             if (!produceAllTypes("/", typeMgr, typeDependencies, &options, sal_True))
163cdf0e10cSrcweir             {
164cdf0e10cSrcweir                 fprintf(stderr, "%s ERROR: %s\n",
165cdf0e10cSrcweir                         options.getProgramName().getStr(),
166cdf0e10cSrcweir                         "an error occurs while dumping all types.");
167cdf0e10cSrcweir                 exit(99);
168cdf0e10cSrcweir             }
169cdf0e10cSrcweir         }
170cdf0e10cSrcweir     }
171cdf0e10cSrcweir     catch( CannotDumpException& e)
172cdf0e10cSrcweir     {
173cdf0e10cSrcweir         fprintf(stderr, "%s ERROR: %s\n",
174cdf0e10cSrcweir                 options.getProgramName().getStr(),
175cdf0e10cSrcweir                 e.m_message.getStr());
176cdf0e10cSrcweir         exit(99);
177cdf0e10cSrcweir     }
178cdf0e10cSrcweir 
179cdf0e10cSrcweir     return 0;
180cdf0e10cSrcweir }
181