Files
loongoffice/codemaker/source/codemaker/codemaker.cxx
Oliver Bolte 8dad2f14f3 INTEGRATION: CWS pchfix02 (1.5.34); FILE MERGED
2006/09/01 17:19:20 kaib 1.5.34.1: #i68856# Added header markers and pch files
2006-09-17 02:33:54 +00:00

197 lines
6.5 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: codemaker.cxx,v $
*
* $Revision: 1.6 $
*
* last change: $Author: obo $ $Date: 2006-09-17 03:33:54 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_codemaker.hxx"
#include "sal/config.h"
#include "codemaker/codemaker.hxx"
#include "codemaker/options.hxx"
#include "codemaker/typemanager.hxx"
#include "codemaker/unotype.hxx"
#include "osl/diagnose.h"
#include "registry/reader.hxx"
#include "registry/types.h"
#include "rtl/strbuf.h"
#include "rtl/string.h"
#include "rtl/string.hxx"
#include "rtl/ustring.hxx"
#include "sal/types.h"
#include <vector>
namespace {
void checkNoTypeArguments(std::vector< rtl::OString > const & arguments) {
if (!arguments.empty()) {
throw CannotDumpException(
rtl::OString(RTL_CONSTASCII_STRINGPARAM("Bad type information")));
//TODO
}
}
}
namespace codemaker {
rtl::OString convertString(rtl::OUString const & string) {
rtl::OString s;
if (!string.convertToString(
&s, RTL_TEXTENCODING_UTF8,
(RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
| RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
{
throw CannotDumpException(
rtl::OString(
RTL_CONSTASCII_STRINGPARAM(
"Failure converting string from UTF-16 to UTF-8")));
}
return s;
}
rtl::OString errorMsg(rtl::OString const & desc, rtl::OString const & type) {
rtl::OStringBuffer msg(128);
msg.append(desc);
msg.append(type);
return msg.makeStringAndClear();
}
codemaker::UnoType::Sort decomposeAndResolve(
TypeManager const & manager, rtl::OString const & type,
bool resolveTypedefs, bool allowVoid, bool allowExtraEntities,
RTTypeClass * typeClass, rtl::OString * name, sal_Int32 * rank,
std::vector< rtl::OString > * arguments)
{
OSL_ASSERT(typeClass != 0 && name != 0 && rank != 0 && arguments != 0);
*rank = 0;
for (rtl::OString t(type);;) {
sal_Int32 n = 0;
*name = codemaker::UnoType::decompose(t, &n, arguments);
if (n > SAL_MAX_INT32 - *rank) {
throw CannotDumpException(
errorMsg(rtl::OString(
RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
type));
//TODO
}
*rank += n;
if (n > 0) {
allowVoid = false;
allowExtraEntities = false;
}
codemaker::UnoType::Sort sort = codemaker::UnoType::getSort(*name);
switch (sort) {
case codemaker::UnoType::SORT_VOID:
if (!allowVoid) {
throw CannotDumpException(
errorMsg(rtl::OString(
RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
type));
//TODO
}
default:
checkNoTypeArguments(*arguments);
*typeClass = RT_TYPE_INVALID;
return sort;
case codemaker::UnoType::SORT_COMPLEX:
typereg::Reader reader(manager.getTypeReader(*name));
*typeClass = reader.getTypeClass();
switch (*typeClass) {
case RT_TYPE_ENUM:
case RT_TYPE_INTERFACE:
checkNoTypeArguments(*arguments);
return sort;
case RT_TYPE_STRUCT:
if (!(allowExtraEntities && arguments->empty())
&& (arguments->size() > SAL_MAX_UINT16
|| (static_cast< sal_uInt16 >(arguments->size())
!= reader.getReferenceCount())))
{
throw CannotDumpException(
errorMsg(rtl::OString(
RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
type));
//TODO
}
return sort;
case RT_TYPE_MODULE:
case RT_TYPE_EXCEPTION:
case RT_TYPE_SERVICE:
case RT_TYPE_SINGLETON:
case RT_TYPE_CONSTANTS:
if (!allowExtraEntities) {
throw CannotDumpException(
errorMsg(rtl::OString(
RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
type));
//TODO
}
checkNoTypeArguments(*arguments);
//TODO: check reader for consistency
return sort;
case RT_TYPE_TYPEDEF:
checkNoTypeArguments(*arguments);
if (reader.getSuperTypeCount() == 1
&& reader.getFieldCount() == 0
&& reader.getMethodCount() == 0
&& reader.getReferenceCount() == 0)
{
if (resolveTypedefs) {
t = convertString(reader.getSuperTypeName(0));
continue;
} else {
return sort;
}
}
default:
throw CannotDumpException(
errorMsg(rtl::OString(
RTL_CONSTASCII_STRINGPARAM("Bad type information: ")),
type));
//TODO
}
}
}
}
}