blob: 3f0d4de029b83f44857549a2aa461a1b4f9b488b [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_codemaker.hxx"
#include <stdio.h>
#include "sal/main.h"
#include "codemaker/typemanager.hxx"
#include "codemaker/generatedtypeset.hxx"
#include "cppuoptions.hxx"
#include "cpputype.hxx"
using namespace rtl;
namespace {
void failed(rtl::OString const & typeName, CppuOptions * options) {
fprintf(stderr, "%s ERROR: %s\n", options->getProgramName().getStr(),
rtl::OString("cannot dump Type '" + typeName + "'").getStr());
exit(99);
}
void produce(
RegistryKey& rTypeKey, bool bIsExtraType, TypeManager const & typeMgr,
codemaker::GeneratedTypeSet & generated, CppuOptions * options)
{
if (!produceType(rTypeKey, bIsExtraType, typeMgr, generated, options)) {
OString typeName = typeMgr.getTypeName(rTypeKey);
failed(typeName, options);
}
}
void produce(
rtl::OString const & typeName, TypeManager const & typeMgr,
codemaker::GeneratedTypeSet & generated, CppuOptions * options)
{
if (!produceType(typeName, typeMgr, generated, options)) {
failed(typeName, options);
}
}
void produceAllTypes(RegistryKey& rTypeKey, bool bIsExtraType,
TypeManager const & typeMgr,
codemaker::GeneratedTypeSet & generated,
CppuOptions* pOptions,
sal_Bool bFullScope)
throw( CannotDumpException )
{
OString typeName = typeMgr.getTypeName(rTypeKey);
produce(rTypeKey, bIsExtraType, typeMgr, generated, pOptions);
RegistryKeyList typeKeys = typeMgr.getTypeKeys(typeName);
RegistryKeyList::const_iterator iter = typeKeys.begin();
RegistryKey key, subKey;
RegistryKeyArray subKeys;
while (iter != typeKeys.end())
{
key = (*iter).first;
if (!(*iter).second && !key.openSubKeys(OUString(), subKeys))
{
for (sal_uInt32 i = 0; i < subKeys.getLength(); i++)
{
subKey = subKeys.getElement(i);
if (bFullScope)
{
produceAllTypes(subKey, (*iter).second, typeMgr,
generated, pOptions, true);
} else
{
produce(subKey, (*iter).second,
typeMgr, generated, pOptions);
}
}
}
++iter;
}
}
void produceAllTypes(const OString& typeName,
TypeManager const & typeMgr,
codemaker::GeneratedTypeSet & generated,
CppuOptions* pOptions,
sal_Bool bFullScope)
throw( CannotDumpException )
{
produce(typeName, typeMgr, generated, pOptions);
RegistryKeyList typeKeys = typeMgr.getTypeKeys(typeName);
RegistryKeyList::const_iterator iter = typeKeys.begin();
RegistryKey key, subKey;
RegistryKeyArray subKeys;
while (iter != typeKeys.end())
{
key = (*iter).first;
if (!(*iter).second && !key.openSubKeys(OUString(), subKeys))
{
for (sal_uInt32 i = 0; i < subKeys.getLength(); i++)
{
subKey = subKeys.getElement(i);
if (bFullScope)
{
produceAllTypes(subKey, (*iter).second, typeMgr,
generated, pOptions, true);
} else
{
produce(subKey, (*iter).second,
typeMgr, generated, pOptions);
}
}
}
++iter;
}
}
}
SAL_IMPLEMENT_MAIN_WITH_ARGS(argc, argv)
{
CppuOptions options;
try
{
if (!options.initOptions(argc, argv))
{
exit(1);
}
}
catch( IllegalArgument& e)
{
fprintf(stderr, "Illegal option: %s\n", e.m_message.getStr());
exit(99);
}
RegistryTypeManager typeMgr;
if (!typeMgr.init(options.getInputFiles(), options.getExtraInputFiles()))
{
fprintf(stderr, "%s : init registries failed, check your registry files.\n", options.getProgramName().getStr());
exit(99);
}
if (options.isValid("-B"))
{
typeMgr.setBase(options.getOption("-B"));
}
codemaker::GeneratedTypeSet generated;
try
{
if (options.isValid("-T"))
{
OString tOption(options.getOption("-T"));
OString typeName, tmpName;
sal_Int32 nIndex = 0;
do
{
typeName = tOption.getToken(0, ';', nIndex);
sal_Int32 nPos = typeName.lastIndexOf( '.' );
tmpName = typeName.copy( nPos != -1 ? nPos+1 : 0 );
if (tmpName == "*")
{
// produce this type and his scope
if (typeName.equals("*"))
{
tmpName = "/";
} else
{
tmpName = typeName.copy(0, typeName.lastIndexOf('.')).replace('.', '/');
if ( tmpName.isEmpty() )
tmpName = "/";
else
tmpName.replace('.', '/');
}
// related to task #116780# the scope is recursively
// generated. bFullScope = true
produceAllTypes(
tmpName, typeMgr, generated, &options, true);
} else
{
// produce only this type
produce(
typeName.replace('.', '/'), typeMgr, generated, &options);
}
} while( nIndex != -1 );
} else
{
// produce all types
produceAllTypes("/", typeMgr, generated, &options, true);
}
// C++ header files generated for the following UNO types are included
// in header files in cppu/inc/com/sun/star/uno (Any.hxx, Reference.hxx,
// Type.h), so it seems best to always generate those C++ header files:
produce("com/sun/star/uno/RuntimeException", typeMgr, generated, &options);
produce("com/sun/star/uno/TypeClass", typeMgr, generated, &options);
produce("com/sun/star/uno/XInterface", typeMgr, generated, &options);
}
catch( CannotDumpException& e)
{
fprintf(stderr, "%s ERROR: %s\n",
options.getProgramName().getStr(),
e.m_message.getStr());
exit(99);
}
return 0;
}