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
10ff7655f0SAndrew Rist  *
11ff7655f0SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12ff7655f0SAndrew Rist  *
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.
19ff7655f0SAndrew Rist  *
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/generatedtypeset.hxx"
33cdf0e10cSrcweir 
34cdf0e10cSrcweir #include "cppuoptions.hxx"
35cdf0e10cSrcweir #include "cpputype.hxx"
36cdf0e10cSrcweir 
37cdf0e10cSrcweir using namespace rtl;
38cdf0e10cSrcweir 
39cdf0e10cSrcweir namespace {
40cdf0e10cSrcweir 
failed(rtl::OString const & typeName,CppuOptions * options)41cdf0e10cSrcweir void failed(rtl::OString const & typeName, CppuOptions * options) {
42cdf0e10cSrcweir     fprintf(stderr, "%s ERROR: %s\n", options->getProgramName().getStr(),
43cdf0e10cSrcweir             rtl::OString("cannot dump Type '" + typeName + "'").getStr());
44cdf0e10cSrcweir     exit(99);
45cdf0e10cSrcweir }
46cdf0e10cSrcweir 
produce(RegistryKey & rTypeKey,bool bIsExtraType,TypeManager const & typeMgr,codemaker::GeneratedTypeSet & generated,CppuOptions * options)47cdf0e10cSrcweir void produce(
48cdf0e10cSrcweir     RegistryKey& rTypeKey, bool bIsExtraType, TypeManager const & typeMgr,
49cdf0e10cSrcweir     codemaker::GeneratedTypeSet & generated, CppuOptions * options)
50cdf0e10cSrcweir {
51cdf0e10cSrcweir     if (!produceType(rTypeKey, bIsExtraType, typeMgr, generated, options)) {
52cdf0e10cSrcweir         OString typeName = typeMgr.getTypeName(rTypeKey);
53cdf0e10cSrcweir         failed(typeName, options);
54cdf0e10cSrcweir     }
55cdf0e10cSrcweir }
56cdf0e10cSrcweir 
produce(rtl::OString const & typeName,TypeManager const & typeMgr,codemaker::GeneratedTypeSet & generated,CppuOptions * options)57cdf0e10cSrcweir void produce(
58cdf0e10cSrcweir     rtl::OString const & typeName, TypeManager const & typeMgr,
59cdf0e10cSrcweir     codemaker::GeneratedTypeSet & generated, CppuOptions * options)
60cdf0e10cSrcweir {
61cdf0e10cSrcweir     if (!produceType(typeName, typeMgr, generated, options)) {
62cdf0e10cSrcweir         failed(typeName, options);
63cdf0e10cSrcweir     }
64cdf0e10cSrcweir }
65cdf0e10cSrcweir 
produceAllTypes(RegistryKey & rTypeKey,bool bIsExtraType,TypeManager const & typeMgr,codemaker::GeneratedTypeSet & generated,CppuOptions * pOptions,sal_Bool bFullScope)66cdf0e10cSrcweir void produceAllTypes(RegistryKey& rTypeKey, bool bIsExtraType,
67cdf0e10cSrcweir 						 TypeManager const & typeMgr,
68cdf0e10cSrcweir                          codemaker::GeneratedTypeSet & generated,
69cdf0e10cSrcweir 						 CppuOptions* pOptions,
70cdf0e10cSrcweir 						 sal_Bool bFullScope)
71cdf0e10cSrcweir 	throw( CannotDumpException )
72cdf0e10cSrcweir {
73cdf0e10cSrcweir     OString typeName = typeMgr.getTypeName(rTypeKey);
74cdf0e10cSrcweir 
75cdf0e10cSrcweir     produce(rTypeKey, bIsExtraType, typeMgr, generated, pOptions);
76cdf0e10cSrcweir 
77cdf0e10cSrcweir     RegistryKeyList typeKeys = typeMgr.getTypeKeys(typeName);
78cdf0e10cSrcweir 	RegistryKeyList::const_iterator iter = typeKeys.begin();
79cdf0e10cSrcweir     RegistryKey key, subKey;
80cdf0e10cSrcweir     RegistryKeyArray subKeys;
81cdf0e10cSrcweir 
82cdf0e10cSrcweir 	while (iter != typeKeys.end())
83cdf0e10cSrcweir 	{
84cdf0e10cSrcweir         key = (*iter).first;
85cdf0e10cSrcweir 
86cdf0e10cSrcweir         if (!(*iter).second  && !key.openSubKeys(OUString(), subKeys))
87cdf0e10cSrcweir         {
88cdf0e10cSrcweir             for (sal_uInt32 i = 0; i < subKeys.getLength(); i++)
89cdf0e10cSrcweir             {
90cdf0e10cSrcweir                 subKey = subKeys.getElement(i);
91cdf0e10cSrcweir                 if (bFullScope)
92cdf0e10cSrcweir                 {
93cdf0e10cSrcweir                     produceAllTypes(subKey, (*iter).second, typeMgr,
94cdf0e10cSrcweir                                     generated, pOptions, true);
95cdf0e10cSrcweir                 } else
96cdf0e10cSrcweir                 {
97cdf0e10cSrcweir                     produce(subKey, (*iter).second,
98cdf0e10cSrcweir                             typeMgr, generated, pOptions);
99cdf0e10cSrcweir                 }
100cdf0e10cSrcweir             }
101cdf0e10cSrcweir         }
102cdf0e10cSrcweir 
103cdf0e10cSrcweir         ++iter;
104cdf0e10cSrcweir 	}
105cdf0e10cSrcweir }
106cdf0e10cSrcweir 
produceAllTypes(const OString & typeName,TypeManager const & typeMgr,codemaker::GeneratedTypeSet & generated,CppuOptions * pOptions,sal_Bool bFullScope)107cdf0e10cSrcweir void produceAllTypes(const OString& typeName,
108cdf0e10cSrcweir                      TypeManager const & typeMgr,
109cdf0e10cSrcweir                      codemaker::GeneratedTypeSet & generated,
110cdf0e10cSrcweir                      CppuOptions* pOptions,
111cdf0e10cSrcweir                      sal_Bool bFullScope)
112cdf0e10cSrcweir 	throw( CannotDumpException )
113cdf0e10cSrcweir {
114cdf0e10cSrcweir     produce(typeName, typeMgr, generated, pOptions);
115cdf0e10cSrcweir 
116cdf0e10cSrcweir     RegistryKeyList typeKeys = typeMgr.getTypeKeys(typeName);
117cdf0e10cSrcweir 	RegistryKeyList::const_iterator iter = typeKeys.begin();
118cdf0e10cSrcweir     RegistryKey key, subKey;
119cdf0e10cSrcweir     RegistryKeyArray subKeys;
120cdf0e10cSrcweir 
121cdf0e10cSrcweir 	while (iter != typeKeys.end())
122cdf0e10cSrcweir 	{
123cdf0e10cSrcweir         key = (*iter).first;
124cdf0e10cSrcweir         if (!(*iter).second  && !key.openSubKeys(OUString(), subKeys))
125cdf0e10cSrcweir         {
126cdf0e10cSrcweir             for (sal_uInt32 i = 0; i < subKeys.getLength(); i++)
127cdf0e10cSrcweir             {
128cdf0e10cSrcweir                 subKey = subKeys.getElement(i);
129cdf0e10cSrcweir                 if (bFullScope)
130cdf0e10cSrcweir                 {
131cdf0e10cSrcweir                     produceAllTypes(subKey, (*iter).second, typeMgr,
132cdf0e10cSrcweir                                     generated, pOptions, true);
133cdf0e10cSrcweir                 } else
134cdf0e10cSrcweir                 {
135cdf0e10cSrcweir                     produce(subKey, (*iter).second,
136cdf0e10cSrcweir                             typeMgr, generated, pOptions);
137cdf0e10cSrcweir                 }
138cdf0e10cSrcweir             }
139cdf0e10cSrcweir         }
140cdf0e10cSrcweir 
141cdf0e10cSrcweir         ++iter;
142cdf0e10cSrcweir 	}
143cdf0e10cSrcweir }
144cdf0e10cSrcweir 
145cdf0e10cSrcweir }
146cdf0e10cSrcweir 
SAL_IMPLEMENT_MAIN_WITH_ARGS(argc,argv)147cdf0e10cSrcweir SAL_IMPLEMENT_MAIN_WITH_ARGS(argc, argv)
148cdf0e10cSrcweir {
149cdf0e10cSrcweir 	CppuOptions options;
150cdf0e10cSrcweir 
151cdf0e10cSrcweir 	try
152cdf0e10cSrcweir 	{
153cdf0e10cSrcweir 		if (!options.initOptions(argc, argv))
154cdf0e10cSrcweir 		{
155cdf0e10cSrcweir 			exit(1);
156cdf0e10cSrcweir 		}
157cdf0e10cSrcweir 	}
158cdf0e10cSrcweir 	catch( IllegalArgument& e)
159cdf0e10cSrcweir 	{
160cdf0e10cSrcweir 		fprintf(stderr, "Illegal option: %s\n", e.m_message.getStr());
161cdf0e10cSrcweir 		exit(99);
162cdf0e10cSrcweir 	}
163cdf0e10cSrcweir 
164cdf0e10cSrcweir 	RegistryTypeManager typeMgr;
165cdf0e10cSrcweir 
166cdf0e10cSrcweir 	if (!typeMgr.init(options.getInputFiles(), options.getExtraInputFiles()))
167cdf0e10cSrcweir 	{
168cdf0e10cSrcweir 		fprintf(stderr, "%s : init registries failed, check your registry files.\n", options.getProgramName().getStr());
169cdf0e10cSrcweir 		exit(99);
170cdf0e10cSrcweir 	}
171cdf0e10cSrcweir 
172cdf0e10cSrcweir 	if (options.isValid("-B"))
173cdf0e10cSrcweir 	{
174cdf0e10cSrcweir 		typeMgr.setBase(options.getOption("-B"));
175cdf0e10cSrcweir 	}
176cdf0e10cSrcweir 
177cdf0e10cSrcweir     codemaker::GeneratedTypeSet generated;
178cdf0e10cSrcweir 	try
179cdf0e10cSrcweir 	{
180cdf0e10cSrcweir 		if (options.isValid("-T"))
181cdf0e10cSrcweir 		{
182cdf0e10cSrcweir 			OString tOption(options.getOption("-T"));
183cdf0e10cSrcweir 
184cdf0e10cSrcweir 			OString typeName, tmpName;
185cdf0e10cSrcweir             sal_Int32 nIndex = 0;
186cdf0e10cSrcweir             do
187cdf0e10cSrcweir 			{
188cdf0e10cSrcweir 				typeName = tOption.getToken(0, ';', nIndex);
189cdf0e10cSrcweir 
190cdf0e10cSrcweir                 sal_Int32 nPos = typeName.lastIndexOf( '.' );
191cdf0e10cSrcweir                 tmpName = typeName.copy( nPos != -1 ? nPos+1 : 0 );
192cdf0e10cSrcweir 				if (tmpName == "*")
193cdf0e10cSrcweir 				{
194cdf0e10cSrcweir 					// produce this type and his scope
195cdf0e10cSrcweir 					if (typeName.equals("*"))
196cdf0e10cSrcweir 					{
197cdf0e10cSrcweir 						tmpName = "/";
198cdf0e10cSrcweir 					} else
199cdf0e10cSrcweir 					{
200cdf0e10cSrcweir 						tmpName = typeName.copy(0, typeName.lastIndexOf('.')).replace('.', '/');
201*9d8e7fbaSHerbert Dürr 						if ( tmpName.isEmpty() )
202cdf0e10cSrcweir 							tmpName = "/";
203cdf0e10cSrcweir 						else
204cdf0e10cSrcweir 							tmpName.replace('.', '/');
205cdf0e10cSrcweir 					}
206cdf0e10cSrcweir                     // related to task #116780# the scope is recursively
207cdf0e10cSrcweir                     // generated.  bFullScope = true
208cdf0e10cSrcweir 					produceAllTypes(
209cdf0e10cSrcweir                         tmpName, typeMgr, generated, &options, true);
210cdf0e10cSrcweir 				} else
211cdf0e10cSrcweir 				{
212cdf0e10cSrcweir 					// produce only this type
213cdf0e10cSrcweir                     produce(
214cdf0e10cSrcweir                         typeName.replace('.', '/'), typeMgr, generated, &options);
215cdf0e10cSrcweir 				}
216cdf0e10cSrcweir 			} while( nIndex != -1 );
217cdf0e10cSrcweir 		} else
218cdf0e10cSrcweir 		{
219cdf0e10cSrcweir 			// produce all types
220cdf0e10cSrcweir 			produceAllTypes("/", typeMgr, generated, &options, true);
221cdf0e10cSrcweir 		}
222cdf0e10cSrcweir         // C++ header files generated for the following UNO types are included
223cdf0e10cSrcweir         // in header files in cppu/inc/com/sun/star/uno (Any.hxx, Reference.hxx,
224cdf0e10cSrcweir         // Type.h), so it seems best to always generate those C++ header files:
225cdf0e10cSrcweir         produce("com/sun/star/uno/RuntimeException", typeMgr, generated, &options);
226cdf0e10cSrcweir         produce("com/sun/star/uno/TypeClass", typeMgr, generated, &options);
227cdf0e10cSrcweir         produce("com/sun/star/uno/XInterface", typeMgr, generated, &options);
228cdf0e10cSrcweir 	}
229cdf0e10cSrcweir 	catch( CannotDumpException& e)
230cdf0e10cSrcweir 	{
231cdf0e10cSrcweir 		fprintf(stderr, "%s ERROR: %s\n",
232cdf0e10cSrcweir 				options.getProgramName().getStr(),
233cdf0e10cSrcweir 				e.m_message.getStr());
234cdf0e10cSrcweir 		exit(99);
235cdf0e10cSrcweir 	}
236cdf0e10cSrcweir 
237cdf0e10cSrcweir 	return 0;
238cdf0e10cSrcweir }
239cdf0e10cSrcweir 
240cdf0e10cSrcweir 
241