summaryrefslogtreecommitdiff
path: root/cppuhelper/source
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2013-02-25 15:31:05 +0100
committerStephan Bergmann <sbergman@redhat.com>2013-02-25 16:24:44 +0100
commit320571bf701a092d0f2d15fd4589ae271802a03f (patch)
tree6b6fa9fd7d5c259037d4b9a976adb023e5ea6332 /cppuhelper/source
parentb324cbefb0b92dc7a4813dca88dc8dbd9641cc0b (diff)
WIP: Experimental new binary type.rdb format
Move unoidl functionality into a module of its own, as a prerequisite to use it in codemaker etc. (This is intended to ultimately remove modules store and registry, modulo backwards compatibility constraints.) Change-Id: If5274cbd3a595951e6cf7a9664bc542f01833f38
Diffstat (limited to 'cppuhelper/source')
-rw-r--r--cppuhelper/source/typedescriptionprovider.cxx598
-rw-r--r--cppuhelper/source/unoidl.cxx63
-rw-r--r--cppuhelper/source/unoidlprovider.cxx1363
-rw-r--r--cppuhelper/source/unoidlprovider.hxx54
4 files changed, 331 insertions, 1747 deletions
diff --git a/cppuhelper/source/typedescriptionprovider.cxx b/cppuhelper/source/typedescriptionprovider.cxx
index bf77491ea991..7dbe5e590b88 100644
--- a/cppuhelper/source/typedescriptionprovider.cxx
+++ b/cppuhelper/source/typedescriptionprovider.cxx
@@ -49,16 +49,16 @@
#include "com/sun/star/uno/XInterface.hpp"
#include "cppuhelper/compbase2.hxx"
#include "cppuhelper/implbase1.hxx"
-#include "cppuhelper/unoidl.hxx"
#include "osl/file.hxx"
#include "osl/mutex.hxx"
#include "rtl/ref.hxx"
#include "rtl/ustring.hxx"
#include "sal/types.h"
+#include "unoidl/unoidl.hxx"
+#include "unoidl/unoidlprovider.hxx"
#include "paths.hxx"
#include "typedescriptionprovider.hxx"
-#include "unoidlprovider.hxx"
namespace {
@@ -108,7 +108,7 @@ public:
ModuleDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::ModuleEntity > const & entity):
+ rtl::Reference< unoidl::ModuleEntity > const & entity):
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -129,20 +129,26 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::ModuleEntity > entity_;
+ rtl::Reference< unoidl::ModuleEntity > entity_;
};
css::uno::Sequence< css::uno::Reference< css::reflection::XTypeDescription > >
ModuleDescription::getMembers() throw (css::uno::RuntimeException) {
- std::vector< rtl::OUString > names(entity_->getMemberNames());
- assert(names.size() <= SAL_MAX_INT32);
- sal_Int32 n = static_cast< sal_Int32 >(names.size());
- css::uno::Sequence<
- css::uno::Reference< css::reflection::XTypeDescription > > s(n);
- for (sal_Int32 i = 0; i != n; ++i) {
- s[i] = resolve(context_, name_ + "." + names[i]);
+ try {
+ std::vector< rtl::OUString > names(entity_->getMemberNames());
+ assert(names.size() <= SAL_MAX_INT32);
+ sal_Int32 n = static_cast< sal_Int32 >(names.size());
+ css::uno::Sequence<
+ css::uno::Reference< css::reflection::XTypeDescription > > s(n);
+ for (sal_Int32 i = 0; i != n; ++i) {
+ s[i] = resolve(context_, name_ + "." + names[i]);
+ }
+ return s;
+ } catch (unoidl::FileFormatException & e) {
+ throw css::uno::DeploymentException(
+ e.getUri() + ": " + e.getDetail(),
+ static_cast< cppu::OWeakObject * >(this));
}
- return s;
}
typedef cppu::ImplInheritanceHelper1<
@@ -153,7 +159,7 @@ class EnumTypeDescription: public EnumTypeDescription_Base {
public:
EnumTypeDescription(
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::EnumTypeEntity > const & entity):
+ rtl::Reference< unoidl::EnumTypeEntity > const & entity):
EnumTypeDescription_Base(entity->isPublished()), name_(name),
entity_(entity)
{ assert(entity.is()); }
@@ -179,7 +185,7 @@ private:
throw (css::uno::RuntimeException);
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::EnumTypeEntity > entity_;
+ rtl::Reference< unoidl::EnumTypeEntity > entity_;
};
css::uno::Sequence< rtl::OUString > EnumTypeDescription::getEnumNames()
@@ -215,7 +221,7 @@ public:
PlainStructTypeDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::PlainStructTypeEntity > const & entity):
+ rtl::Reference< unoidl::PlainStructTypeEntity > const & entity):
PlainStructTypeDescription_Base(entity->isPublished()),
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -259,7 +265,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::PlainStructTypeEntity > entity_;
+ rtl::Reference< unoidl::PlainStructTypeEntity > entity_;
};
css::uno::Sequence< css::uno::Reference< css::reflection::XTypeDescription > >
@@ -321,8 +327,8 @@ public:
PolymorphicStructTypeTemplateDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::PolymorphicStructTypeTemplateEntity >
- const & entity):
+ rtl::Reference< unoidl::PolymorphicStructTypeTemplateEntity > const &
+ entity):
PolymorphicStructTypeTemplateDescription_Base(entity->isPublished()),
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -362,7 +368,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::PolymorphicStructTypeTemplateEntity > entity_;
+ rtl::Reference< unoidl::PolymorphicStructTypeTemplateEntity > entity_;
};
css::uno::Sequence< css::uno::Reference< css::reflection::XTypeDescription > >
@@ -417,7 +423,7 @@ public:
ExceptionTypeDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::ExceptionTypeEntity > const & entity):
+ rtl::Reference< unoidl::ExceptionTypeEntity > const & entity):
ExceptionTypeDescription_Base(entity->isPublished()), context_(context),
name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -449,7 +455,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::ExceptionTypeEntity > entity_;
+ rtl::Reference< unoidl::ExceptionTypeEntity > entity_;
};
css::uno::Sequence< css::uno::Reference< css::reflection::XTypeDescription > >
@@ -551,7 +557,7 @@ public:
AttributeDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- cppu::unoidl::InterfaceTypeEntity::Attribute const & attribute,
+ unoidl::InterfaceTypeEntity::Attribute const & attribute,
sal_Int32 position):
context_(context), name_(name), attribute_(attribute),
position_(position)
@@ -596,7 +602,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- cppu::unoidl::InterfaceTypeEntity::Attribute attribute_;
+ unoidl::InterfaceTypeEntity::Attribute attribute_;
sal_Int32 position_;
};
@@ -637,7 +643,7 @@ class MethodParameter:
public:
MethodParameter(
css::uno::Reference< css::uno::XComponentContext > const & context,
- cppu::unoidl::InterfaceTypeEntity::Method::Parameter const & parameter,
+ unoidl::InterfaceTypeEntity::Method::Parameter const & parameter,
sal_Int32 position):
context_(context), parameter_(parameter), position_(position)
{}
@@ -655,20 +661,18 @@ private:
virtual sal_Bool SAL_CALL isIn() throw (css::uno::RuntimeException) {
return
(parameter_.direction
- == cppu::unoidl::InterfaceTypeEntity::Method::Parameter::
- DIRECTION_IN)
+ == unoidl::InterfaceTypeEntity::Method::Parameter::DIRECTION_IN)
|| (parameter_.direction
- == cppu::unoidl::InterfaceTypeEntity::Method::Parameter::
+ == unoidl::InterfaceTypeEntity::Method::Parameter::
DIRECTION_IN_OUT);
}
virtual sal_Bool SAL_CALL isOut() throw (css::uno::RuntimeException) {
return
(parameter_.direction
- == cppu::unoidl::InterfaceTypeEntity::Method::Parameter::
- DIRECTION_OUT)
+ == unoidl::InterfaceTypeEntity::Method::Parameter::DIRECTION_OUT)
|| (parameter_.direction
- == cppu::unoidl::InterfaceTypeEntity::Method::Parameter::
+ == unoidl::InterfaceTypeEntity::Method::Parameter::
DIRECTION_IN_OUT);
}
@@ -676,7 +680,7 @@ private:
{ return position_; }
css::uno::Reference< css::uno::XComponentContext > context_;
- cppu::unoidl::InterfaceTypeEntity::Method::Parameter parameter_;
+ unoidl::InterfaceTypeEntity::Method::Parameter parameter_;
sal_Int32 position_;
};
@@ -689,8 +693,7 @@ public:
MethodDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- cppu::unoidl::InterfaceTypeEntity::Method const & method,
- sal_Int32 position):
+ unoidl::InterfaceTypeEntity::Method const & method, sal_Int32 position):
context_(context), name_(name), method_(method), position_(position)
{}
@@ -730,7 +733,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- cppu::unoidl::InterfaceTypeEntity::Method method_;
+ unoidl::InterfaceTypeEntity::Method method_;
sal_Int32 position_;
};
@@ -767,7 +770,7 @@ public:
InterfaceTypeDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::InterfaceTypeEntity > const & entity):
+ rtl::Reference< unoidl::InterfaceTypeEntity > const & entity):
InterfaceTypeDescription_Base(entity->isPublished()), context_(context),
name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -810,7 +813,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::InterfaceTypeEntity > entity_;
+ rtl::Reference< unoidl::InterfaceTypeEntity > entity_;
};
css::uno::Sequence<
@@ -905,7 +908,7 @@ public:
ConstantGroupDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::ConstantGroupEntity > const & entity):
+ rtl::Reference< unoidl::ConstantGroupEntity > const & entity):
ConstantGroupDescription_Base(entity->isPublished()), context_(context),
name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -927,7 +930,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::ConstantGroupEntity > entity_;
+ rtl::Reference< unoidl::ConstantGroupEntity > entity_;
};
css::uno::Sequence<
@@ -955,7 +958,7 @@ public:
TypedefDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::TypedefEntity > const & entity):
+ rtl::Reference< unoidl::TypedefEntity > const & entity):
TypedefDescription_Base(entity->isPublished()), context_(context),
name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -976,7 +979,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::TypedefEntity > entity_;
+ rtl::Reference< unoidl::TypedefEntity > entity_;
};
class ConstructorParameter:
@@ -986,7 +989,7 @@ class ConstructorParameter:
public:
ConstructorParameter(
css::uno::Reference< css::uno::XComponentContext > const & context,
- cppu::unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter
+ unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter
const & parameter,
sal_Int32 position):
context_(context), parameter_(parameter), position_(position)
@@ -1016,7 +1019,7 @@ private:
{ return parameter_.rest; }
css::uno::Reference< css::uno::XComponentContext > context_;
- cppu::unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter
+ unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter
parameter_;
sal_Int32 position_;
};
@@ -1029,7 +1032,7 @@ class ConstructorDescription:
public:
ConstructorDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
- cppu::unoidl::SingleInterfaceBasedServiceEntity::Constructor const &
+ unoidl::SingleInterfaceBasedServiceEntity::Constructor const &
constructor):
context_(context), constructor_(constructor)
{}
@@ -1055,7 +1058,7 @@ private:
SAL_CALL getExceptions() throw (css::uno::RuntimeException);
css::uno::Reference< css::uno::XComponentContext > context_;
- cppu::unoidl::SingleInterfaceBasedServiceEntity::Constructor constructor_;
+ unoidl::SingleInterfaceBasedServiceEntity::Constructor constructor_;
};
css::uno::Sequence< css::uno::Reference< css::reflection::XParameter > >
@@ -1097,8 +1100,8 @@ public:
SingleInterfaceBasedServiceDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::SingleInterfaceBasedServiceEntity >
- const & entity):
+ rtl::Reference< unoidl::SingleInterfaceBasedServiceEntity > const &
+ entity):
SingleInterfaceBasedServiceDescription_Base(entity->isPublished()),
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -1176,7 +1179,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::SingleInterfaceBasedServiceEntity > entity_;
+ rtl::Reference< unoidl::SingleInterfaceBasedServiceEntity > entity_;
};
css::uno::Sequence<
@@ -1203,8 +1206,7 @@ class PropertyDescription:
public:
PropertyDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
- cppu::unoidl::AccumulationBasedServiceEntity::Property const &
- property):
+ unoidl::AccumulationBasedServiceEntity::Property const & property):
context_(context), property_(property)
{}
@@ -1227,7 +1229,7 @@ private:
{ return resolve(context_, property_.type); }
css::uno::Reference< css::uno::XComponentContext > context_;
- cppu::unoidl::AccumulationBasedServiceEntity::Property property_;
+ unoidl::AccumulationBasedServiceEntity::Property property_;
};
typedef cppu::ImplInheritanceHelper1<
@@ -1241,7 +1243,7 @@ public:
AccumulationBasedServiceDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::AccumulationBasedServiceEntity > const &
+ rtl::Reference< unoidl::AccumulationBasedServiceEntity > const &
entity):
AccumulationBasedServiceDescription_Base(entity->isPublished()),
context_(context), name_(name), entity_(entity)
@@ -1302,7 +1304,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::AccumulationBasedServiceEntity > entity_;
+ rtl::Reference< unoidl::AccumulationBasedServiceEntity > entity_;
};
css::uno::Sequence<
@@ -1411,8 +1413,7 @@ public:
InterfaceBasedSingletonDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::InterfaceBasedSingletonEntity > const &
- entity):
+ rtl::Reference< unoidl::InterfaceBasedSingletonEntity > const & entity):
InterfaceBasedSingletonDescription_Base(entity->isPublished()),
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -1444,7 +1445,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::InterfaceBasedSingletonEntity > entity_;
+ rtl::Reference< unoidl::InterfaceBasedSingletonEntity > entity_;
};
typedef cppu::ImplInheritanceHelper1<
@@ -1458,8 +1459,7 @@ public:
ServiceBasedSingletonDescription(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & name,
- rtl::Reference< cppu::unoidl::ServiceBasedSingletonEntity > const &
- entity):
+ rtl::Reference< unoidl::ServiceBasedSingletonEntity > const & entity):
ServiceBasedSingletonDescription_Base(entity_->isPublished()),
context_(context), name_(name), entity_(entity)
{ assert(entity.is()); }
@@ -1491,7 +1491,7 @@ private:
css::uno::Reference< css::uno::XComponentContext > context_;
rtl::OUString name_;
- rtl::Reference< cppu::unoidl::ServiceBasedSingletonEntity > entity_;
+ rtl::Reference< unoidl::ServiceBasedSingletonEntity > entity_;
};
class Enumeration:
@@ -1503,7 +1503,7 @@ public:
Enumeration(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & prefix,
- rtl::Reference< cppu::unoidl::MapCursor > const & cursor,
+ rtl::Reference< unoidl::MapCursor > const & cursor,
css::uno::Sequence< css::uno::TypeClass > const & types, bool deep):
context_(context), types_(types), deep_(deep)
{
@@ -1536,22 +1536,22 @@ private:
struct Position {
Position(
rtl::OUString const & thePrefix,
- rtl::Reference< cppu::unoidl::MapCursor > const & theCursor):
+ rtl::Reference< unoidl::MapCursor > const & theCursor):
prefix(thePrefix), cursor(theCursor)
{ assert(theCursor.is()); }
Position(
rtl::OUString const & thePrefix,
- rtl::Reference< cppu::unoidl::ConstantGroupEntity > const &
+ rtl::Reference< unoidl::ConstantGroupEntity > const &
theConstantGroup):
prefix(thePrefix), constantGroup(theConstantGroup),
constantGroupIndex(constantGroup->getMembers().begin())
{ assert(theConstantGroup.is()); }
rtl::OUString prefix;
- rtl::Reference< cppu::unoidl::MapCursor > cursor;
- rtl::Reference< cppu::unoidl::ConstantGroupEntity > constantGroup;
- std::vector< cppu::unoidl::ConstantGroupEntity::Member >::const_iterator
+ rtl::Reference< unoidl::MapCursor > cursor;
+ rtl::Reference< unoidl::ConstantGroupEntity > constantGroup;
+ std::vector< unoidl::ConstantGroupEntity::Member >::const_iterator
constantGroupIndex;
};
@@ -1595,87 +1595,93 @@ bool Enumeration::matches(css::uno::TypeClass tc) const {
}
void Enumeration::findNextMatch() {
- for (;;) {
- assert(!positions_.empty());
- rtl::OUString name;
- if (positions_.top().cursor.is()) { // root or module
- rtl::Reference< cppu::unoidl::Entity > ent(
- positions_.top().cursor->getNext(&name));
- if (!ent.is()) {
- positions_.pop();
- if (positions_.empty()) {
+ try {
+ for (;;) {
+ assert(!positions_.empty());
+ rtl::OUString name;
+ if (positions_.top().cursor.is()) { // root or module
+ rtl::Reference< unoidl::Entity > ent(
+ positions_.top().cursor->getNext(&name));
+ if (!ent.is()) {
+ positions_.pop();
+ if (positions_.empty()) {
+ break;
+ }
+ continue;
+ }
+ name = positions_.top().prefix + name;
+ css::uno::TypeClass tc;
+ switch (ent->getSort()) {
+ case unoidl::Entity::SORT_MODULE:
+ tc = css::uno::TypeClass_MODULE;
+ if (deep_) {
+ positions_.push(
+ Position(
+ name + ".",
+ static_cast< unoidl::ModuleEntity * >(
+ ent.get())->createCursor()));
+ }
+ break;
+ case unoidl::Entity::SORT_ENUM_TYPE:
+ tc = css::uno::TypeClass_ENUM;
+ break;
+ case unoidl::Entity::SORT_PLAIN_STRUCT_TYPE:
+ case unoidl::Entity::SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE:
+ tc = css::uno::TypeClass_STRUCT;
+ break;
+ case unoidl::Entity::SORT_EXCEPTION_TYPE:
+ tc = css::uno::TypeClass_EXCEPTION;
+ break;
+ case unoidl::Entity::SORT_INTERFACE_TYPE:
+ tc = css::uno::TypeClass_INTERFACE;
+ break;
+ case unoidl::Entity::SORT_TYPEDEF:
+ tc = css::uno::TypeClass_TYPEDEF;
+ break;
+ case unoidl::Entity::SORT_CONSTANT_GROUP:
+ tc = css::uno::TypeClass_CONSTANTS;
+ if (deep_ && matches(css::uno::TypeClass_CONSTANT)) {
+ positions_.push(
+ Position(
+ name + ".",
+ static_cast< unoidl::ConstantGroupEntity * >(
+ ent.get())));
+ }
break;
+ case unoidl::Entity::SORT_SINGLE_INTERFACE_BASED_SERVICE:
+ case unoidl::Entity::SORT_ACCUMULATION_BASED_SERVICE:
+ tc = css::uno::TypeClass_SERVICE;
+ break;
+ case unoidl::Entity::SORT_INTERFACE_BASED_SINGLETON:
+ case unoidl::Entity::SORT_SERVICE_BASED_SINGLETON:
+ tc = css::uno::TypeClass_SINGLETON;
+ break;
+ default:
+ for (;;) { std::abort(); } // this cannot happen
}
- continue;
- }
- name = positions_.top().prefix + name;
- css::uno::TypeClass tc;
- switch (ent->getSort()) {
- case cppu::unoidl::Entity::SORT_MODULE:
- tc = css::uno::TypeClass_MODULE;
- if (deep_) {
- positions_.push(
- Position(
- name + ".",
- static_cast< cppu::unoidl::ModuleEntity * >(
- ent.get())->createCursor()));
+ if (matches(tc)) {
+ current_ = name;
+ break;
}
- break;
- case cppu::unoidl::Entity::SORT_ENUM_TYPE:
- tc = css::uno::TypeClass_ENUM;
- break;
- case cppu::unoidl::Entity::SORT_PLAIN_STRUCT_TYPE:
- case cppu::unoidl::Entity::SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE:
- tc = css::uno::TypeClass_STRUCT;
- break;
- case cppu::unoidl::Entity::SORT_EXCEPTION_TYPE:
- tc = css::uno::TypeClass_EXCEPTION;
- break;
- case cppu::unoidl::Entity::SORT_INTERFACE_TYPE:
- tc = css::uno::TypeClass_INTERFACE;
- break;
- case cppu::unoidl::Entity::SORT_TYPEDEF:
- tc = css::uno::TypeClass_TYPEDEF;
- break;
- case cppu::unoidl::Entity::SORT_CONSTANT_GROUP:
- tc = css::uno::TypeClass_CONSTANTS;
- if (deep_ && matches(css::uno::TypeClass_CONSTANT)) {
- positions_.push(
- Position(
- name + ".",
- static_cast< cppu::unoidl::ConstantGroupEntity * >(
- ent.get())));
+ } else { // constant group
+ if (positions_.top().constantGroupIndex
+ == positions_.top().constantGroup->getMembers().end())
+ {
+ positions_.pop();
+ if (positions_.empty()) {
+ break;
+ }
+ continue;
}
+ current_ = positions_.top().prefix
+ + positions_.top().constantGroupIndex++->name;
break;
- case cppu::unoidl::Entity::SORT_SINGLE_INTERFACE_BASED_SERVICE:
- case cppu::unoidl::Entity::SORT_ACCUMULATION_BASED_SERVICE:
- tc = css::uno::TypeClass_SERVICE;
- break;
- case cppu::unoidl::Entity::SORT_INTERFACE_BASED_SINGLETON:
- case cppu::unoidl::Entity::SORT_SERVICE_BASED_SINGLETON:
- tc = css::uno::TypeClass_SINGLETON;
- break;
- default:
- for (;;) { std::abort(); } // this cannot happen
- }
- if (matches(tc)) {
- current_ = name;
- break;
- }
- } else { // constant group
- if (positions_.top().constantGroupIndex
- == positions_.top().constantGroup->getMembers().end())
- {
- positions_.pop();
- if (positions_.empty()) {
- break;
- }
- continue;
}
- current_ = positions_.top().prefix
- + positions_.top().constantGroupIndex++->name;
- break;
}
+ } catch (unoidl::FileFormatException & e) {
+ throw css::uno::DeploymentException(
+ e.getUri() + ": " + e.getDetail(),
+ static_cast< cppu::OWeakObject * >(this));
}
}
@@ -1688,11 +1694,12 @@ class Provider:
private osl::Mutex, public Provider_Base, private boost::noncopyable
{
public:
+ // throws unoidl::FileFormatException, unoidl::NoSuchFileException:
Provider(
css::uno::Reference< css::uno::XComponentContext > const & context,
rtl::OUString const & uri):
Provider_Base(*static_cast< osl::Mutex * >(this)), context_(context),
- provider_(new cppu::UnoidlProvider(uri))
+ provider_(new unoidl::UnoidlProvider(uri))
{}
using Provider_Base::acquire;
@@ -1709,8 +1716,7 @@ private:
css::container::NoSuchElementException, css::uno::RuntimeException);
virtual sal_Bool SAL_CALL hasByHierarchicalName(
- rtl::OUString const & aName) throw (css::uno::RuntimeException)
- { return provider_->find(aName) != 0; }
+ rtl::OUString const & aName) throw (css::uno::RuntimeException);
virtual css::uno::Reference< css::reflection::XTypeDescriptionEnumeration >
SAL_CALL createTypeDescriptionEnumeration(
@@ -1723,117 +1729,169 @@ private:
css::uno::RuntimeException);
css::uno::Reference< css::uno::XComponentContext > context_;
- rtl::Reference< cppu::UnoidlProvider > provider_;
+ rtl::Reference< unoidl::UnoidlProvider > provider_;
};
css::uno::Any Provider::getByHierarchicalName(rtl::OUString const & aName)
throw (css::container::NoSuchElementException, css::uno::RuntimeException)
{
- bool cnst;
- sal_uInt32 off = provider_->find(aName, &cnst);
- if (off == 0) {
- throw css::container::NoSuchElementException(
- aName, static_cast< cppu::OWeakObject * >(this));
- }
- if (cnst) {
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new ConstantDescription(aName, provider_->getConstant(off)));
- } else {
- rtl::Reference< cppu::unoidl::Entity > ent(provider_->getEntity(off));
- switch (ent->getSort()) {
- case cppu::unoidl::Entity::SORT_MODULE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new ModuleDescription(
- context_, aName,
- static_cast< cppu::unoidl::ModuleEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_ENUM_TYPE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new EnumTypeDescription(
- aName,
- static_cast< cppu::unoidl::EnumTypeEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_PLAIN_STRUCT_TYPE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new PlainStructTypeDescription(
- context_, aName,
- static_cast< cppu::unoidl::PlainStructTypeEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new PolymorphicStructTypeTemplateDescription(
- context_, aName,
- static_cast<
- cppu::unoidl::PolymorphicStructTypeTemplateEntity *
- >(ent.get())));
- case cppu::unoidl::Entity::SORT_EXCEPTION_TYPE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new ExceptionTypeDescription(
- context_, aName,
- static_cast< cppu::unoidl::ExceptionTypeEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_INTERFACE_TYPE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new InterfaceTypeDescription(
- context_, aName,
- static_cast< cppu::unoidl::InterfaceTypeEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_TYPEDEF:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new TypedefDescription(
- context_, aName,
- static_cast< cppu::unoidl::TypedefEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_CONSTANT_GROUP:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new ConstantGroupDescription(
- context_, aName,
- static_cast< cppu::unoidl::ConstantGroupEntity * >(
- ent.get())));
- case cppu::unoidl::Entity::SORT_SINGLE_INTERFACE_BASED_SERVICE:
+ try {
+ bool cnst;
+ sal_uInt32 off = provider_->find(aName, &cnst);
+ if (off == 0) {
+ throw css::container::NoSuchElementException(
+ aName, static_cast< cppu::OWeakObject * >(this));
+ }
+ if (cnst) {
+ unoidl::ConstantValue val1(provider_->getConstant(off));
+ css::uno::Any val2;
+ switch (val1.type) {
+ case unoidl::ConstantValue::TYPE_BOOLEAN:
+ val2 <<= val1.booleanValue;
+ break;
+ case unoidl::ConstantValue::TYPE_BYTE:
+ val2 <<= val1.byteValue;
+ break;
+ case unoidl::ConstantValue::TYPE_SHORT:
+ val2 <<= val1.shortValue;
+ break;
+ case unoidl::ConstantValue::TYPE_UNSIGNED_SHORT:
+ val2 <<= val1.unsignedShortValue;
+ break;
+ case unoidl::ConstantValue::TYPE_LONG:
+ val2 <<= val1.longValue;
+ break;
+ case unoidl::ConstantValue::TYPE_UNSIGNED_LONG:
+ val2 <<= val1.unsignedLongValue;
+ break;
+ case unoidl::ConstantValue::TYPE_HYPER:
+ val2 <<= val1.hyperValue;
+ break;
+ case unoidl::ConstantValue::TYPE_UNSIGNED_HYPER:
+ val2 <<= val1.unsignedHyperValue;
+ break;
+ case unoidl::ConstantValue::TYPE_FLOAT:
+ val2 <<= val1.floatValue;
+ break;
+ case unoidl::ConstantValue::TYPE_DOUBLE:
+ val2 <<= val1.doubleValue;
+ break;
+ default:
+ for (;;) { std::abort(); } // this cannot happen
+ }
return css::uno::makeAny<
css::uno::Reference< css::reflection::XTypeDescription > >(
- new SingleInterfaceBasedServiceDescription(
- context_, aName,
- static_cast<
- cppu::unoidl::SingleInterfaceBasedServiceEntity * >(
+ new ConstantDescription(aName, val2));
+ } else {
+ rtl::Reference< unoidl::Entity > ent(provider_->getEntity(off));
+ switch (ent->getSort()) {
+ case unoidl::Entity::SORT_MODULE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new ModuleDescription(
+ context_, aName,
+ static_cast< unoidl::ModuleEntity * >(ent.get())));
+ case unoidl::Entity::SORT_ENUM_TYPE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new EnumTypeDescription(
+ aName,
+ static_cast< unoidl::EnumTypeEntity * >(
ent.get())));
- case cppu::unoidl::Entity::SORT_ACCUMULATION_BASED_SERVICE:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new AccumulationBasedServiceDescription(
- context_, aName,
- static_cast<
- cppu::unoidl::AccumulationBasedServiceEntity * >(
+ case unoidl::Entity::SORT_PLAIN_STRUCT_TYPE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new PlainStructTypeDescription(
+ context_, aName,
+ static_cast< unoidl::PlainStructTypeEntity * >(
ent.get())));
- case cppu::unoidl::Entity::SORT_INTERFACE_BASED_SINGLETON:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new InterfaceBasedSingletonDescription(
- context_, aName,
- static_cast<
- cppu::unoidl::InterfaceBasedSingletonEntity * >(
+ case unoidl::Entity::SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new PolymorphicStructTypeTemplateDescription(
+ context_, aName,
+ static_cast<
+ unoidl::PolymorphicStructTypeTemplateEntity * >(
+ ent.get())));
+ case unoidl::Entity::SORT_EXCEPTION_TYPE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new ExceptionTypeDescription(
+ context_, aName,
+ static_cast< unoidl::ExceptionTypeEntity * >(
ent.get())));
- case cppu::unoidl::Entity::SORT_SERVICE_BASED_SINGLETON:
- return css::uno::makeAny<
- css::uno::Reference< css::reflection::XTypeDescription > >(
- new ServiceBasedSingletonDescription(
- context_, aName,
- static_cast<
- cppu::unoidl::ServiceBasedSingletonEntity * >(
+ case unoidl::Entity::SORT_INTERFACE_TYPE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new InterfaceTypeDescription(
+ context_, aName,
+ static_cast< unoidl::InterfaceTypeEntity * >(
ent.get())));
- default:
- for (;;) { std::abort(); } // this cannot happen
+ case unoidl::Entity::SORT_TYPEDEF:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new TypedefDescription(
+ context_, aName,
+ static_cast< unoidl::TypedefEntity * >(ent.get())));
+ case unoidl::Entity::SORT_CONSTANT_GROUP:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new ConstantGroupDescription(
+ context_, aName,
+ static_cast< unoidl::ConstantGroupEntity * >(
+ ent.get())));
+ case unoidl::Entity::SORT_SINGLE_INTERFACE_BASED_SERVICE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new SingleInterfaceBasedServiceDescription(
+ context_, aName,
+ static_cast<
+ unoidl::SingleInterfaceBasedServiceEntity * >(
+ ent.get())));
+ case unoidl::Entity::SORT_ACCUMULATION_BASED_SERVICE:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new AccumulationBasedServiceDescription(
+ context_, aName,
+ static_cast<
+ unoidl::AccumulationBasedServiceEntity * >(
+ ent.get())));
+ case unoidl::Entity::SORT_INTERFACE_BASED_SINGLETON:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new InterfaceBasedSingletonDescription(
+ context_, aName,
+ static_cast<
+ unoidl::InterfaceBasedSingletonEntity * >(
+ ent.get())));
+ case unoidl::Entity::SORT_SERVICE_BASED_SINGLETON:
+ return css::uno::makeAny<
+ css::uno::Reference< css::reflection::XTypeDescription > >(
+ new ServiceBasedSingletonDescription(
+ context_, aName,
+ static_cast<
+ unoidl::ServiceBasedSingletonEntity * >(
+ ent.get())));
+ default:
+ for (;;) { std::abort(); } // this cannot happen
+ }
}
+ } catch (unoidl::FileFormatException & e) {
+ throw css::uno::DeploymentException(
+ e.getUri() + ": " + e.getDetail(),
+ static_cast< cppu::OWeakObject * >(this));
+ }
+}
+
+sal_Bool Provider::hasByHierarchicalName(
+ rtl::OUString const & aName) throw (css::uno::RuntimeException)
+{
+ try {
+ return provider_->find(aName) != 0;
+ } catch (unoidl::FileFormatException & e) {
+ throw css::uno::DeploymentException(
+ e.getUri() + ": " + e.getDetail(),
+ static_cast< cppu::OWeakObject * >(this));
}
}
@@ -1846,33 +1904,39 @@ Provider::createTypeDescriptionEnumeration(
css::reflection::NoSuchTypeNameException,
css::reflection::InvalidTypeNameException, css::uno::RuntimeException)
{
- rtl::OUString prefix;
- rtl::Reference< cppu::unoidl::MapCursor > cursor;
- if (moduleName.isEmpty()) {
- cursor = provider_->createRootCursor();
- } else {
- prefix = moduleName + ".";
- bool cnst;
- sal_uInt32 off = provider_->find(moduleName, &cnst);
- if (off == 0) {
- throw css::reflection::NoSuchTypeNameException(
- moduleName, static_cast< cppu::OWeakObject * >(this));
- }
- if (cnst) {
- throw css::reflection::InvalidTypeNameException(
- moduleName, static_cast< cppu::OWeakObject * >(this));
- }
- rtl::Reference< cppu::unoidl::Entity > ent(provider_->getEntity(off));
- if (ent->getSort() != cppu::unoidl::Entity::SORT_MODULE) {
- throw css::reflection::InvalidTypeNameException(
- moduleName, static_cast< cppu::OWeakObject * >(this));
+ try {
+ rtl::OUString prefix;
+ rtl::Reference< unoidl::MapCursor > cursor;
+ if (moduleName.isEmpty()) {
+ cursor = provider_->createRootCursor();
+ } else {
+ prefix = moduleName + ".";
+ bool cnst;
+ sal_uInt32 off = provider_->find(moduleName, &cnst);
+ if (off == 0) {
+ throw css::reflection::NoSuchTypeNameException(
+ moduleName, static_cast< cppu::OWeakObject * >(this));
+ }
+ if (cnst) {
+ throw css::reflection::InvalidTypeNameException(
+ moduleName, static_cast< cppu::OWeakObject * >(this));
+ }
+ rtl::Reference< unoidl::Entity > ent(provider_->getEntity(off));
+ if (ent->getSort() != unoidl::Entity::SORT_MODULE) {
+ throw css::reflection::InvalidTypeNameException(
+ moduleName, static_cast< cppu::OWeakObject * >(this));
+ }
+ cursor = static_cast< unoidl::ModuleEntity * >(ent.get())->
+ createCursor();
}
- cursor = static_cast< cppu::unoidl::ModuleEntity * >(ent.get())->
- createCursor();
+ return new Enumeration(
+ context_, prefix, cursor, types,
+ depth == css::reflection::TypeDescriptionSearchDepth_INFINITE);
+ } catch (unoidl::FileFormatException & e) {
+ throw css::uno::DeploymentException(
+ e.getUri() + ": " + e.getDetail(),
+ static_cast< cppu::OWeakObject * >(this));
}
- return new Enumeration(
- context_, prefix, cursor, types,
- depth == css::reflection::TypeDescriptionSearchDepth_INFINITE);
}
css::uno::Reference< css::container::XHierarchicalNameAccess >
@@ -1916,7 +1980,7 @@ void readRdbFile(
css::uno::Reference< css::container::XHierarchicalNameAccess > prov;
try {
prov = new Provider(context, uri);
- } catch (css::container::NoSuchElementException &) {
+ } catch (unoidl::NoSuchFileException &) {
if (optional) {
SAL_INFO("cppuhelper", "Ignored optional " << uri);
return;
@@ -1924,7 +1988,7 @@ void readRdbFile(
throw css::uno::DeploymentException(
uri + ": no such file",
css::uno::Reference< css::uno::XInterface >());
- } catch (css::registry::InvalidRegistryException &) {
+ } catch (unoidl::FileFormatException &) {
prov = readLegacyRdbFile(uri, serviceManager, context);
}
assert(prov.is());
diff --git a/cppuhelper/source/unoidl.cxx b/cppuhelper/source/unoidl.cxx
deleted file mode 100644
index b9109af0416f..000000000000
--- a/cppuhelper/source/unoidl.cxx
+++ /dev/null
@@ -1,63 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- */
-
-#include "sal/config.h"
-
-#include <vector>
-
-#include "cppuhelper/unoidl.hxx"
-#include "rtl/ref.hxx"
-#include "rtl/ustring.hxx"
-
-#include "unoidlprovider.hxx"
-
-namespace cppu { namespace unoidl {
-
-Entity::~Entity() throw () {}
-
-MapCursor::~MapCursor() throw () {}
-
-ModuleEntity::~ModuleEntity() throw () {}
-
-PublishableEntity::~PublishableEntity() throw () {}
-
-EnumTypeEntity::~EnumTypeEntity() throw () {}
-
-PlainStructTypeEntity::~PlainStructTypeEntity() throw () {}
-
-PolymorphicStructTypeTemplateEntity::~PolymorphicStructTypeTemplateEntity()
- throw ()
-{}
-
-ExceptionTypeEntity::~ExceptionTypeEntity() throw () {}
-
-InterfaceTypeEntity::~InterfaceTypeEntity() throw () {}
-
-TypedefEntity::~TypedefEntity() throw () {}
-
-ConstantGroupEntity::~ConstantGroupEntity() throw () {}
-
-SingleInterfaceBasedServiceEntity::~SingleInterfaceBasedServiceEntity() throw ()
-{}
-
-AccumulationBasedServiceEntity::~AccumulationBasedServiceEntity() throw () {}
-
-InterfaceBasedSingletonEntity::~InterfaceBasedSingletonEntity() throw () {}
-
-ServiceBasedSingletonEntity::~ServiceBasedSingletonEntity() throw () {}
-
-Provider::~Provider() throw () {}
-
-rtl::Reference< Provider > loadProvider(rtl::OUString const & uri) {
- return new UnoidlProvider(uri);
-}
-
-} }
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/cppuhelper/source/unoidlprovider.cxx b/cppuhelper/source/unoidlprovider.cxx
deleted file mode 100644
index 12b497490c87..000000000000
--- a/cppuhelper/source/unoidlprovider.cxx
+++ /dev/null
@@ -1,1363 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- */
-
-#include "sal/config.h"
-
-#include <algorithm>
-#include <cassert>
-#include <cstring>
-#include <vector>
-
-#include "com/sun/star/container/NoSuchElementException.hpp"
-#include "com/sun/star/registry/InvalidRegistryException.hpp"
-#include "com/sun/star/uno/Any.hxx"
-#include "com/sun/star/uno/DeploymentException.hpp"
-#include "com/sun/star/uno/Reference.hxx"
-#include "com/sun/star/uno/XInterface.hpp"
-#include "cppuhelper/unoidl.hxx"
-#include "osl/endian.h"
-#include "osl/file.h"
-#include "rtl/ref.hxx"
-#include "rtl/ustring.hxx"
-#include "sal/log.hxx"
-#include "sal/types.h"
-#include "salhelper/simplereferenceobject.hxx"
-
-#include "unoidlprovider.hxx"
-
-// New binary format:
-//
-// Uses the following definitions:
-//
-// * UInt16: 2-byte value, LSB first
-// * UInt32: 4-byte value, LSB first
-// * UInt64: 8-byte value, LSB first
-// * Offset: UInt32 value, counting bytes from start of file
-// * NUL-Name: zero or more non-NUL US-ASCII bytes followed by a NUL byte
-// * Len-Name: UInt32 number of characters, with 0x80000000 bit 1, followed by
-// that many (- 0x80000000) US-ASCII bytes
-// * Idx-Name: either an Offset (with 0x80000000 bit 0) of a Len-Name, or a
-// Len-Name
-// * Entry: Offset of NUL-Name followed by Offset of payload
-// * Map: zero or more Entries
-//
-// Layout of per-entry payload in the root or a module Map:
-//
-// * kind byte:
-// ** 0: module
-// *** followed by:
-// **** UInt32 number N1 of entries of Map
-// **** N1 * Entry
-// ** otherwise:
-// *** 0x80 bit: 1 if published
-// *** 0x40 bit: 1 if deprecated
-// *** 0x20 bit: flag (may only be 1 for certain kinds, see below)
-// *** remaining bits:
-// **** 1: enum type
-// ***** followed by:
-// ****** UInt32 number N1 of members
-// ****** N1 * tuple of:
-// ******* Offset of Idx-Name
-// ******* UInt32
-// **** 2: plain struct type (with base if flag is 1)
-// ***** followed by:
-// ****** if "with base": Offset of Idx-Name
-// ****** UInt32 number N1 of direct members
-// ****** N1 * tuple of:
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name type
-// **** 3: polymorphic struct type template
-// ***** followed by:
-// ****** UInt32 number N1 of type parameters
-// ****** N1 * Offset of Idx-Name
-// ****** UInt32 number N2 of members
-// ****** N2 * tuple of:
-// ******* kind byte: 0x01 bit is 1 if parameterized type
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name type
-// **** 4: exception type (with base if flag is 1)
-// ***** followed by:
-// ****** if "with base": Offset of Idx-Name
-// ****** UInt32 number N1 of direct members
-// ****** N1 * tuple of:
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name type
-// **** 5: interface type
-// ***** followed by:
-// ****** UInt32 number N1 of direct mandatory bases
-// ****** N1 * Offset of Idx-Name
-// ****** UInt32 number N2 of direct optional bases
-// ****** N2 * Offset of Idx-Name
-// ****** UInt32 number N3 of direct attributes
-// ****** N3 * tuple of:
-// ******* kind byte:
-// ******** 0x02 bit: 1 if read-only
-// ******** 0x01 bit: 1 if bound
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name type
-// ******* UInt32 number N4 of get exceptions
-// ******* N4 * Offset of Idx-Name
-// ******* UInt32 number N5 of set exceptions
-// ******* N5 * Offset of Idx-Name
-// ****** UInt32 number N6 of direct methods
-// ****** N6 * tuple of:
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name return type
-// ******* UInt32 number N7 of parameters
-// ******* N7 * tuple of:
-// ******** direction byte: 0 for in, 1 for out, 2 for in-out
-// ******** Offset of Idx-Name name
-// ******** Offset of Idx-Name type
-// ******* UInt32 number N8 of exceptions
-// ******* N8 * Offset of Idx-Name
-// **** 6: typedef
-// ***** followed by:
-// ****** Offset of Idx-Name
-// **** 7: constant group
-// ***** followed by:
-// ****** UInt32 number N1 of entries of Map
-// ****** N1 * Entry
-// **** 8: single-interface--based service (with default constructor if flag is
-// 1)
-// ***** followed by:
-// ****** Offset of Idx-Name
-// ****** if not "with default constructor":
-// ******* UInt32 number N1 of constructors
-// ******* N1 * tuple of:
-// ******** Offset of Idx-Name
-// ******** UInt32 number N2 of parameters
-// ******** N2 * tuple of
-// ********* kind byte: 0x04 bit is 1 if rest parameter
-// ********* Offset of Idx-Name name
-// ********* Offset of Idx-Name type
-// ******** UInt32 number N3 of exceptions
-// ******** N3 * Offset of Idx-Name
-// **** 9: accumulation-based service
-// ***** followed by:
-// ****** UInt32 number N1 of direct mandatory base services
-// ****** N1 * Offset of Idx-Name
-// ****** UInt32 number N2 of direct optional base services
-// ****** N2 * Offset of Idx-Name
-// ****** UInt32 number N3 of direct mandatory base interfaces
-// ****** N3 * Offset of Idx-Name
-// ****** UInt32 number N4 of direct optional base interfaces
-// ****** N4 * Offset of Idx-Name
-// ****** UInt32 number N5 of direct properties
-// ****** N5 * tuple of:
-// ******* UInt16 kind:
-// ******** 0x0100 bit: 1 if optional
-// ******** 0x0080 bit: 1 if removable
-// ******** 0x0040 bit: 1 if maybedefault
-// ******** 0x0020 bit: 1 if maybeambiguous
-// ******** 0x0010 bit: 1 if readonly
-// ******** 0x0008 bit: 1 if transient
-// ******** 0x0004 bit: 1 if constrained
-// ******** 0x0002 bit: 1 if bound
-// ******** 0x0001 bit: 1 if maybevoid
-// ******* Offset of Idx-Name name
-// ******* Offset of Idx-Name type
-// **** 10: interface-based singleton
-// ***** followed by:
-// ****** Offset of Idx-Name
-// **** 11: service-based singleton
-// ***** followed by:
-// ****** Offset of Idx-Name
-//
-// Layout of per-entry payload in a constant group Map:
-//
-// * kind byte:
-// ** 0x80 bit: 1 if deprecated
-// ** remaining bits:
-// *** 0: BOOLEAN
-// **** followed by value byte, 0 represents false, 1 represents true
-// *** 1: BYTE
-// **** followed by value byte, representing values with two's complement
-// *** 2: SHORT
-// **** followed by UInt16 value, representing values with two's complement
-// *** 3: UNSIGNED SHORT
-// **** followed by UInt16 value
-// *** 4: LONG
-// **** followed by UInt32 value, representing values with two's complement
-// *** 5: UNSIGNED LONG
-// **** followed by UInt32 value
-// *** 6: HYPER
-// **** followed by UInt64 value, representing values with two's complement
-// *** 7: UNSIGNED HYPER
-// **** followed by UInt64 value
-// *** 8: FLOAT
-// **** followed by 4-byte value, representing values in ISO 60599 binary32
-// format, LSB first
-// *** 9: DOUBLE
-// **** followed by 8-byte value, representing values in ISO 60599 binary64
-// format, LSB first
-//
-// Memory layout:
-//
-// * 8 byte header "UNOIDL\0\xFF
-// * Offset of root Map
-// * UInt32 number of entries of root Map
-// ...
-
-namespace {
-
-// sizeof (Memory16) == 2
-struct Memory16 {
- unsigned char byte[2];
-
- sal_uInt16 getUnsigned16() const {
- return static_cast< sal_uInt16 >(byte[0])
- | (static_cast< sal_uInt16 >(byte[1]) << 8);
- }
-};
-
-// sizeof (Memory32) == 4
-struct Memory32 {
- unsigned char byte[4];
-
- sal_uInt32 getUnsigned32() const {
- return static_cast< sal_uInt32 >(byte[0])
- | (static_cast< sal_uInt32 >(byte[1]) << 8)
- | (static_cast< sal_uInt32 >(byte[2]) << 16)
- | (static_cast< sal_uInt32 >(byte[3]) << 24);
- }
-
- float getIso60599Binary32() const {
- union {
- unsigned char buf[4];
- float f; // assuming float is ISO 60599 binary32
- } sa;
-#if defined OSL_LITENDIAN
- sa.buf[0] = byte[0];
- sa.buf[1] = byte[1];
- sa.buf[2] = byte[2];
- sa.buf[3] = byte[3];
-#else
- sa.buf[0] = byte[3];
- sa.buf[1] = byte[2];
- sa.buf[2] = byte[1];
- sa.buf[3] = byte[0];
-#endif
- return sa.f;
- }
-};
-
-// sizeof (Memory64) == 8
-struct Memory64 {
- unsigned char byte[8];
-
- sal_uInt64 getUnsigned64() const {
- return static_cast< sal_uInt64 >(byte[0])
- | (static_cast< sal_uInt64 >(byte[1]) << 8)
- | (static_cast< sal_uInt64 >(byte[2]) << 16)
- | (static_cast< sal_uInt64 >(byte[3]) << 24)
- | (static_cast< sal_uInt64 >(byte[4]) << 32)
- | (static_cast< sal_uInt64 >(byte[5]) << 40)
- | (static_cast< sal_uInt64 >(byte[6]) << 48)
- | (static_cast< sal_uInt64 >(byte[7]) << 56);
- }
-
- double getIso60599Binary64() const {
- union {
- unsigned char buf[8];
- double d; // assuming double is ISO 60599 binary64
- } sa;
-#if defined OSL_LITENDIAN
- sa.buf[0] = byte[0];
- sa.buf[1] = byte[1];
- sa.buf[2] = byte[2];
- sa.buf[3] = byte[3];
- sa.buf[4] = byte[4];
- sa.buf[5] = byte[5];
- sa.buf[6] = byte[6];
- sa.buf[7] = byte[7];
-#else
- sa.buf[0] = byte[7];
- sa.buf[1] = byte[6];
- sa.buf[2] = byte[5];
- sa.buf[3] = byte[4];
- sa.buf[4] = byte[3];
- sa.buf[5] = byte[2];
- sa.buf[6] = byte[1];
- sa.buf[7] = byte[0];
-#endif
- return sa.d;
- }
-};
-
-}
-
-namespace cppu {
-
-class MappedFile: public salhelper::SimpleReferenceObject {
-public:
- explicit MappedFile(rtl::OUString const & fileUrl);
-
- sal_uInt8 read8(sal_uInt32 offset) const;
-
- sal_uInt16 read16(sal_uInt32 offset) const;
-
- sal_uInt32 read32(sal_uInt32 offset) const;
-
- sal_uInt64 read64(sal_uInt32 offset) const;
-
- float readIso60599Binary32(sal_uInt32 offset) const;
-
- double readIso60599Binary64(sal_uInt32 offset) const;
-
- rtl::OUString readNameNul(sal_uInt32 offset) const;
-
- rtl::OUString readNameLen(sal_uInt32 offset, sal_uInt32 * newOffset = 0)
- const;
-
- oslFileHandle handle;
- sal_uInt64 size;
- void * address;
-
-private:
- virtual ~MappedFile();
-
- sal_uInt8 get8(sal_uInt32 offset) const;
-
- sal_uInt16 get16(sal_uInt32 offset) const;
-
- sal_uInt32 get32(sal_uInt32 offset) const;
-
- sal_uInt64 get64(sal_uInt32 offset) const;
-
- float getIso60599Binary32(sal_uInt32 offset) const;
-
- double getIso60599Binary64(sal_uInt32 offset) const;
-};
-
-MappedFile::MappedFile(rtl::OUString const & fileUrl) {
- oslFileError e = osl_openFile(
- fileUrl.pData, &handle, osl_File_OpenFlag_Read);
- switch (e) {
- case osl_File_E_None:
- break;
- case osl_File_E_NOENT:
- throw css::container::NoSuchElementException(
- fileUrl, css::uno::Reference< css::uno::XInterface >());
- default:
- throw css::uno::RuntimeException(
- "cannot open " + fileUrl + ": " + rtl::OUString::number(e),
- css::uno::Reference< css::uno::XInterface >());
- }
- e = osl_getFileSize(handle, &size);
- if (e == osl_File_E_None) {
- e = osl_mapFile(
- handle, &address, size, 0, osl_File_MapFlag_RandomAccess);
- }
- if (e != osl_File_E_None) {
- oslFileError e2 = osl_closeFile(handle);
- SAL_WARN_IF(
- e2 != osl_File_E_None, "cppuhelper",
- "cannot close " << fileUrl << ": " << +e2);
- throw css::uno::RuntimeException(
- "cannot mmap " + fileUrl + ": " + rtl::OUString::number(e),
- css::uno::Reference< css::uno::XInterface >());
- }
-}
-
-sal_uInt8 MappedFile::read8(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 1) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 8-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return get8(offset);
-}
-
-sal_uInt16 MappedFile::read16(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 2) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 16-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return get16(offset);
-}
-
-sal_uInt32 MappedFile::read32(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 4) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 32-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return get32(offset);
-}
-
-sal_uInt64 MappedFile::read64(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 8) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 64-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return get64(offset);
-}
-
-float MappedFile::readIso60599Binary32(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 4) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 32-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return getIso60599Binary32(offset);
-}
-
-double MappedFile::readIso60599Binary64(sal_uInt32 offset) const {
- assert(size >= 8);
- if (offset > size - 8) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for 64-bit value too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return getIso60599Binary64(offset);
-}
-
-rtl::OUString MappedFile::readNameNul(sal_uInt32 offset) const {
- if (offset > size) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: offset for string too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- sal_uInt64 end = offset;
- for (;; ++end) {
- if (end == size) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: string misses trailing NUL",
- css::uno::Reference< css::uno::XInterface >());
- }
- if (static_cast< char const * >(address)[end] == 0) {
- break;
- }
- }
- if (end - offset > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: string too long",
- css::uno::Reference< css::uno::XInterface >());
- }
- rtl::OUString name;
- if (!rtl_convertStringToUString(
- &name.pData, static_cast< char const * >(address) + offset,
- end - offset, RTL_TEXTENCODING_ASCII_US,
- (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_INVALID_ERROR)))
- {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: name is not ASCII",
- css::uno::Reference< css::uno::XInterface >());
- }
- return name;
-}
-
-rtl::OUString MappedFile::readNameLen(sal_uInt32 offset, sal_uInt32 * newOffset)
- const
-{
- sal_uInt32 len = read32(offset);
- if ((len & 0x80000000) == 0) {
- if (newOffset != 0) {
- *newOffset = offset + 4;
- }
- offset = len;
- len = read32(offset);
- if ((len & 0x80000000) == 0) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: name length high bit unset",
- css::uno::Reference< css::uno::XInterface >());
- }
- len &= ~0x80000000;
- } else {
- len &= ~0x80000000;
- if (newOffset != 0) {
- *newOffset = offset + 4 + len;
- }
- }
- if (len > SAL_MAX_INT32 || len > size - offset - 4) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: size of name is too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- rtl::OUString name;
- if (!rtl_convertStringToUString(
- &name.pData, static_cast< char const * >(address) + offset + 4, len,
- RTL_TEXTENCODING_ASCII_US,
- (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_ERROR
- | RTL_TEXTTOUNICODE_FLAGS_INVALID_ERROR)))
- {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: name is not ASCII",
- css::uno::Reference< css::uno::XInterface >());
- }
- return name;
-}
-
-MappedFile::~MappedFile() {
- oslFileError e = osl_unmapMappedFile(handle, address, size);
- SAL_WARN_IF(e != osl_File_E_None, "cppuhelper", "cannot unmap: " << +e);
- e = osl_closeFile(handle);
- SAL_WARN_IF(e != osl_File_E_None, "cppuhelper", "cannot close: " << +e);
-}
-
-sal_uInt8 MappedFile::get8(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 1);
- return static_cast< char const * >(address)[offset];
-}
-
-sal_uInt16 MappedFile::get16(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 2);
- return reinterpret_cast< Memory16 const * >(
- static_cast< char const * >(address) + offset)->getUnsigned16();
-}
-
-sal_uInt32 MappedFile::get32(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 4);
- return reinterpret_cast< Memory32 const * >(
- static_cast< char const * >(address) + offset)->getUnsigned32();
-}
-
-sal_uInt64 MappedFile::get64(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 8);
- return reinterpret_cast< Memory64 const * >(
- static_cast< char const * >(address) + offset)->getUnsigned64();
-}
-
-float MappedFile::getIso60599Binary32(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 4);
- return reinterpret_cast< Memory32 const * >(
- static_cast< char const * >(address) + offset)->getIso60599Binary32();
-}
-
-double MappedFile::getIso60599Binary64(sal_uInt32 offset) const {
- assert(size >= 8);
- assert(offset <= size - 8);
- return reinterpret_cast< Memory64 const * >(
- static_cast< char const * >(address) + offset)->getIso60599Binary64();
-}
-
-// sizeof (MapEntry) == 8
-struct MapEntry {
- Memory32 name;
- Memory32 data;
-};
-
-namespace {
-
-enum Compare { COMPARE_LESS, COMPARE_GREATER, COMPARE_EQUAL };
-
-Compare compare(
- rtl::Reference< MappedFile > const & file, rtl::OUString const & name,
- sal_Int32 nameOffset, sal_Int32 nameLength, MapEntry const * entry)
-{
- assert(file.is());
- assert(entry != 0);
- sal_uInt32 off = entry->name.getUnsigned32();
- if (off > file->size - 1) { // at least a trailing NUL
- throw css::uno::DeploymentException(
- "broken UNOIDL file: string offset too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- assert(nameLength >= 0);
- sal_uInt64 min = std::min(
- static_cast< sal_uInt64 >(nameLength), file->size - off);
- for (sal_uInt64 i = 0; i != min; ++i) {
- sal_Unicode c1 = name[nameOffset + i];
- sal_Unicode c2 = static_cast< unsigned char const * >(file->address)[
- off + i];
- if (c1 < c2) {
- return COMPARE_LESS;
- } else if (c1 > c2 || c2 == 0) {
- // ...the "|| c2 == 0" is for the odd case where name erroneously
- // contains NUL characters
- return COMPARE_GREATER;
- }
- }
- if (static_cast< sal_uInt64 >(nameLength) == min) {
- if (file->size - off == min) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: string misses trailing NUL",
- css::uno::Reference< css::uno::XInterface >());
- }
- return
- static_cast< unsigned char const * >(file->address)[off + min] == 0
- ? COMPARE_EQUAL : COMPARE_LESS;
- } else {
- return COMPARE_GREATER;
- }
-}
-
-sal_uInt32 findInMap(
- rtl::Reference< MappedFile > const & file, MapEntry const * mapBegin,
- sal_uInt32 mapSize, rtl::OUString const & name, sal_Int32 nameOffset,
- sal_Int32 nameLength)
-{
- if (mapSize == 0) {
- return 0;
- }
- sal_uInt32 n = mapSize / 2;
- MapEntry const * p = mapBegin + n;
- switch (compare(file, name, nameOffset, nameLength, p)) {
- case COMPARE_LESS:
- return findInMap(file, mapBegin, n, name, nameOffset, nameLength);
- case COMPARE_GREATER:
- return findInMap(
- file, p + 1, mapSize - n - 1, name, nameOffset, nameLength);
- default: // COMPARE_EQUAL
- break;
- }
- sal_uInt32 off = mapBegin[n].data.getUnsigned32();
- if (off == 0) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: map entry data offset is null",
- css::uno::Reference< css::uno::XInterface >());
- }
- return off;
-}
-
-css::uno::Any readConstant(
- rtl::Reference< MappedFile > const & file, sal_uInt32 offset)
-{
- assert(file.is());
- int v = file->read8(offset);
- int type = v & 0x7F;
- bool deprecated = (v & 0x80) != 0; (void)deprecated;//TODO
- switch (type) {
- case 0: // BOOLEAN
- v = file->read8(offset + 1);
- switch (v) {
- case 0:
- return css::uno::makeAny(false);
- case 1:
- return css::uno::makeAny(true);
- default:
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad boolean constant value "
- + rtl::OUString::number(v)),
- css::uno::Reference< css::uno::XInterface >());
- }
- break;
- case 1: // BYTE
- return css::uno::makeAny< sal_Int8 >(file->read8(offset + 1));
- //TODO: implementation-defined behavior of conversion from sal_uInt8
- // to sal_Int8 relies on two's complement representation
- case 2: // SHORT
- return css::uno::makeAny< sal_Int16 >(file->read16(offset + 1));
- //TODO: implementation-defined behavior of conversion from
- // sal_uInt16 to sal_Int16 relies on two's complement representation
- case 3: // UNSIGNED SHORT
- return css::uno::makeAny(file->read16(offset + 1));
- case 4: // LONG
- return css::uno::makeAny< sal_Int32 >(file->read32(offset + 1));
- //TODO: implementation-defined behavior of conversion from
- // sal_uInt32 to sal_Int32 relies on two's complement representation
- case 5: // UNSIGNED LONG
- return css::uno::makeAny(file->read32(offset + 1));
- case 6: // HYPER
- return css::uno::makeAny< sal_Int64 >(file->read64(offset + 1));
- //TODO: implementation-defined behavior of conversion from
- // sal_uInt64 to sal_Int64 relies on two's complement representation
- case 7: // UNSIGNED HYPER
- return css::uno::makeAny(file->read64(offset + 1));
- case 8: // FLOAT
- return css::uno::makeAny(file->readIso60599Binary32(offset + 1));
- case 9: // DOUBLE
- return css::uno::makeAny(file->readIso60599Binary64(offset + 1));
- default:
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad constant type byte "
- + rtl::OUString::number(v)),
- css::uno::Reference< css::uno::XInterface >());
- }
-}
-
-rtl::Reference< unoidl::Entity > readEntity(
- rtl::Reference< MappedFile > const & file, sal_uInt32 offset);
-
-class UnoidlCursor: public unoidl::MapCursor {
-public:
- UnoidlCursor(
- rtl::Reference< MappedFile > file, MapEntry const * mapBegin,
- sal_uInt32 mapSize):
- file_(file), mapIndex_(mapBegin), mapEnd_(mapBegin + mapSize)
- {}
-
-private:
- virtual ~UnoidlCursor() throw () {}
-
- virtual rtl::Reference< unoidl::Entity > getNext(rtl::OUString * name);
-
- rtl::Reference< MappedFile > file_;
- MapEntry const * mapIndex_;
- MapEntry const * mapEnd_;
-};
-
-rtl::Reference< unoidl::Entity > UnoidlCursor::getNext(rtl::OUString * name) {
- assert(name != 0);
- rtl::Reference< unoidl::Entity > ent;
- if (mapIndex_ != mapEnd_) {
- *name = file_->readNameNul(mapIndex_->name.getUnsigned32());
- ent = readEntity(file_, mapIndex_->data.getUnsigned32());
- ++mapIndex_;
- }
- return ent;
-}
-
-class UnoidlModuleEntity: public unoidl::ModuleEntity {
-public:
- UnoidlModuleEntity(
- rtl::Reference< MappedFile > const & file, sal_uInt32 mapOffset,
- sal_uInt32 mapSize):
- file_(file),
- mapBegin_(
- reinterpret_cast< MapEntry const * >(
- static_cast< char const * >(file_->address) + mapOffset)),
- mapSize_(mapSize)
- { assert(file.is()); }
-
-private:
- virtual ~UnoidlModuleEntity() throw () {}
-
- virtual std::vector< rtl::OUString > getMemberNames() const;
-
- virtual rtl::Reference< unoidl::MapCursor > createCursor() const
- { return new UnoidlCursor(file_, mapBegin_, mapSize_); }
-
- rtl::Reference< MappedFile > file_;
- MapEntry const * mapBegin_;
- sal_uInt32 mapSize_;
-};
-
-std::vector< rtl::OUString > UnoidlModuleEntity::getMemberNames() const {
- std::vector< rtl::OUString > names;
- for (sal_uInt32 i = 0; i != mapSize_; ++i) {
- names.push_back(file_->readNameNul(mapBegin_[i].name.getUnsigned32()));
- }
- return names;
-}
-
-rtl::Reference< unoidl::Entity > readEntity(
- rtl::Reference< MappedFile > const & file, sal_uInt32 offset)
-{
- assert(file.is());
- int v = file->read8(offset);
- int type = v & 0x3F;
- bool published = (v & 0x80) != 0;
- bool deprecated = (v & 0x40) != 0; (void)deprecated;//TODO
- bool flag = (v & 0x20) != 0;
- switch (type) {
- case 0: // module
- {
- if (v != 0) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad module type byte "
- + rtl::OUString::number(v)),
- css::uno::Reference< css::uno::XInterface >());
- }
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: too many items in module",
- css::uno::Reference< css::uno::XInterface >());
- }
- if (offset + 5 + 8 * n > file->size) { //TODO: overflow
- throw css::uno::DeploymentException(
- "broken UNOIDL file: module map offset + size too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- return new UnoidlModuleEntity(file, offset + 5, n);
- }
- case 1: // enum type
- {
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: too many members of enum type",
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 5;
- std::vector< unoidl::EnumTypeEntity::Member > mems;
- for (sal_uInt32 i = 0; i != n; ++i) {
- rtl::OUString memName(file->readNameLen(offset, &offset));
- sal_Int32 memValue = static_cast< sal_Int32 >(
- file->read32(offset));
- //TODO: implementation-defined behavior of conversion from
- // sal_uInt32 to sal_Int32 relies on two's complement
- // representation
- offset += 4;
- mems.push_back(
- unoidl::EnumTypeEntity::Member(memName, memValue));
- }
- return new unoidl::EnumTypeEntity(published, mems);
- }
- case 2: // plain struct type without base
- case 2 | 0x20: // plain struct type with base
- {
- ++offset;
- rtl::OUString base;
- if (flag) {
- base = file->readNameLen(offset, &offset);
- if (base.isEmpty()) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: empty base type name of plain"
- " struct type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- }
- sal_uInt32 n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct members of plain"
- " struct type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::PlainStructTypeEntity::Member > mems;
- for (sal_uInt32 i = 0; i != n; ++i) {
- rtl::OUString memName(file->readNameLen(offset, &offset));
- rtl::OUString memType(file->readNameLen(offset, &offset));
- mems.push_back(
- unoidl::PlainStructTypeEntity::Member(memName, memType));
- }
- return new unoidl::PlainStructTypeEntity(published, base, mems);
- }
- case 3: // polymorphic struct type template
- {
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many type parameters of"
- " polymorphic struct type template"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 5;
- std::vector< rtl::OUString > params;
- for (sal_uInt32 i = 0; i != n; ++i) {
- params.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many members of polymorphic"
- " struct type template"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::PolymorphicStructTypeTemplateEntity::Member >
- mems;
- for (sal_uInt32 i = 0; i != n; ++i) {
- v = file->read8(offset);
- ++offset;
- rtl::OUString memName(file->readNameLen(offset, &offset));
- rtl::OUString memType(file->readNameLen(offset, &offset));
- if (v > 1) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad flags "
- + rtl::OUString::number(v) + " for member " + memName
- + " of polymorphic struct type template"),
- css::uno::Reference< css::uno::XInterface >());
- }
- mems.push_back(
- unoidl::PolymorphicStructTypeTemplateEntity::Member(
- memName, memType, v == 1));
- }
- return new unoidl::PolymorphicStructTypeTemplateEntity(
- published, params, mems);
- }
- case 4: // exception type without base
- case 4 | 0x20: // exception type with base
- {
- ++offset;
- rtl::OUString base;
- if (flag) {
- base = file->readNameLen(offset, &offset);
- if (base.isEmpty()) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: empty base type name of"
- " exception type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- }
- sal_uInt32 n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct members of"
- " exception type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::ExceptionTypeEntity::Member > mems;
- for (sal_uInt32 i = 0; i != n; ++i) {
- rtl::OUString memName(file->readNameLen(offset, &offset));
- rtl::OUString memType(file->readNameLen(offset, &offset));
- mems.push_back(
- unoidl::ExceptionTypeEntity::Member(memName, memType));
- }
- return new unoidl::ExceptionTypeEntity(published, base, mems);
- }
- case 5: // interface type
- {
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct mandatory bases of"
- " interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 5;
- std::vector< rtl::OUString > mandBases;
- for (sal_uInt32 i = 0; i != n; ++i) {
- mandBases.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct optional bases of"
- " interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< rtl::OUString > optBases;
- for (sal_uInt32 i = 0; i != n; ++i) {
- optBases.push_back(file->readNameLen(offset, &offset));
- }
- sal_uInt32 nAttrs = file->read32(offset);
- if (nAttrs > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct attributes of"
- " interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::InterfaceTypeEntity::Attribute > attrs;
- for (sal_uInt32 i = 0; i != nAttrs; ++i) {
- v = file->read8(offset);
- ++offset;
- rtl::OUString attrName(file->readNameLen(offset, &offset));
- rtl::OUString attrType(file->readNameLen(offset, &offset));
- if (v > 0x03) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad flags for direct attribute "
- + attrName + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- std::vector< rtl::OUString > getExcs;
- sal_uInt32 m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many getter exceptions for"
- " direct attribute " + attrName
- + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- for (sal_uInt32 j = 0; j != m; ++j) {
- getExcs.push_back(file->readNameLen(offset, &offset));
- }
- std::vector< rtl::OUString > setExcs;
- if ((v & 0x02) == 0) {
- m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many setter exceptions"
- " for direct attribute " + attrName
- + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- for (sal_uInt32 j = 0; j != m; ++j) {
- setExcs.push_back(file->readNameLen(offset, &offset));
- }
- }
- attrs.push_back(
- unoidl::InterfaceTypeEntity::Attribute(
- attrName, attrType, (v & 0x01) != 0, (v & 0x02) != 0,
- getExcs, setExcs));
- }
- sal_uInt32 nMeths = file->read32(offset);
- if (nMeths > SAL_MAX_INT32 - nAttrs) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct attributes and"
- " methods of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::InterfaceTypeEntity::Method > meths;
- for (sal_uInt32 i = 0; i != nMeths; ++i) {
- rtl::OUString methName(file->readNameLen(offset, &offset));
- rtl::OUString methType(file->readNameLen(offset, &offset));
- sal_uInt32 m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many parameters for method "
- + methName + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::InterfaceTypeEntity::Method::Parameter >
- params;
- for (sal_uInt32 j = 0; j != m; ++j) {
- v = file->read8(offset);
- ++offset;
- rtl::OUString paramName(
- file->readNameLen(offset, &offset));
- rtl::OUString paramType(
- file->readNameLen(offset, &offset));
- unoidl::InterfaceTypeEntity::Method::Parameter::Direction
- dir;
- switch (v) {
- case 0:
- dir = unoidl::InterfaceTypeEntity::Method::Parameter::
- DIRECTION_IN;
- break;
- case 1:
- dir = unoidl::InterfaceTypeEntity::Method::Parameter::
- DIRECTION_OUT;
- break;
- case 2:
- dir = unoidl::InterfaceTypeEntity::Method::Parameter::
- DIRECTION_IN_OUT;
- break;
- default:
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad direction "
- + rtl::OUString::number(v) + " of parameter "
- + paramName + " for method " + methName
- + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- params.push_back(
- unoidl::InterfaceTypeEntity::Method::Parameter(
- paramName, paramType, dir));
- }
- std::vector< rtl::OUString > excs;
- m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many exceptions for method "
- + methName + " of interface type"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- for (sal_uInt32 j = 0; j != m; ++j) {
- excs.push_back(file->readNameLen(offset, &offset));
- }
- meths.push_back(
- unoidl::InterfaceTypeEntity::Method(
- methName, methType, params, excs));
- }
- return new unoidl::InterfaceTypeEntity(
- published, mandBases, optBases, attrs, meths);
- }
- case 6: // typedef
- return new unoidl::TypedefEntity(
- published, file->readNameLen(offset + 1));
- case 7: // constant group
- {
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- "broken UNOIDL file: too many constants in constant group",
- css::uno::Reference< css::uno::XInterface >());
- }
- if (offset + 5 + 8 * n > file->size) { //TODO: overflow
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: constant group map offset + size too"
- " large"),
- css::uno::Reference< css::uno::XInterface >());
- }
- MapEntry const * p = reinterpret_cast< MapEntry const * >(
- static_cast< char const * >(file->address) + offset + 5);
- std::vector< unoidl::ConstantGroupEntity::Member > mems;
- for (sal_uInt32 i = 0; i != n; ++i) {
- mems.push_back(
- unoidl::ConstantGroupEntity::Member(
- file->readNameNul(p[i].name.getUnsigned32()),
- readConstant(file, p[i].data.getUnsigned32())));
- }
- return new unoidl::ConstantGroupEntity(published, mems);
- }
- case 8: // single-interface--based service without default constructor
- case 8 | 0x20: // single-interface--based service with default constructor
- {
- rtl::OUString base(file->readNameLen(offset + 1, &offset));
- std::vector<
- unoidl::SingleInterfaceBasedServiceEntity::Constructor >
- ctors;
- if (flag) {
- ctors.push_back(
- unoidl::SingleInterfaceBasedServiceEntity::Constructor());
- } else {
- sal_uInt32 n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many constructors of"
- " single-interface--based service"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- for (sal_uInt32 i = 0; i != n; ++i) {
- rtl::OUString ctorName(file->readNameLen(offset, &offset));
- sal_uInt32 m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many parameters for"
- " constructor " + ctorName
- + " of single-interface--based service"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector<
- unoidl::SingleInterfaceBasedServiceEntity::Constructor::
- Parameter > params;
- for (sal_uInt32 j = 0; j != m; ++j) {
- v = file->read8(offset);
- ++offset;
- rtl::OUString paramName(
- file->readNameLen(offset, &offset));
- rtl::OUString paramType(
- file->readNameLen(offset, &offset));
- bool rest;
- switch (v) {
- case 0:
- rest = false;
- break;
- case 0x04:
- rest = true;
- break;
- default:
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad mode "
- + rtl::OUString::number(v) + " of parameter "
- + paramName + " for constructor " + ctorName
- + " of single-interface--based service"),
- css::uno::Reference< css::uno::XInterface >());
- }
- params.push_back(
- unoidl::SingleInterfaceBasedServiceEntity::
- Constructor::Parameter(
- paramName, paramType, rest));
- }
- std::vector< rtl::OUString > excs;
- m = file->read32(offset);
- if (m > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many exceptions for"
- " constructor " + ctorName
- + " of single-interface--based service"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- for (sal_uInt32 j = 0; j != m; ++j) {
- excs.push_back(file->readNameLen(offset, &offset));
- }
- ctors.push_back(
- unoidl::SingleInterfaceBasedServiceEntity::Constructor(
- ctorName, params, excs));
- }
- }
- return new unoidl::SingleInterfaceBasedServiceEntity(
- published, base, ctors);
- }
- case 9: // accumulation-based service
- {
- sal_uInt32 n = file->read32(offset + 1);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct mandatory service"
- " bases of accumulation-based service"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 5;
- std::vector< rtl::OUString > mandServs;
- for (sal_uInt32 i = 0; i != n; ++i) {
- mandServs.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct optional service"
- " bases of accumulation-based servcie"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< rtl::OUString > optServs;
- for (sal_uInt32 i = 0; i != n; ++i) {
- optServs.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct mandatory interface"
- " bases of accumulation-based servcie"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< rtl::OUString > mandIfcs;
- for (sal_uInt32 i = 0; i != n; ++i) {
- mandIfcs.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct optional interface"
- " bases of accumulation-based servcie"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< rtl::OUString > optIfcs;
- for (sal_uInt32 i = 0; i != n; ++i) {
- optIfcs.push_back(file->readNameLen(offset, &offset));
- }
- n = file->read32(offset);
- if (n > SAL_MAX_INT32) {
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: too many direct properties of"
- " accumulation-based servcie"),
- css::uno::Reference< css::uno::XInterface >());
- }
- offset += 4;
- std::vector< unoidl::AccumulationBasedServiceEntity::Property >
- props;
- for (sal_uInt32 i = 0; i != n; ++i) {
- sal_uInt16 attrs = file->read16(offset);
- offset += 2;
- rtl::OUString propName(file->readNameLen(offset, &offset));
- rtl::OUString propType(file->readNameLen(offset, &offset));
- if (attrs > 0x01FF) { // see css.beans.PropertyAttribute
- throw css::uno::DeploymentException(
- ("broken UNOIDL file: bad mode "
- + rtl::OUString::number(v) + " of property " + propName
- + " for accumulation-based servcie"),
- css::uno::Reference< css::uno::XInterface >());
- }
- props.push_back(
- unoidl::AccumulationBasedServiceEntity::Property(
- propName, propType,
- static_cast<
- unoidl::AccumulationBasedServiceEntity::Property::
- Attributes >(
- attrs)));
- }
- return new unoidl::AccumulationBasedServiceEntity(
- published, mandServs, optServs, mandIfcs, optIfcs, props);
- }
- case 10: // interface-based singleton
- return new unoidl::InterfaceBasedSingletonEntity(
- published, file->readNameLen(offset + 1));
- case 11: // service-based singleton
- return new unoidl::ServiceBasedSingletonEntity(
- published, file->readNameLen(offset + 1));
- default:
- throw css::uno::DeploymentException(
- "broken UNOIDL file: bad type byte " + rtl::OUString::number(v),
- css::uno::Reference< css::uno::XInterface >());
- }
-}
-
-}
-
-UnoidlProvider::UnoidlProvider(rtl::OUString const & uri):
- file_(new MappedFile(uri))
-{
- if (file_->size < 8 || std::memcmp(file_->address, "UNOIDL\0\xFF", 8) != 0)
- {
- throw css::registry::InvalidRegistryException(
- uri, css::uno::Reference< css::uno::XInterface >());
- }
- sal_uInt32 off = file_->read32(8);
- mapSize_ = file_->read32(12);
- if (off + 8 * mapSize_ > file_->size) { //TODO: overflow
- throw css::uno::DeploymentException(
- "broken UNOIDL file: root map offset + size too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- mapBegin_ = reinterpret_cast< MapEntry const * >(
- static_cast< char const * >(file_->address) + off);
-}
-
-rtl::Reference< unoidl::MapCursor > UnoidlProvider::createRootCursor() const {
- return new UnoidlCursor(file_, mapBegin_, mapSize_);
-}
-
-sal_uInt32 UnoidlProvider::find(rtl::OUString const & name, bool * constant)
- const
-{
- MapEntry const * mapBegin = mapBegin_;
- sal_uInt32 mapSize = mapSize_;
- bool cgroup = false;
- for (sal_Int32 i = 0;;) {
- sal_Int32 j = name.indexOf('.', i);
- if (j == -1) {
- j = name.getLength();
- }
- sal_Int32 off = findInMap(file_, mapBegin, mapSize, name, i, j - i);
- if (off == 0) {
- return 0;
- }
- if (j == name.getLength()) {
- if (constant != 0) {
- *constant = cgroup;
- }
- return off;
- }
- if (cgroup) {
- return 0;
- //TODO: throw an exception instead here, where the segments of a
- // constant's name are a prefix of the requested name's
- // segments?
- }
- int v = file_->read8(off);
- if (v != 0) { // module
- if ((v & 0x3F) == 7) { // constant group
- cgroup = true;
- } else {
- return 0;
- //TODO: throw an exception instead here, where the segments
- // of a non-module, non-constant-group entity's name are a
- // prefix of the requested name's segments?
- }
- }
- mapSize = file_->read32(off + 1);
- if (8 * mapSize > file_->size - off - 5) { //TODO: overflow
- throw css::uno::DeploymentException(
- "broken UNOIDL file: map offset + size too large",
- css::uno::Reference< css::uno::XInterface >());
- }
- mapBegin = reinterpret_cast< MapEntry const * >(
- static_cast< char const * >(file_->address) + off + 5);
- i = j + 1;
- }
-}
-
-rtl::Reference< unoidl::Entity > UnoidlProvider::getEntity(sal_uInt32 offset)
- const
-{
- return readEntity(file_, offset);
-}
-
-css::uno::Any UnoidlProvider::getConstant(sal_uInt32 offset) const {
- return readConstant(file_, offset);
-}
-
-UnoidlProvider::~UnoidlProvider() throw () {}
-
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/cppuhelper/source/unoidlprovider.hxx b/cppuhelper/source/unoidlprovider.hxx
deleted file mode 100644
index 45089b9d688b..000000000000
--- a/cppuhelper/source/unoidlprovider.hxx
+++ /dev/null
@@ -1,54 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- */
-
-#ifndef INCLUDED_CPPUHELPER_SOURCE_UNOIDLPROVIDER_HXX
-#define INCLUDED_CPPUHELPER_SOURCE_UNOIDLPROVIDER_HXX
-
-#include "sal/config.h"
-
-#include "cppuhelper/unoidl.hxx"
-#include "rtl/ref.hxx"
-#include "sal/types.h"
-
-namespace com { namespace sun { namespace star { namespace uno {
- class Any;
-} } } }
-namespace cppu {
- class MappedFile;
- struct MapEntry;
-}
-namespace rtl { class OUString; }
-
-namespace cppu {
-
-class UnoidlProvider: public unoidl::Provider {
-public:
- explicit UnoidlProvider(rtl::OUString const & uri);
-
- virtual rtl::Reference< unoidl::MapCursor > createRootCursor() const;
-
- sal_uInt32 find(rtl::OUString const & name, bool * constant = 0) const;
-
- rtl::Reference< unoidl::Entity > getEntity(sal_uInt32 offset) const;
-
- css::uno::Any getConstant(sal_uInt32 offset) const;
-
-private:
- virtual ~UnoidlProvider() throw ();
-
- rtl::Reference< MappedFile > file_;
- MapEntry const * mapBegin_;
- sal_uInt32 mapSize_;
-};
-
-}
-
-#endif
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */