summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStephan Bergmann <sbergman@redhat.com>2013-05-16 14:50:21 +0200
committerStephan Bergmann <sbergman@redhat.com>2013-05-16 16:12:45 +0200
commita1dff2901e9b6f70ea87df5e76825367b38ceaf4 (patch)
treed1284375fd10c07c736c2edec450cfd823b096d0
parent08662568a590bfb20849fce077d8b5aff8b99b57 (diff)
Support for annotations in the new UNOIDL format
...used for now to transport @deprecated information. Also, improve Idx-String (formerly Idx-Name, but also used for UTF-8 annotations now) format, using the 0x80000000 for the indirection rather than the base case. (And the README erroneously used "Offset of" Idx-String all over the place.) Change-Id: I7003b1558ab536a11a9af308f9b16a7ef8840792
-rwxr-xr-xcodemaker/source/cppumaker/cpputype.cxx47
-rw-r--r--codemaker/source/cppumaker/dependencies.cxx4
-rw-r--r--codemaker/source/javamaker/javatype.cxx6
-rw-r--r--cppuhelper/source/typemanager.cxx15
-rw-r--r--include/unoidl/unoidl.hxx218
-rw-r--r--unodevtools/source/skeletonmaker/cpptypemaker.cxx18
-rw-r--r--unodevtools/source/skeletonmaker/javatypemaker.cxx16
-rw-r--r--unodevtools/source/skeletonmaker/skeletoncommon.cxx35
-rw-r--r--unoidl/README120
-rw-r--r--unoidl/source/legacyprovider.cxx117
-rw-r--r--unoidl/source/reg2unoidl.cxx339
-rw-r--r--unoidl/source/unoidlprovider.cxx338
12 files changed, 869 insertions, 404 deletions
diff --git a/codemaker/source/cppumaker/cpputype.cxx b/codemaker/source/cppumaker/cpputype.cxx
index 5d01a9f4bb37..9848f5790058 100755
--- a/codemaker/source/cppumaker/cpputype.cxx
+++ b/codemaker/source/cppumaker/cpputype.cxx
@@ -930,9 +930,15 @@ OUString CppuType::indent() const {
return buf.makeStringAndClear();
}
-bool isDocumentedDeprecated(OUString const & documentation) {
- return documentation.indexOf("@deprecated") != -1;
- //TODO: this check is somewhat crude
+bool isDeprecated(std::vector< OUString > const & annotations) {
+ for (std::vector< OUString >::const_iterator i(annotations.begin());
+ i != annotations.end(); ++i)
+ {
+ if (*i == "deprecated") {
+ return true;
+ }
+ }
+ return false;
}
void dumpDeprecation(FileStream & out, bool deprecated) {
@@ -963,16 +969,17 @@ void BaseOffset::calculateBases(
rtl::Reference< unoidl::InterfaceTypeEntity > const & entity)
{
assert(entity.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBases().begin());
i != entity->getDirectMandatoryBases().end(); ++i)
{
- if (set_.insert(*i).second) {
+ if (set_.insert(i->name).second) {
rtl::Reference< unoidl::Entity > ent;
- codemaker::UnoType::Sort sort = manager_->getSort(*i, &ent);
+ codemaker::UnoType::Sort sort = manager_->getSort(i->name, &ent);
if (sort != codemaker::UnoType::SORT_INTERFACE_TYPE) {
throw CannotDumpException(
- "interface type base " + *i + " is not an interface type");
+ "interface type base " + i->name
+ + " is not an interface type");
}
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
dynamic_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
@@ -1037,17 +1044,17 @@ InterfaceType::InterfaceType(
{
assert(entity.is());
m_inheritedMemberCount = 0;
- m_isDeprecated = isDocumentedDeprecated("TODO");
+ m_isDeprecated = isDeprecated(entity->getAnnotations());
}
void InterfaceType::dumpDeclaration(FileStream & out) {
out << "\nclass SAL_NO_VTABLE " << id_;
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity_->getDirectMandatoryBases().begin());
i != entity_->getDirectMandatoryBases().end(); ++i)
{
out << (i == entity_->getDirectMandatoryBases().begin() ? " :" : ",")
- << " public " << codemaker::cpp::scopedCppName(u2b(*i));
+ << " public " << codemaker::cpp::scopedCppName(u2b(i->name));
}
out << "\n{\npublic:\n";
inc();
@@ -1094,7 +1101,7 @@ void InterfaceType::dumpAttributes(FileStream & out) {
i(entity_->getDirectAttributes().begin());
i != entity_->getDirectAttributes().end(); ++i)
{
- bool depr = m_isDeprecated || isDocumentedDeprecated("TODO");
+ bool depr = m_isDeprecated || isDeprecated(i->annotations);
out << indent();
dumpDeprecation(out, depr);
out << "virtual ";
@@ -1124,7 +1131,7 @@ void InterfaceType::dumpMethods(FileStream & out) {
i != entity_->getDirectMethods().end(); ++i)
{
out << indent();
- dumpDeprecation(out, m_isDeprecated || isDocumentedDeprecated("TODO"));
+ dumpDeprecation(out, m_isDeprecated || isDeprecated(i->annotations));
out << "virtual ";
dumpType(out, i->returnType);
out << " SAL_CALL " << i->name << "(";
@@ -1169,10 +1176,10 @@ void InterfaceType::dumpNormalGetCppuType(FileStream & out) {
<< "static typelib_TypeDescriptionReference * the_type = 0;\n"
<< indent() << "if ( !the_type )\n" << indent() << "{\n";
inc();
- std::vector< OUString >::size_type bases(
+ std::vector< unoidl::AnnotatedReference >::size_type bases(
entity_->getDirectMandatoryBases().size());
if (bases == 1
- && (entity_->getDirectMandatoryBases()[0]
+ && (entity_->getDirectMandatoryBases()[0].name
== "com.sun.star.uno.XInterface"))
{
bases = 0;
@@ -1180,13 +1187,13 @@ void InterfaceType::dumpNormalGetCppuType(FileStream & out) {
if (bases != 0) {
out << indent() << "typelib_TypeDescriptionReference * aSuperTypes["
<< entity_->getDirectMandatoryBases().size() << "];\n";
- std::vector< OUString >::size_type n = 0;
- for (std::vector< OUString >::const_iterator i(
+ std::vector< unoidl::AnnotatedReference >::size_type n = 0;
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity_->getDirectMandatoryBases().begin());
i != entity_->getDirectMandatoryBases().end(); ++i)
{
out << indent() << "aSuperTypes[" << n++ << "] = ::cppu::UnoType< ";
- dumpType(out, *i, true, false, false, true);
+ dumpType(out, i->name, true, false, false, true);
out << " >::get().getTypeLibType();\n";
}
}
@@ -1215,13 +1222,13 @@ void InterfaceType::dumpComprehensiveGetCppuType(FileStream & out) {
<< indent() << "typelib_InterfaceTypeDescription * pTD = 0;\n\n";
out << indent() << "typelib_TypeDescriptionReference * aSuperTypes["
<< entity_->getDirectMandatoryBases().size() << "];\n";
- std::vector< OUString >::size_type n = 0;
- for (std::vector< OUString >::const_iterator i(
+ std::vector< unoidl::AnnotatedReference >::size_type n = 0;
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity_->getDirectMandatoryBases().begin());
i != entity_->getDirectMandatoryBases().end(); ++i)
{
out << indent() << "aSuperTypes[" << n++ << "] = ::cppu::UnoType< ";
- dumpType(out, *i, false, false, false, true);
+ dumpType(out, i->name, false, false, false, true);
out << " >::get().getTypeLibType();\n";
}
std::size_t count = entity_->getDirectAttributes().size()
diff --git a/codemaker/source/cppumaker/dependencies.cxx b/codemaker/source/cppumaker/dependencies.cxx
index 82ae4a1de026..b56bacfd4b1f 100644
--- a/codemaker/source/cppumaker/dependencies.cxx
+++ b/codemaker/source/cppumaker/dependencies.cxx
@@ -103,11 +103,11 @@ Dependencies::Dependencies(
{
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
static_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
- insert(*i, true);
+ insert(i->name, true);
}
if (!(ent2->getDirectAttributes().empty()
&& ent2->getDirectMethods().empty()))
diff --git a/codemaker/source/javamaker/javatype.cxx b/codemaker/source/javamaker/javatype.cxx
index 6f3186632fe1..d12f04e62a72 100644
--- a/codemaker/source/javamaker/javatype.cxx
+++ b/codemaker/source/javamaker/javatype.cxx
@@ -1810,12 +1810,12 @@ void handleInterfaceType(
| ClassFile::ACC_ABSTRACT),
className, "java/lang/Object", ""));
SAL_WNODEPRECATED_DECLARATIONS_POP
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBases().begin());
i != entity->getDirectMandatoryBases().end(); ++i)
{
- dependencies->insert(*i);
- cf->addInterface(codemaker::convertString(*i).replace('.', '/'));
+ dependencies->insert(i->name);
+ cf->addInterface(codemaker::convertString(i->name).replace('.', '/'));
}
// As a special case, let com.sun.star.lang.XEventListener extend
// java.util.EventListener ("A tagging interface that all event listener
diff --git a/cppuhelper/source/typemanager.cxx b/cppuhelper/source/typemanager.cxx
index 6f7cd898d464..672e377f6dc1 100644
--- a/cppuhelper/source/typemanager.cxx
+++ b/cppuhelper/source/typemanager.cxx
@@ -926,7 +926,7 @@ private:
getBaseType() throw (css::uno::RuntimeException) {
return entity_->getDirectMandatoryBases().empty()
? css::uno::Reference< css::reflection::XTypeDescription >()
- : manager_->resolve(entity_->getDirectMandatoryBases()[0]);
+ : manager_->resolve(entity_->getDirectMandatoryBases()[0].name);
}
virtual css::uno::Uik SAL_CALL getUik() throw (css::uno::RuntimeException)
@@ -988,7 +988,7 @@ InterfaceTypeDescription::getBaseTypes() throw (css::uno::RuntimeException) {
css::uno::Sequence<
css::uno::Reference< css::reflection::XTypeDescription > > s(n);
for (sal_Int32 i = 0; i != n; ++i) {
- s[i] = manager_->resolve(entity_->getDirectMandatoryBases()[i]);
+ s[i] = manager_->resolve(entity_->getDirectMandatoryBases()[i].name);
}
return s;
}
@@ -1003,7 +1003,7 @@ InterfaceTypeDescription::getOptionalBaseTypes()
css::uno::Sequence<
css::uno::Reference< css::reflection::XTypeDescription > > s(n);
for (sal_Int32 i = 0; i != n; ++i) {
- s[i] = manager_->resolve(entity_->getDirectOptionalBases()[i]);
+ s[i] = manager_->resolve(entity_->getDirectOptionalBases()[i].name);
}
return s;
}
@@ -1487,7 +1487,8 @@ AccumulationBasedServiceDescription::getMandatoryServices()
css::uno::Reference< css::reflection::XServiceTypeDescription > > s(n);
for (sal_Int32 i = 0; i != n; ++i) {
s[i].set(
- manager_->resolve(entity_->getDirectMandatoryBaseServices()[i]),
+ manager_->resolve(
+ entity_->getDirectMandatoryBaseServices()[i].name),
css::uno::UNO_QUERY_THROW);
}
return s;
@@ -1505,7 +1506,7 @@ AccumulationBasedServiceDescription::getOptionalServices()
css::uno::Reference< css::reflection::XServiceTypeDescription > > s(n);
for (sal_Int32 i = 0; i != n; ++i) {
s[i].set(
- manager_->resolve(entity_->getDirectOptionalBaseServices()[i]),
+ manager_->resolve(entity_->getDirectOptionalBaseServices()[i].name),
css::uno::UNO_QUERY_THROW);
}
return s;
@@ -1526,7 +1527,7 @@ AccumulationBasedServiceDescription::getMandatoryInterfaces()
s[i].set(
resolveTypedefs(
manager_->find(
- entity_->getDirectMandatoryBaseInterfaces()[i])),
+ entity_->getDirectMandatoryBaseInterfaces()[i].name)),
css::uno::UNO_QUERY_THROW);
}
return s;
@@ -1547,7 +1548,7 @@ AccumulationBasedServiceDescription::getOptionalInterfaces()
s[i].set(
resolveTypedefs(
manager_->find(
- entity_->getDirectOptionalBaseInterfaces()[i])),
+ entity_->getDirectOptionalBaseInterfaces()[i].name)),
css::uno::UNO_QUERY_THROW);
}
return s;
diff --git a/include/unoidl/unoidl.hxx b/include/unoidl/unoidl.hxx
index 9d774473c7ee..7a7c558bf2dc 100644
--- a/include/unoidl/unoidl.hxx
+++ b/include/unoidl/unoidl.hxx
@@ -65,6 +65,18 @@ private:
rtl::OUString detail_;
};
+struct AnnotatedReference {
+ AnnotatedReference(
+ rtl::OUString const & theName,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), annotations(theAnnotations)
+ {}
+
+ rtl::OUString name;
+
+ std::vector< rtl::OUString > annotations;
+};
+
class LO_DLLPUBLIC_UNOIDL Entity: public salhelper::SimpleReferenceObject {
public:
enum Sort {
@@ -115,32 +127,45 @@ class LO_DLLPUBLIC_UNOIDL PublishableEntity: public Entity {
public:
bool isPublished() const { return published_; }
+ std::vector< rtl::OUString > const & getAnnotations() const
+ { return annotations_; }
+
protected:
- SAL_DLLPRIVATE PublishableEntity(Sort sort, bool published):
- Entity(sort), published_(published)
+ SAL_DLLPRIVATE PublishableEntity(
+ Sort sort, bool published,
+ std::vector< rtl::OUString > const & annotations):
+ Entity(sort), published_(published), annotations_(annotations)
{}
virtual SAL_DLLPRIVATE ~PublishableEntity() throw ();
private:
bool published_;
+
+ std::vector< rtl::OUString > annotations_;
};
class LO_DLLPUBLIC_UNOIDL EnumTypeEntity: public PublishableEntity {
public:
struct Member {
- Member(rtl::OUString const & theName, sal_Int32 theValue):
- name(theName), value(theValue)
+ Member(
+ rtl::OUString const & theName, sal_Int32 theValue,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), value(theValue), annotations(theAnnotations)
{}
rtl::OUString name;
sal_Int32 value;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE EnumTypeEntity(
- bool published, std::vector< Member > const & members):
- PublishableEntity(SORT_ENUM_TYPE, published), members_(members)
+ bool published, std::vector< Member > const & members,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_ENUM_TYPE, published, annotations),
+ members_(members)
{ assert(!members.empty()); }
std::vector< Member > const & getMembers() const { return members_; }
@@ -154,19 +179,23 @@ private:
class LO_DLLPUBLIC_UNOIDL PlainStructTypeEntity: public PublishableEntity {
public:
struct Member {
- Member(rtl::OUString const & theName, rtl::OUString const & theType):
- name(theName), type(theType)
+ Member(rtl::OUString const & theName, rtl::OUString const & theType,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), type(theType), annotations(theAnnotations)
{}
rtl::OUString name;
rtl::OUString type;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE PlainStructTypeEntity(
bool published, rtl::OUString const & directBase,
- std::vector< Member > const & directMembers):
- PublishableEntity(SORT_PLAIN_STRUCT_TYPE, published),
+ std::vector< Member > const & directMembers,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_PLAIN_STRUCT_TYPE, published, annotations),
directBase_(directBase), directMembers_(directMembers)
{}
@@ -189,8 +218,10 @@ public:
struct Member {
Member(
rtl::OUString const & theName, rtl::OUString const & theType,
- bool theParameterized):
- name(theName), type(theType), parameterized(theParameterized)
+ bool theParameterized,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), type(theType), parameterized(theParameterized),
+ annotations(theAnnotations)
{}
rtl::OUString name;
@@ -198,12 +229,16 @@ public:
rtl::OUString type;
bool parameterized;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE PolymorphicStructTypeTemplateEntity(
bool published, std::vector< rtl::OUString > const & typeParameters,
- std::vector< Member > const & members):
- PublishableEntity(SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE, published),
+ std::vector< Member > const & members,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(
+ SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE, published, annotations),
typeParameters_(typeParameters), members_(members)
{}
@@ -222,19 +257,24 @@ private:
class LO_DLLPUBLIC_UNOIDL ExceptionTypeEntity: public PublishableEntity {
public:
struct Member {
- Member(rtl::OUString const & theName, rtl::OUString const & theType):
- name(theName), type(theType)
+ Member(
+ rtl::OUString const & theName, rtl::OUString const & theType,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), type(theType), annotations(theAnnotations)
{}
rtl::OUString name;
rtl::OUString type;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE ExceptionTypeEntity(
bool published, rtl::OUString const & directBase,
- std::vector< Member > const & directMembers):
- PublishableEntity(SORT_EXCEPTION_TYPE, published),
+ std::vector< Member > const & directMembers,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_EXCEPTION_TYPE, published, annotations),
directBase_(directBase), directMembers_(directMembers)
{}
@@ -257,10 +297,11 @@ public:
rtl::OUString const & theName, rtl::OUString const & theType,
bool theBound, bool theReadOnly,
std::vector< rtl::OUString > const & theGetExceptions,
- std::vector< rtl::OUString > const & theSetExceptions):
+ std::vector< rtl::OUString > const & theSetExceptions,
+ std::vector< rtl::OUString > const & theAnnotations):
name(theName), type(theType), bound(theBound),
readOnly(theReadOnly), getExceptions(theGetExceptions),
- setExceptions(theSetExceptions)
+ setExceptions(theSetExceptions), annotations(theAnnotations)
{ assert(!theReadOnly || theSetExceptions.empty()); }
rtl::OUString name;
@@ -274,6 +315,8 @@ public:
std::vector< rtl::OUString > getExceptions;
std::vector< rtl::OUString > setExceptions;
+
+ std::vector< rtl::OUString > annotations;
};
struct Method {
@@ -296,9 +339,10 @@ public:
Method(
rtl::OUString const & theName, rtl::OUString const & theReturnType,
std::vector< Parameter > const & theParameters,
- std::vector< rtl::OUString > const & theExceptions):
+ std::vector< rtl::OUString > const & theExceptions,
+ std::vector< rtl::OUString > const & theAnnotations):
name(theName), returnType(theReturnType), parameters(theParameters),
- exceptions(theExceptions)
+ exceptions(theExceptions), annotations(theAnnotations)
{}
rtl::OUString name;
@@ -308,24 +352,27 @@ public:
std::vector< Parameter > parameters;
std::vector< rtl::OUString > exceptions;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE InterfaceTypeEntity(
bool published,
- std::vector< rtl::OUString > const & directMandatoryBases,
- std::vector< rtl::OUString > const & directOptionalBases,
+ std::vector< AnnotatedReference > const & directMandatoryBases,
+ std::vector< AnnotatedReference > const & directOptionalBases,
std::vector< Attribute > const & directAttributes,
- std::vector< Method > const & directMethods):
- PublishableEntity(SORT_INTERFACE_TYPE, published),
+ std::vector< Method > const & directMethods,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_INTERFACE_TYPE, published, annotations),
directMandatoryBases_(directMandatoryBases),
directOptionalBases_(directOptionalBases),
directAttributes_(directAttributes), directMethods_(directMethods)
{}
- std::vector< rtl::OUString > const & getDirectMandatoryBases() const
+ std::vector< AnnotatedReference > const & getDirectMandatoryBases() const
{ return directMandatoryBases_; }
- std::vector< rtl::OUString > const & getDirectOptionalBases() const
+ std::vector< AnnotatedReference > const & getDirectOptionalBases() const
{ return directOptionalBases_; }
std::vector< Attribute > const & getDirectAttributes() const
@@ -337,16 +384,18 @@ public:
private:
virtual SAL_DLLPRIVATE ~InterfaceTypeEntity() throw ();
- std::vector< rtl::OUString > directMandatoryBases_;
- std::vector< rtl::OUString > directOptionalBases_;
+ std::vector< AnnotatedReference > directMandatoryBases_;
+ std::vector< AnnotatedReference > directOptionalBases_;
std::vector< Attribute > directAttributes_;
std::vector< Method > directMethods_;
};
class LO_DLLPUBLIC_UNOIDL TypedefEntity: public PublishableEntity {
public:
- SAL_DLLPRIVATE TypedefEntity(bool published, rtl::OUString const & type):
- PublishableEntity(SORT_TYPEDEF, published), type_(type)
+ SAL_DLLPRIVATE TypedefEntity(
+ bool published, rtl::OUString const & type,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_TYPEDEF, published, annotations), type_(type)
{}
rtl::OUString getType() const { return type_; }
@@ -363,36 +412,31 @@ struct LO_DLLPUBLIC_UNOIDL ConstantValue {
TYPE_UNSIGNED_LONG, TYPE_HYPER, TYPE_UNSIGNED_HYPER, TYPE_FLOAT,
TYPE_DOUBLE };
- explicit ConstantValue(bool value): type(TYPE_BOOLEAN), booleanValue(value)
- {}
+ ConstantValue(bool value): type(TYPE_BOOLEAN), booleanValue(value) {}
- explicit ConstantValue(sal_Int8 value): type(TYPE_BYTE), byteValue(value) {}
+ ConstantValue(sal_Int8 value): type(TYPE_BYTE), byteValue(value) {}
- explicit ConstantValue(sal_Int16 value): type(TYPE_SHORT), shortValue(value)
- {}
+ ConstantValue(sal_Int16 value): type(TYPE_SHORT), shortValue(value) {}
- explicit ConstantValue(sal_uInt16 value):
+ ConstantValue(sal_uInt16 value):
type(TYPE_UNSIGNED_SHORT), unsignedShortValue(value)
{}
- explicit ConstantValue(sal_Int32 value): type(TYPE_LONG), longValue(value)
- {}
+ ConstantValue(sal_Int32 value): type(TYPE_LONG), longValue(value) {}
- explicit ConstantValue(sal_uInt32 value):
+ ConstantValue(sal_uInt32 value):
type(TYPE_UNSIGNED_LONG), unsignedLongValue(value)
{}
- explicit ConstantValue(sal_Int64 value): type(TYPE_HYPER), hyperValue(value)
- {}
+ ConstantValue(sal_Int64 value): type(TYPE_HYPER), hyperValue(value) {}
- explicit ConstantValue(sal_uInt64 value):
+ ConstantValue(sal_uInt64 value):
type(TYPE_UNSIGNED_HYPER), unsignedHyperValue(value)
{}
- explicit ConstantValue(float value): type(TYPE_FLOAT), floatValue(value) {}
+ ConstantValue(float value): type(TYPE_FLOAT), floatValue(value) {}
- explicit ConstantValue(double value): type(TYPE_DOUBLE), doubleValue(value)
- {}
+ ConstantValue(double value): type(TYPE_DOUBLE), doubleValue(value) {}
Type type;
@@ -413,18 +457,24 @@ struct LO_DLLPUBLIC_UNOIDL ConstantValue {
class LO_DLLPUBLIC_UNOIDL ConstantGroupEntity: public PublishableEntity {
public:
struct Member {
- Member(rtl::OUString const & theName, ConstantValue const & theValue):
- name(theName), value(theValue)
+ Member(
+ rtl::OUString const & theName, ConstantValue const & theValue,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), value(theValue), annotations(theAnnotations)
{}
rtl::OUString name;
ConstantValue value;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE ConstantGroupEntity(
- bool published, std::vector< Member > const & members):
- PublishableEntity(SORT_CONSTANT_GROUP, published), members_(members)
+ bool published, std::vector< Member > const & members,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_CONSTANT_GROUP, published, annotations),
+ members_(members)
{}
std::vector< Member > const & getMembers() const { return members_; }
@@ -459,9 +509,10 @@ public:
Constructor(
rtl::OUString const & theName,
std::vector< Parameter > const & theParameters,
- std::vector< rtl::OUString > const & theExceptions):
+ std::vector< rtl::OUString > const & theExceptions,
+ std::vector< rtl::OUString > const & theAnnotations):
name(theName), parameters(theParameters), exceptions(theExceptions),
- defaultConstructor(false)
+ annotations(theAnnotations), defaultConstructor(false)
{}
rtl::OUString name;
@@ -470,13 +521,17 @@ public:
std::vector< rtl::OUString > exceptions;
+ std::vector< rtl::OUString > annotations;
+
bool defaultConstructor;
};
SAL_DLLPRIVATE SingleInterfaceBasedServiceEntity(
bool published, rtl::OUString const & base,
- std::vector< Constructor > const & constructors):
- PublishableEntity(SORT_SINGLE_INTERFACE_BASED_SERVICE, published),
+ std::vector< Constructor > const & constructors,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(
+ SORT_SINGLE_INTERFACE_BASED_SERVICE, published, annotations),
base_(base), constructors_(constructors)
{}
@@ -511,8 +566,10 @@ public:
Property(
rtl::OUString const & theName, rtl::OUString const & theType,
- Attributes theAttributes):
- name(theName), type(theType), attributes(theAttributes)
+ Attributes theAttributes,
+ std::vector< rtl::OUString > const & theAnnotations):
+ name(theName), type(theType), attributes(theAttributes),
+ annotations(theAnnotations)
{}
rtl::OUString name;
@@ -520,16 +577,20 @@ public:
rtl::OUString type;
Attributes attributes;
+
+ std::vector< rtl::OUString > annotations;
};
SAL_DLLPRIVATE AccumulationBasedServiceEntity(
bool published,
- std::vector< rtl::OUString > const & directMandatoryBaseServices,
- std::vector< rtl::OUString > const & directOptionalBaseServices,
- std::vector< rtl::OUString > const & directMandatoryBaseInterfaces,
- std::vector< rtl::OUString > const & directOptionalBaseInterfaces,
- std::vector< Property > const & directProperties):
- PublishableEntity(SORT_ACCUMULATION_BASED_SERVICE, published),
+ std::vector< AnnotatedReference > const & directMandatoryBaseServices,
+ std::vector< AnnotatedReference > const & directOptionalBaseServices,
+ std::vector< AnnotatedReference > const & directMandatoryBaseInterfaces,
+ std::vector< AnnotatedReference > const & directOptionalBaseInterfaces,
+ std::vector< Property > const & directProperties,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(
+ SORT_ACCUMULATION_BASED_SERVICE, published, annotations),
directMandatoryBaseServices_(directMandatoryBaseServices),
directOptionalBaseServices_(directOptionalBaseServices),
directMandatoryBaseInterfaces_(directMandatoryBaseInterfaces),
@@ -537,17 +598,20 @@ public:
directProperties_(directProperties)
{}
- std::vector< rtl::OUString > const & getDirectMandatoryBaseServices() const
+ std::vector< AnnotatedReference > const & getDirectMandatoryBaseServices()
+ const
{ return directMandatoryBaseServices_; }
- std::vector< rtl::OUString > const & getDirectOptionalBaseServices() const
+ std::vector< AnnotatedReference > const & getDirectOptionalBaseServices()
+ const
{ return directOptionalBaseServices_; }
- std::vector< rtl::OUString > const & getDirectMandatoryBaseInterfaces()
+ std::vector< AnnotatedReference > const & getDirectMandatoryBaseInterfaces()
const
{ return directMandatoryBaseInterfaces_; }
- std::vector< rtl::OUString > const & getDirectOptionalBaseInterfaces() const
+ std::vector< AnnotatedReference > const & getDirectOptionalBaseInterfaces()
+ const
{ return directOptionalBaseInterfaces_; }
std::vector< Property > const & getDirectProperties() const
@@ -556,10 +620,10 @@ public:
private:
virtual SAL_DLLPRIVATE ~AccumulationBasedServiceEntity() throw ();
- std::vector< rtl::OUString > directMandatoryBaseServices_;
- std::vector< rtl::OUString > directOptionalBaseServices_;
- std::vector< rtl::OUString > directMandatoryBaseInterfaces_;
- std::vector< rtl::OUString > directOptionalBaseInterfaces_;
+ std::vector< AnnotatedReference > directMandatoryBaseServices_;
+ std::vector< AnnotatedReference > directOptionalBaseServices_;
+ std::vector< AnnotatedReference > directMandatoryBaseInterfaces_;
+ std::vector< AnnotatedReference > directOptionalBaseInterfaces_;
std::vector< Property > directProperties_;
};
@@ -568,8 +632,10 @@ class LO_DLLPUBLIC_UNOIDL InterfaceBasedSingletonEntity:
{
public:
SAL_DLLPRIVATE InterfaceBasedSingletonEntity(
- bool published, rtl::OUString const & base):
- PublishableEntity(SORT_INTERFACE_BASED_SINGLETON, published),
+ bool published, rtl::OUString const & base,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(
+ SORT_INTERFACE_BASED_SINGLETON, published, annotations),
base_(base)
{}
@@ -585,8 +651,10 @@ class LO_DLLPUBLIC_UNOIDL ServiceBasedSingletonEntity: public PublishableEntity
{
public:
SAL_DLLPRIVATE ServiceBasedSingletonEntity(
- bool published, rtl::OUString const & base):
- PublishableEntity(SORT_SERVICE_BASED_SINGLETON, published), base_(base)
+ bool published, rtl::OUString const & base,
+ std::vector< rtl::OUString > const & annotations):
+ PublishableEntity(SORT_SERVICE_BASED_SINGLETON, published, annotations),
+ base_(base)
{}
rtl::OUString getBase() const { return base_; }
diff --git a/unodevtools/source/skeletonmaker/cpptypemaker.cxx b/unodevtools/source/skeletonmaker/cpptypemaker.cxx
index abd301269f7d..51a17c48b4bf 100644
--- a/unodevtools/source/skeletonmaker/cpptypemaker.cxx
+++ b/unodevtools/source/skeletonmaker/cpptypemaker.cxx
@@ -537,12 +537,12 @@ void printMethods(std::ostream & o,
dynamic_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
assert(ent2.is());
if (options.all || defaultvalue) {
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
printMethods(
- o, options, manager, *i, generated, delegate, classname,
+ o, options, manager, i->name, generated, delegate, classname,
indentation, defaultvalue, propertyhelper);
}
if (!(ent2->getDirectAttributes().empty()
@@ -737,20 +737,20 @@ void printServiceMembers(
OString const & delegate)
{
assert(entity.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBaseServices().begin());
i != entity->getDirectMandatoryBaseServices().end(); ++i)
{
- o << "\n// exported service " << *i << "\n";
- generateDocumentation(o, options, manager, u2b(*i), delegate);
- o << "\n// end of exported service " << *i << "\n";
+ o << "\n// exported service " << i->name << "\n";
+ generateDocumentation(o, options, manager, u2b(i->name), delegate);
+ o << "\n// end of exported service " << i->name << "\n";
}
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBaseInterfaces().begin());
i != entity->getDirectMandatoryBaseInterfaces().end(); ++i)
{
- o << "\n// supported interface " << *i << "\n";
- generateDocumentation(o, options, manager, u2b(*i), delegate);
+ o << "\n// supported interface " << i->name << "\n";
+ generateDocumentation(o, options, manager, u2b(i->name), delegate);
}
if (delegate.isEmpty()) {
o << "\n// properties of service \""<< name << "\"\n";
diff --git a/unodevtools/source/skeletonmaker/javatypemaker.cxx b/unodevtools/source/skeletonmaker/javatypemaker.cxx
index cb84458ac752..d6b29b00cf26 100644
--- a/unodevtools/source/skeletonmaker/javatypemaker.cxx
+++ b/unodevtools/source/skeletonmaker/javatypemaker.cxx
@@ -461,12 +461,12 @@ void printMethods(std::ostream & o,
dynamic_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
assert(ent2.is());
if ( options.all || defaultvalue ) {
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
printMethods(
- o, options, manager, *i, generated, delegate, indentation,
+ o, options, manager, i->name, generated, delegate, indentation,
defaultvalue, usepropertymixin);
}
if (!(ent2->getDirectAttributes().empty()
@@ -638,19 +638,19 @@ void printServiceMembers(
OString const & delegate)
{
assert(entity.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBaseServices().begin());
i != entity->getDirectMandatoryBaseServices().end(); ++i)
{
- o << "\n// exported service " << *i << "\n";
- generateDocumentation(o, options, manager, u2b(*i), delegate);
+ o << "\n// exported service " << i->name << "\n";
+ generateDocumentation(o, options, manager, u2b(i->name), delegate);
}
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
entity->getDirectMandatoryBaseInterfaces().begin());
i != entity->getDirectMandatoryBaseInterfaces().end(); ++i)
{
- o << "\n// supported interface " << *i << "\n";
- generateDocumentation(o, options, manager, u2b(*i), delegate);
+ o << "\n// supported interface " << i->name << "\n";
+ generateDocumentation(o, options, manager, u2b(i->name), delegate);
}
o << "\n// properties of service \""<< name << "\"\n";
for (std::vector< unoidl::AccumulationBasedServiceEntity::Property >::
diff --git a/unodevtools/source/skeletonmaker/skeletoncommon.cxx b/unodevtools/source/skeletonmaker/skeletoncommon.cxx
index a8957aa9c2d3..e66b39acb981 100644
--- a/unodevtools/source/skeletonmaker/skeletoncommon.cxx
+++ b/unodevtools/source/skeletonmaker/skeletoncommon.cxx
@@ -122,11 +122,11 @@ void checkAttributes(rtl::Reference< TypeManager > const & manager,
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
dynamic_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
assert(ent2.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
- checkAttributes(manager, *i, attributes, propinterfaces);
+ checkAttributes(manager, i->name, attributes, propinterfaces);
}
for (std::vector< unoidl::InterfaceTypeEntity::Attribute >::
const_iterator i(ent2->getDirectAttributes().begin());
@@ -146,7 +146,8 @@ void checkAttributes(rtl::Reference< TypeManager > const & manager,
| (i->readOnly
? (unoidl::AccumulationBasedServiceEntity::
Property::ATTRIBUTE_READ_ONLY)
- : 0))))));
+ : 0)))),
+ std::vector< OUString >()));
}
}
break;
@@ -157,17 +158,17 @@ void checkAttributes(rtl::Reference< TypeManager > const & manager,
dynamic_cast< unoidl::AccumulationBasedServiceEntity * >(
ent.get()));
assert(ent2.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBaseServices().begin());
i != ent2->getDirectMandatoryBaseServices().end(); ++i)
{
- checkAttributes(manager, *i, attributes, propinterfaces);
+ checkAttributes(manager, i->name, attributes, propinterfaces);
}
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBaseInterfaces().begin());
i != ent2->getDirectMandatoryBaseInterfaces().end(); ++i)
{
- checkAttributes(manager, *i, attributes, propinterfaces);
+ checkAttributes(manager, i->name, attributes, propinterfaces);
}
for (std::vector<
unoidl::AccumulationBasedServiceEntity::Property >::
@@ -237,19 +238,19 @@ void checkType(rtl::Reference< TypeManager > const & manager,
dynamic_cast< unoidl::AccumulationBasedServiceEntity * >(
ent.get()));
assert(ent2.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBaseServices().begin());
i != ent2->getDirectMandatoryBaseServices().end(); ++i)
{
checkType(
- manager, *i, interfaceTypes, serviceTypes, properties);
+ manager, i->name, interfaceTypes, serviceTypes, properties);
}
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBaseInterfaces().begin());
i != ent2->getDirectMandatoryBaseInterfaces().end(); ++i)
{
checkType(
- manager, *i, interfaceTypes, serviceTypes, properties);
+ manager, i->name, interfaceTypes, serviceTypes, properties);
}
for (std::vector<
unoidl::AccumulationBasedServiceEntity::Property >::
@@ -307,11 +308,11 @@ bool checkServiceProperties(rtl::Reference< TypeManager > const & manager,
if (!ent2->getDirectProperties().empty()) {
return true;
}
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBaseServices().begin());
i != ent2->getDirectMandatoryBaseServices().end(); ++i)
{
- if (checkServiceProperties(manager, *i)) {
+ if (checkServiceProperties(manager, i->name)) {
return true;
}
}
@@ -391,11 +392,11 @@ bool checkXComponentSupport(
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
dynamic_cast< unoidl::InterfaceTypeEntity * >(ent.get()));
assert(ent2.is());
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
- if (checkXComponentSupport(manager, *i)) {
+ if (checkXComponentSupport(manager, i->name)) {
return true;
}
}
@@ -587,12 +588,12 @@ void generateFunctionParameterMap(std::ostream& o,
// check if the specified add-in functions supports valid types
checkAddInTypes(manager, name, ent2);
- for (std::vector< OUString >::const_iterator i(
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator i(
ent2->getDirectMandatoryBases().begin());
i != ent2->getDirectMandatoryBases().end(); ++i)
{
generateFunctionParameterMap(
- o, options, manager, *i, generated, bFirst);
+ o, options, manager, i->name, generated, bFirst);
}
if ( generated.contains(u2b(name)) )
diff --git a/unoidl/README b/unoidl/README
index 5daff7a618c2..84246e9db876 100644
--- a/unoidl/README
+++ b/unoidl/README
@@ -27,6 +27,18 @@ quantities are stored LSB first, without alignment requirements. Offsets are
considered a limitation in practice (and avoids unnecessary bloat compared to
64 bit offsets).
+Annotations can be added for (non-module) entities and certain parts of such
+entities (e.g., both for an interface type definition and for a direct method of
+an interface type definition; the idea is that it can be added for direct parts
+that forma a "many-to-one" relationship; there is a tradeoff between generality
+of concept and size of representation, esp. for the C++ representation types in
+namespace unoidl) and consist of arbitrary sequences of name/value strings.
+Each name/value string is encoded as a single UTF-8 string containing a name (an
+arbitrary sequence of Unicode code points not containing U+003D EQUALS SIGN),
+optionally followed by U+003D EQUALS SIGN and a value (an abritrary sequence of
+Unicode code points). The only annotation name currently in use is "deprecated"
+(without a value).
+
The following definitions are used throughout:
* UInt16: 2-byte value, LSB first
@@ -34,10 +46,12 @@ The following definitions are used throughout:
* 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
+* Len-String: UInt32 number of characters, with 0x80000000 bit 0, followed by
+ that many US-ASCII (for UNOIDL related names) resp. UTF-8 (for annotations)
+ bytes
+* Idx-String: either an Offset (with 0x80000000 bit 1) of a Len-String, or a
+ Len-String
+* Annotations: UInt32 number N of annotations followed by N * Idx-String
* Entry: Offset of NUL-Name followed by Offset of payload
* Map: zero or more Entries
@@ -68,7 +82,7 @@ Layout of per-entry payload in the root or a module Map:
** otherwise:
*** 0x80 bit: 1 if published
-*** 0x40 bit: 1 if deprecated
+*** 0x40 bit: 1 if annotated
*** 0x20 bit: flag (may only be 1 for certain kinds, see below)
*** remaining bits:
@@ -76,67 +90,77 @@ Layout of per-entry payload in the root or a module Map:
***** followed by:
****** UInt32 number N1 of members
****** N1 * tuple of:
-******* Offset of Idx-Name
+******* Idx-String
******* UInt32
+******* if annotated: Annotations
**** 2: plain struct type (with base if flag is 1)
***** followed by:
-****** if "with base": Offset of Idx-Name
+****** if "with base": Idx-String
****** UInt32 number N1 of direct members
****** N1 * tuple of:
-******* Offset of Idx-Name name
-******* Offset of Idx-Name type
+******* Idx-String name
+******* Idx-String type
+******* if annotated: Annotations
**** 3: polymorphic struct type template
***** followed by:
****** UInt32 number N1 of type parameters
-****** N1 * Offset of Idx-Name
+****** N1 * Idx-String
****** 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
+******* Idx-String name
+******* Idx-String type
+******* if annotated: Annotations
**** 4: exception type (with base if flag is 1)
***** followed by:
-****** if "with base": Offset of Idx-Name
+****** if "with base": Idx-String
****** UInt32 number N1 of direct members
****** N1 * tuple of:
-******* Offset of Idx-Name name
-******* Offset of Idx-Name type
+******* Idx-String name
+******* Idx-String type
+******* if annotated: Annotations
**** 5: interface type
***** followed by:
****** UInt32 number N1 of direct mandatory bases
-****** N1 * Offset of Idx-Name
+****** N1 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** UInt32 number N2 of direct optional bases
-****** N2 * Offset of Idx-Name
+****** N2 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** 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
+******* Idx-String name
+******* Idx-String type
******* UInt32 number N4 of get exceptions
-******* N4 * Offset of Idx-Name
+******* N4 * Idx-String
******* UInt32 number N5 of set exceptions
-******* N5 * Offset of Idx-Name
+******* N5 * Idx-String
+******* if annotated: Annotations
****** UInt32 number N6 of direct methods
****** N6 * tuple of:
-******* Offset of Idx-Name name
-******* Offset of Idx-Name return type
+******* Idx-String name
+******* Idx-String 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
+******** Idx-String name
+******** Idx-String type
******* UInt32 number N8 of exceptions
-******* N8 * Offset of Idx-Name
+******* N8 * Idx-String
+******* if annotated: Annotations
**** 6: typedef
***** followed by:
-****** Offset of Idx-Name
+****** Idx-String
**** 7: constant group
***** followed by:
@@ -145,29 +169,38 @@ Layout of per-entry payload in the root or a module Map:
**** 8: single-interface--based service (with default constructor if flag is 1)
***** followed by:
-****** Offset of Idx-Name
+****** Idx-String
****** if not "with default constructor":
******* UInt32 number N1 of constructors
******* N1 * tuple of:
-******** Offset of Idx-Name
+******** Idx-String
******** 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
+********* Idx-String name
+********* Idx-String type
******** UInt32 number N3 of exceptions
-******** N3 * Offset of Idx-Name
+******** N3 * Idx-String
+******** if annotated: Annotations
**** 9: accumulation-based service
***** followed by:
****** UInt32 number N1 of direct mandatory base services
-****** N1 * Offset of Idx-Name
+****** N1 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** UInt32 number N2 of direct optional base services
-****** N2 * Offset of Idx-Name
+****** N2 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** UInt32 number N3 of direct mandatory base interfaces
-****** N3 * Offset of Idx-Name
+****** N3 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** UInt32 number N4 of direct optional base interfaces
-****** N4 * Offset of Idx-Name
+****** N4 * tuple of:
+******* Idx-String
+******* if annotated: Annotations
****** UInt32 number N5 of direct properties
****** N5 * tuple of:
******* UInt16 kind:
@@ -180,21 +213,24 @@ Layout of per-entry payload in the root or a module Map:
******** 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
+******* Idx-String name
+******* Idx-String type
+******* if annotated: Annotations
**** 10: interface-based singleton
***** followed by:
-****** Offset of Idx-Name
+****** Idx-String
**** 11: service-based singleton
***** followed by:
-****** Offset of Idx-Name
+****** Idx-String
+
+*** if annotated, followed by: Annotations
Layout of per-entry payload in a constant group Map:
* kind byte:
-** 0x80 bit: 1 if deprecated
+** 0x80 bit: 1 if annotated
** remaining bits:
*** 0: BOOLEAN
@@ -228,3 +264,5 @@ Layout of per-entry payload in a constant group Map:
*** 9: DOUBLE
**** followed by 8-byte value, representing values in ISO 60599 binary64 format,
LSB first
+
+* if annotated, followed by: Annotations
diff --git a/unoidl/source/legacyprovider.cxx b/unoidl/source/legacyprovider.cxx
index 485b43d48055..17b95dcd629c 100644
--- a/unoidl/source/legacyprovider.cxx
+++ b/unoidl/source/legacyprovider.cxx
@@ -26,6 +26,15 @@ namespace unoidl {
namespace {
+std::vector< OUString > translateAnnotations(OUString const & documentation) {
+ std::vector< OUString > ans;
+ if (documentation.indexOf("@deprecated") != -1) {
+ //TODO: this check is somewhat crude
+ ans.push_back("deprecated");
+ }
+ return ans;
+}
+
ConstantValue translateConstantValue(
RegistryKey & key, RTConstValue const & value)
{
@@ -219,17 +228,22 @@ rtl::Reference< Entity > readEntity(
switch (reader.getTypeClass()) {
case RT_TYPE_INTERFACE:
{
- std::vector< OUString > mandBases;
+ std::vector< AnnotatedReference > mandBases;
sal_uInt16 n = reader.getSuperTypeCount();
for (sal_uInt16 j = 0; j != n; ++j) {
mandBases.push_back(
- reader.getSuperTypeName(j).replace('/', '.'));
+ AnnotatedReference(
+ reader.getSuperTypeName(j).replace('/', '.'),
+ std::vector< OUString >()));
}
- std::vector< OUString > optBases;
+ std::vector< AnnotatedReference > optBases;
n = reader.getReferenceCount();
for (sal_uInt16 j = 0; j != n; ++j) {
optBases.push_back(
- reader.getReferenceTypeName(j).replace('/', '.'));
+ AnnotatedReference(
+ reader.getReferenceTypeName(j).replace('/', '.'),
+ translateAnnotations(
+ reader.getReferenceDocumentation(j))));
}
sal_uInt16 methodCount = reader.getMethodCount();
std::vector< InterfaceTypeEntity::Attribute > attrs;
@@ -278,7 +292,8 @@ rtl::Reference< Entity > readEntity(
InterfaceTypeEntity::Attribute(
attrName, reader.getFieldTypeName(j).replace('/', '.'),
(flags & RT_ACCESS_BOUND) != 0,
- (flags & RT_ACCESS_READONLY) != 0, getExcs, setExcs));
+ (flags & RT_ACCESS_READONLY) != 0, getExcs, setExcs,
+ translateAnnotations(reader.getFieldDocumentation(j))));
}
std::vector< InterfaceTypeEntity::Method > meths;
for (sal_uInt16 j = 0; j != methodCount; ++j) {
@@ -330,11 +345,14 @@ rtl::Reference< Entity > readEntity(
InterfaceTypeEntity::Method(
reader.getMethodName(j),
reader.getMethodReturnTypeName(j).replace('/', '.'),
- params, excs));
+ params, excs,
+ translateAnnotations(
+ reader.getMethodDocumentation(j))));
}
}
return new InterfaceTypeEntity(
- reader.isPublished(), mandBases, optBases, attrs, meths);
+ reader.isPublished(), mandBases, optBases, attrs, meths,
+ translateAnnotations(reader.getDocumentation()));
}
case RT_TYPE_MODULE:
return new Module(manager, ucr, sub);
@@ -363,10 +381,13 @@ rtl::Reference< Entity > readEntity(
mems.push_back(
PlainStructTypeEntity::Member(
reader.getFieldName(j),
- reader.getFieldTypeName(j).replace('/', '.')));
+ reader.getFieldTypeName(j).replace('/', '.'),
+ translateAnnotations(
+ reader.getFieldDocumentation(j))));
}
return new PlainStructTypeEntity(
- reader.isPublished(), base, mems);
+ reader.isPublished(), base, mems,
+ translateAnnotations(reader.getDocumentation()));
} else {
if (reader.getSuperTypeCount() != 0) {
FileFormatException(
@@ -390,10 +411,13 @@ rtl::Reference< Entity > readEntity(
reader.getFieldTypeName(j).replace('/', '.'),
((reader.getFieldFlags(j)
& RT_ACCESS_PARAMETERIZED_TYPE)
- != 0)));
+ != 0),
+ translateAnnotations(
+ reader.getFieldDocumentation(j))));
}
return new PolymorphicStructTypeTemplateEntity(
- reader.isPublished(), params, mems);
+ reader.isPublished(), params, mems,
+ translateAnnotations(reader.getDocumentation()));
}
}
case RT_TYPE_ENUM:
@@ -412,9 +436,13 @@ rtl::Reference< Entity > readEntity(
}
mems.push_back(
EnumTypeEntity::Member(
- reader.getFieldName(j), v.m_value.aLong));
+ reader.getFieldName(j), v.m_value.aLong,
+ translateAnnotations(reader.getFieldDocumentation(j))));
+
}
- return new EnumTypeEntity(reader.isPublished(), mems);
+ return new EnumTypeEntity(
+ reader.isPublished(), mems,
+ translateAnnotations(reader.getDocumentation()));
}
case RT_TYPE_EXCEPTION:
{
@@ -439,9 +467,12 @@ rtl::Reference< Entity > readEntity(
mems.push_back(
ExceptionTypeEntity::Member(
reader.getFieldName(j),
- reader.getFieldTypeName(j).replace('/', '.')));
+ reader.getFieldTypeName(j).replace('/', '.'),
+ translateAnnotations(reader.getFieldDocumentation(j))));
}
- return new ExceptionTypeEntity(reader.isPublished(), base, mems);
+ return new ExceptionTypeEntity(
+ reader.isPublished(), base, mems,
+ translateAnnotations(reader.getDocumentation()));
}
case RT_TYPE_TYPEDEF:
if (reader.getSuperTypeCount() != 1) {
@@ -452,36 +483,39 @@ rtl::Reference< Entity > readEntity(
+ " of super-types of typedef with key " + sub.getName()));
}
return new TypedefEntity(
- reader.isPublished(), reader.getSuperTypeName(0).replace('/', '.'));
+ reader.isPublished(), reader.getSuperTypeName(0).replace('/', '.'),
+ translateAnnotations(reader.getDocumentation()));
case RT_TYPE_SERVICE:
switch (reader.getSuperTypeCount()) {
case 0:
{
- std::vector< OUString > mandServs;
- std::vector< OUString > optServs;
- std::vector< OUString > mandIfcs;
- std::vector< OUString > optIfcs;
+ std::vector< AnnotatedReference > mandServs;
+ std::vector< AnnotatedReference > optServs;
+ std::vector< AnnotatedReference > mandIfcs;
+ std::vector< AnnotatedReference > optIfcs;
sal_uInt16 n = reader.getReferenceCount();
for (sal_uInt16 j = 0; j != n; ++j) {
- OUString refName(
- reader.getReferenceTypeName(j).replace('/', '.'));
+ AnnotatedReference base(
+ reader.getReferenceTypeName(j).replace('/', '.'),
+ translateAnnotations(
+ reader.getReferenceDocumentation(j)));
switch (reader.getReferenceSort(j)) {
case RT_REF_EXPORTS:
if ((reader.getReferenceFlags(j) & RT_ACCESS_OPTIONAL)
== 0)
{
- mandServs.push_back(refName);
+ mandServs.push_back(base);
} else {
- optServs.push_back(refName);
+ optServs.push_back(base);
}
break;
case RT_REF_SUPPORTS:
if ((reader.getReferenceFlags(j) & RT_ACCESS_OPTIONAL)
== 0)
{
- mandIfcs.push_back(refName);
+ mandIfcs.push_back(base);
} else {
- optIfcs.push_back(refName);
+ optIfcs.push_back(base);
}
break;
default:
@@ -540,11 +574,14 @@ rtl::Reference< Entity > readEntity(
reader.getFieldTypeName(j).replace('/', '.'),
static_cast<
AccumulationBasedServiceEntity::Property::
- Attributes >(attrs)));
+ Attributes >(attrs),
+ translateAnnotations(
+ reader.getFieldDocumentation(j))));
}
return new AccumulationBasedServiceEntity(
reader.isPublished(), mandServs, optServs, mandIfcs,
- optIfcs, props);
+ optIfcs, props,
+ translateAnnotations(reader.getDocumentation()));
}
case 1:
{
@@ -615,17 +652,20 @@ rtl::Reference< Entity > readEntity(
m = reader.getMethodExceptionCount(j);
for (sal_uInt16 k = 0; k != m; ++k) {
excs.push_back(
- reader.getMethodExceptionTypeName(j, k).
- replace('/', '.'));
+ reader.getMethodExceptionTypeName(j, k).replace(
+ '/', '.'));
}
ctors.push_back(
SingleInterfaceBasedServiceEntity::Constructor(
- reader.getMethodName(j), params, excs));
+ reader.getMethodName(j), params, excs,
+ translateAnnotations(
+ reader.getMethodDocumentation(j))));
}
}
return new SingleInterfaceBasedServiceEntity(
reader.isPublished(),
- reader.getSuperTypeName(0).replace('/', '.'), ctors);
+ reader.getSuperTypeName(0).replace('/', '.'), ctors,
+ translateAnnotations(reader.getDocumentation()));
}
default:
throw FileFormatException(
@@ -702,10 +742,12 @@ rtl::Reference< Entity > readEntity(
return newStyle
? rtl::Reference< Entity >(
new InterfaceBasedSingletonEntity(
- reader.isPublished(), baseName))
+ reader.isPublished(), baseName,
+ translateAnnotations(reader.getDocumentation())))
: rtl::Reference< Entity >(
new ServiceBasedSingletonEntity(
- reader.isPublished(), baseName));
+ reader.isPublished(), baseName,
+ translateAnnotations(reader.getDocumentation())));
}
case RT_TYPE_CONSTANTS:
{
@@ -715,9 +757,12 @@ rtl::Reference< Entity > readEntity(
mems.push_back(
ConstantGroupEntity::Member(
reader.getFieldName(j),
- translateConstantValue(sub, reader.getFieldValue(j))));
+ translateConstantValue(sub, reader.getFieldValue(j)),
+ translateAnnotations(reader.getFieldDocumentation(j))));
}
- return new ConstantGroupEntity(reader.isPublished(), mems);
+ return new ConstantGroupEntity(
+ reader.isPublished(), mems,
+ translateAnnotations(reader.getDocumentation()));
}
default:
throw FileFormatException(
diff --git a/unoidl/source/reg2unoidl.cxx b/unoidl/source/reg2unoidl.cxx
index 2bd9e56b6582..bf2b6d271ab2 100644
--- a/unoidl/source/reg2unoidl.cxx
+++ b/unoidl/source/reg2unoidl.cxx
@@ -201,7 +201,21 @@ OString toAscii(OUString const & name) {
return ascii;
}
-sal_uInt64 writeNameNul(osl::File & file, OUString const & name) {
+OString toUtf8(OUString const & string) {
+ OString ascii;
+ if (!string.convertToString(
+ &ascii, RTL_TEXTENCODING_UTF8,
+ (RTL_UNICODETOTEXT_FLAGS_UNDEFINED_ERROR
+ | RTL_UNICODETOTEXT_FLAGS_INVALID_ERROR)))
+ {
+ std::cerr
+ << "Cannot convert \"" << string << "\" to UTF-8" << std::endl;
+ std::exit(EXIT_FAILURE);
+ }
+ return ascii;
+}
+
+sal_uInt64 writeNulName(osl::File & file, OUString const & name) {
OString ascii(toAscii(name));
if (ascii.indexOf('\0') != -1) {
std::cerr
@@ -213,33 +227,57 @@ sal_uInt64 writeNameNul(osl::File & file, OUString const & name) {
return off;
}
-void writeNameLen(osl::File & file, OUString const & name) {
- static std::map< OUString, sal_uInt64 > reuse;
- std::map< OUString, sal_uInt64 >::iterator i(reuse.find(name));
+void writeIdxString(osl::File & file, OString const & string) {
+ static std::map< OString, sal_uInt64 > reuse;
+ std::map< OString, sal_uInt64 >::iterator i(reuse.find(string));
if (i == reuse.end()) {
- reuse.insert(std::make_pair(name, getOffset(file)));
- OString ascii(toAscii(name));
+ reuse.insert(std::make_pair(string, getOffset(file)));
assert(
- (static_cast< sal_uInt64 >(ascii.getLength()) & 0x80000000) == 0);
- write32(
- file, static_cast< sal_uInt64 >(ascii.getLength()) | 0x80000000);
- write(file, ascii.getStr(), ascii.getLength());
+ (static_cast< sal_uInt64 >(string.getLength()) & 0x80000000) == 0);
+ write32(file, static_cast< sal_uInt64 >(string.getLength()));
+ write(file, string.getStr(), string.getLength());
} else {
- write32(file, i->second);
+ if ((i->second & 0x80000000) != 0) {
+ std::cerr
+ << "Cannot write index 0x" << std::hex << i->second << std::dec
+ << " of \"" << string << "\"; input is too large" << std::endl;
+ std::exit(EXIT_FAILURE);
+ }
+ write32(file, i->second | 0x80000000);
+ }
+}
+
+void writeIdxName(osl::File & file, OUString const & name) {
+ writeIdxString(file, toAscii(name));
+}
+
+void writeAnnotations(
+ osl::File & file, bool annotate,
+ std::vector< OUString > const & annotations)
+{
+ assert(annotate || annotations.empty());
+ if (annotate) {
+ write32(file, annotations.size());
+ // overflow from std::vector::size_type -> sal_uInt64 is unrealistic
+ for (std::vector< OUString >::const_iterator i(annotations.begin());
+ i != annotations.end(); ++i)
+ {
+ writeIdxString(file, toUtf8(*i));
+ }
}
}
void writeKind(
osl::File & file,
rtl::Reference< unoidl::PublishableEntity > const & entity,
- bool flag = false)
+ bool annotated, bool flag = false)
{
assert(entity.is());
sal_uInt64 v = entity->getSort();
if (entity->isPublished()) {
v |= 0x80;
}
- if (false /*TODO: deprecated */) {
+ if (annotated) {
v |= 0x40;
}
if (flag) {
@@ -250,7 +288,7 @@ void writeKind(
struct Item {
explicit Item(rtl::Reference< unoidl::Entity > const & theEntity):
- entity(theEntity),nameOffset(0),dataOffset(0)
+ entity(theEntity), nameOffset(0), dataOffset(0)
{}
rtl::Reference< unoidl::Entity > entity;
@@ -259,11 +297,15 @@ struct Item {
};
struct ConstItem {
- explicit ConstItem(unoidl::ConstantValue const & theConstant):
- constant(theConstant),nameOffset(0),dataOffset(0)
+ ConstItem(
+ unoidl::ConstantValue const & theConstant,
+ std::vector< OUString > const & theAnnotations):
+ constant(theConstant), annotations(theAnnotations), nameOffset(0),
+ dataOffset(0)
{}
unoidl::ConstantValue constant;
+ std::vector< OUString > annotations;
sal_uInt64 nameOffset;
sal_uInt64 dataOffset;
};
@@ -302,16 +344,25 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::EnumTypeEntity > ent2(
static_cast< unoidl::EnumTypeEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector< unoidl::EnumTypeEntity::Member >::
+ const_iterator j(ent2->getMembers().begin());
+ !ann && j != ent2->getMembers().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
+ writeKind(file, ent2.get(), ann);
write32(file, ent2->getMembers().size());
for (std::vector< unoidl::EnumTypeEntity::Member >::
const_iterator j(ent2->getMembers().begin());
j != ent2->getMembers().end(); ++j)
{
- writeNameLen(file, j->name);
+ writeIdxName(file, j->name);
write32(file, static_cast< sal_uInt32 >(j->value));
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_PLAIN_STRUCT_TYPE:
@@ -319,19 +370,29 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::PlainStructTypeEntity > ent2(
static_cast< unoidl::PlainStructTypeEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector< unoidl::PlainStructTypeEntity::Member >::
+ const_iterator j(ent2->getDirectMembers().begin());
+ !ann && j != ent2->getDirectMembers().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get(), !ent2->getDirectBase().isEmpty());
+ writeKind(
+ file, ent2.get(), ann, !ent2->getDirectBase().isEmpty());
if (!ent2->getDirectBase().isEmpty()) {
- writeNameLen(file, ent2->getDirectBase());
+ writeIdxName(file, ent2->getDirectBase());
}
write32(file, ent2->getDirectMembers().size());
for (std::vector< unoidl::PlainStructTypeEntity::Member >::
const_iterator j(ent2->getDirectMembers().begin());
j != ent2->getDirectMembers().end(); ++j)
{
- writeNameLen(file, j->name);
- writeNameLen(file, j->type);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->type);
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_POLYMORPHIC_STRUCT_TYPE_TEMPLATE:
@@ -341,14 +402,23 @@ sal_uInt64 writeMap(
static_cast<
unoidl::PolymorphicStructTypeTemplateEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector<
+ unoidl::PolymorphicStructTypeTemplateEntity::Member >::
+ const_iterator j(
+ ent2->getMembers().begin());
+ !ann && j != ent2->getMembers().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
+ writeKind(file, ent2.get(), ann);
write32(file, ent2->getTypeParameters().size());
for (std::vector< OUString >::const_iterator j(
ent2->getTypeParameters().begin());
j != ent2->getTypeParameters().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, *j);
}
write32(file, ent2->getMembers().size());
for (std::vector<
@@ -362,9 +432,11 @@ sal_uInt64 writeMap(
f |= 0x01;
}
write8(file, f);
- writeNameLen(file, j->name);
- writeNameLen(file, j->type);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->type);
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_EXCEPTION_TYPE:
@@ -372,19 +444,29 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::ExceptionTypeEntity > ent2(
static_cast< unoidl::ExceptionTypeEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector< unoidl::ExceptionTypeEntity::Member >::
+ const_iterator j(ent2->getDirectMembers().begin());
+ !ann && j != ent2->getDirectMembers().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get(), !ent2->getDirectBase().isEmpty());
+ writeKind(
+ file, ent2.get(), ann, !ent2->getDirectBase().isEmpty());
if (!ent2->getDirectBase().isEmpty()) {
- writeNameLen(file, ent2->getDirectBase());
+ writeIdxName(file, ent2->getDirectBase());
}
write32(file, ent2->getDirectMembers().size());
for (std::vector< unoidl::ExceptionTypeEntity::Member >::
const_iterator j(ent2->getDirectMembers().begin());
j != ent2->getDirectMembers().end(); ++j)
{
- writeNameLen(file, j->name);
- writeNameLen(file, j->type);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->type);
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_INTERFACE_TYPE:
@@ -392,21 +474,48 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
static_cast< unoidl::InterfaceTypeEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBases().begin());
+ !ann && j != ent2->getDirectMandatoryBases().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBases().begin());
+ !ann && j != ent2->getDirectOptionalBases().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::InterfaceTypeEntity::Attribute >::
+ const_iterator j(ent2->getDirectAttributes().begin());
+ !ann && j != ent2->getDirectAttributes().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::InterfaceTypeEntity::Method >::
+ const_iterator j(ent2->getDirectMethods().begin());
+ !ann && j != ent2->getDirectMethods().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
+ writeKind(file, ent2.get(), ann);
write32(file, ent2->getDirectMandatoryBases().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectMandatoryBases().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBases().begin());
j != ent2->getDirectMandatoryBases().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectOptionalBases().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectOptionalBases().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBases().begin());
j != ent2->getDirectOptionalBases().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectAttributes().size());
for (std::vector< unoidl::InterfaceTypeEntity::Attribute >::
@@ -421,14 +530,14 @@ sal_uInt64 writeMap(
f |= 0x02;
}
write8(file, f);
- writeNameLen(file, j->name);
- writeNameLen(file, j->type);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->type);
write32(file, j->getExceptions.size());
for (std::vector< OUString >::const_iterator k(
j->getExceptions.begin());
k != j->getExceptions.end(); ++k)
{
- writeNameLen(file, *k);
+ writeIdxName(file, *k);
}
if (!j->readOnly) {
write32(file, j->setExceptions.size());
@@ -436,17 +545,18 @@ sal_uInt64 writeMap(
j->setExceptions.begin());
k != j->setExceptions.end(); ++k)
{
- writeNameLen(file, *k);
+ writeIdxName(file, *k);
}
}
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectMethods().size());
for (std::vector< unoidl::InterfaceTypeEntity::Method >::
const_iterator j(ent2->getDirectMethods().begin());
j != ent2->getDirectMethods().end(); ++j)
{
- writeNameLen(file, j->name);
- writeNameLen(file, j->returnType);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->returnType);
write32(file, j->parameters.size());
for (std::vector<
unoidl::InterfaceTypeEntity::Method::Parameter >::
@@ -454,17 +564,19 @@ sal_uInt64 writeMap(
k != j->parameters.end(); ++k)
{
write8(file, k->direction);
- writeNameLen(file, k->name);
- writeNameLen(file, k->type);
+ writeIdxName(file, k->name);
+ writeIdxName(file, k->type);
}
write32(file, j->exceptions.size());
for (std::vector< OUString >::const_iterator k(
j->exceptions.begin());
k != j->exceptions.end(); ++k)
{
- writeNameLen(file, *k);
+ writeIdxName(file, *k);
}
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_TYPEDEF:
@@ -472,9 +584,11 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::TypedefEntity > ent2(
static_cast< unoidl::TypedefEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
- writeNameLen(file, ent2->getType());
+ writeKind(file, ent2.get(), ann);
+ writeIdxName(file, ent2->getType());
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_CONSTANT_GROUP:
@@ -488,7 +602,8 @@ sal_uInt64 writeMap(
j != ent2->getMembers().end(); ++j)
{
if (!cmap.insert(
- std::make_pair(j->name, ConstItem(j->value))).
+ std::make_pair(
+ j->name, ConstItem(j->value, j->annotations))).
second)
{
std::cout
@@ -502,7 +617,7 @@ sal_uInt64 writeMap(
{
j->second.dataOffset = getOffset(file);
sal_uInt64 v = j->second.constant.type;
- if (false /*TODO: deprecated */) {
+ if (!j->second.annotations.empty()) {
v |= 0x80;
}
write8(file, v);
@@ -554,15 +669,19 @@ sal_uInt64 writeMap(
default:
for (;;) { std::abort(); } // this cannot happen
}
+ writeAnnotations(
+ file, !j->second.annotations.empty(),
+ j->second.annotations);
}
for (std::map< OUString, ConstItem >::iterator j(
cmap.begin());
j != cmap.end(); ++j)
{
- j->second.nameOffset = writeNameNul(file, j->first);
+ j->second.nameOffset = writeNulName(file, j->first);
}
+ bool ann = !ent2->getAnnotations().empty();
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
+ writeKind(file, ent2.get(), ann);
write32(file, cmap.size());
// overflow from std::map::size_type -> sal_uInt64 is
// unrealistic
@@ -573,6 +692,7 @@ sal_uInt64 writeMap(
write32(file, j->second.nameOffset);
write32(file, j->second.dataOffset);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_SINGLE_INTERFACE_BASED_SERVICE:
@@ -582,11 +702,22 @@ sal_uInt64 writeMap(
static_cast<
unoidl::SingleInterfaceBasedServiceEntity * >(
i->second.entity.get()));
- i->second.dataOffset = getOffset(file);
bool dfltCtor = ent2->getConstructors().size() == 1
&& ent2->getConstructors()[0].defaultConstructor;
- writeKind(file, ent2.get(), dfltCtor);
- writeNameLen(file, ent2->getBase());
+ bool ann = !ent2->getAnnotations().empty();
+ if (!dfltCtor) {
+ for (std::vector<
+ unoidl::SingleInterfaceBasedServiceEntity::
+ Constructor >::const_iterator j(
+ ent2->getConstructors().begin());
+ !ann && j != ent2->getConstructors().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ }
+ i->second.dataOffset = getOffset(file);
+ writeKind(file, ent2.get(), ann, dfltCtor);
+ writeIdxName(file, ent2->getBase());
if (!dfltCtor) {
write32(file, ent2->getConstructors().size());
for (std::vector<
@@ -601,7 +732,7 @@ sal_uInt64 writeMap(
<< j->name << '"' << std::endl;
std::exit(EXIT_FAILURE);
}
- writeNameLen(file, j->name);
+ writeIdxName(file, j->name);
write32(file, j->parameters.size());
for (std::vector<
unoidl::SingleInterfaceBasedServiceEntity::
@@ -614,18 +745,20 @@ sal_uInt64 writeMap(
f |= 0x04;
}
write8(file, f);
- writeNameLen(file, k->name);
- writeNameLen(file, k->type);
+ writeIdxName(file, k->name);
+ writeIdxName(file, k->type);
}
write32(file, j->exceptions.size());
for (std::vector< OUString >::const_iterator k(
j->exceptions.begin());
k != j->exceptions.end(); ++k)
{
- writeNameLen(file, *k);
+ writeIdxName(file, *k);
}
+ writeAnnotations(file, ann, j->annotations);
}
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_ACCUMULATION_BASED_SERVICE:
@@ -633,35 +766,77 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::AccumulationBasedServiceEntity > ent2(
static_cast< unoidl::AccumulationBasedServiceEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBaseServices().begin());
+ !ann && j != ent2->getDirectMandatoryBaseServices().end();
+ ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBaseServices().begin());
+ !ann && j != ent2->getDirectOptionalBaseServices().end();
+ ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBaseInterfaces().begin());
+ (!ann
+ && j != ent2->getDirectMandatoryBaseInterfaces().end());
+ ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBaseInterfaces().begin());
+ !ann && j != ent2->getDirectOptionalBaseInterfaces().end();
+ ++j)
+ {
+ ann = !j->annotations.empty();
+ }
+ for (std::vector<
+ unoidl::AccumulationBasedServiceEntity::Property >::
+ const_iterator j(
+ ent2->getDirectProperties().begin());
+ !ann && j != ent2->getDirectProperties().end(); ++j)
+ {
+ ann = !j->annotations.empty();
+ }
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
+ writeKind(file, ent2.get(), ann);
write32(file, ent2->getDirectMandatoryBaseServices().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectMandatoryBaseServices().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBaseServices().begin());
j != ent2->getDirectMandatoryBaseServices().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectOptionalBaseServices().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectOptionalBaseServices().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBaseServices().begin());
j != ent2->getDirectOptionalBaseServices().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectMandatoryBaseInterfaces().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectMandatoryBaseInterfaces().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectMandatoryBaseInterfaces().begin());
j != ent2->getDirectMandatoryBaseInterfaces().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectOptionalBaseInterfaces().size());
- for (std::vector< OUString >::const_iterator j(
- ent2->getDirectOptionalBaseInterfaces().begin());
+ for (std::vector< unoidl::AnnotatedReference >::const_iterator
+ j(ent2->getDirectOptionalBaseInterfaces().begin());
j != ent2->getDirectOptionalBaseInterfaces().end(); ++j)
{
- writeNameLen(file, *j);
+ writeIdxName(file, j->name);
+ writeAnnotations(file, ann, j->annotations);
}
write32(file, ent2->getDirectProperties().size());
for (std::vector<
@@ -671,9 +846,11 @@ sal_uInt64 writeMap(
j != ent2->getDirectProperties().end(); ++j)
{
write16(file, static_cast< sal_uInt16 >(j->attributes));
- writeNameLen(file, j->name);
- writeNameLen(file, j->type);
+ writeIdxName(file, j->name);
+ writeIdxName(file, j->type);
+ writeAnnotations(file, ann, j->annotations);
}
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_INTERFACE_BASED_SINGLETON:
@@ -681,9 +858,11 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::InterfaceBasedSingletonEntity > ent2(
static_cast< unoidl::InterfaceBasedSingletonEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
- writeNameLen(file, ent2->getBase());
+ writeKind(file, ent2.get(), ann);
+ writeIdxName(file, ent2->getBase());
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
case unoidl::Entity::SORT_SERVICE_BASED_SINGLETON:
@@ -691,9 +870,11 @@ sal_uInt64 writeMap(
rtl::Reference< unoidl::ServiceBasedSingletonEntity > ent2(
static_cast< unoidl::ServiceBasedSingletonEntity * >(
i->second.entity.get()));
+ bool ann = !ent2->getAnnotations().empty();
i->second.dataOffset = getOffset(file);
- writeKind(file, ent2.get());
- writeNameLen(file, ent2->getBase());
+ writeKind(file, ent2.get(), ann);
+ writeIdxName(file, ent2->getBase());
+ writeAnnotations(file, ann, ent2->getAnnotations());
break;
}
}
@@ -701,7 +882,7 @@ sal_uInt64 writeMap(
for (std::map< OUString, Item >::iterator i(map.begin()); i != map.end();
++i)
{
- i->second.nameOffset = writeNameNul(file, i->first);
+ i->second.nameOffset = writeNulName(file, i->first);
}
sal_uInt64 off = getOffset(file);
if (rootSize == 0) {
diff --git a/unoidl/source/unoidlprovider.cxx b/unoidl/source/unoidlprovider.cxx
index 33848a1c632e..47b6f9eb0399 100644
--- a/unoidl/source/unoidlprovider.cxx
+++ b/unoidl/source/unoidlprovider.cxx
@@ -17,6 +17,8 @@
#include "osl/endian.h"
#include "osl/file.h"
#include "rtl/ref.hxx"
+#include "rtl/textenc.h"
+#include "rtl/textcvt.h"
#include "rtl/ustring.hxx"
#include "sal/log.hxx"
#include "sal/types.h"
@@ -132,9 +134,13 @@ public:
double readIso60599Binary64(sal_uInt32 offset) const;
- OUString readNameNul(sal_uInt32 offset) const;
+ OUString readNulName(sal_uInt32 offset) const;
- OUString readNameLen(sal_uInt32 offset, sal_uInt32 * newOffset = 0) const;
+ OUString readIdxName(sal_uInt32 * offset) const
+ { return readIdxString(offset, RTL_TEXTENCODING_ASCII_US); }
+
+ OUString readIdxString(sal_uInt32 * offset) const
+ { return readIdxString(offset, RTL_TEXTENCODING_UTF8); }
OUString uri;
oslFileHandle handle;
@@ -155,6 +161,9 @@ private:
float getIso60599Binary32(sal_uInt32 offset) const;
double getIso60599Binary64(sal_uInt32 offset) const;
+
+ OUString readIdxString(sal_uInt32 * offset, rtl_TextEncoding encoding)
+ const;
};
MappedFile::MappedFile(OUString const & fileUrl): uri(fileUrl) {
@@ -235,7 +244,7 @@ double MappedFile::readIso60599Binary64(sal_uInt32 offset) const {
return getIso60599Binary64(offset);
}
-OUString MappedFile::readNameNul(sal_uInt32 offset) const {
+OUString MappedFile::readNulName(sal_uInt32 offset) const {
if (offset > size) {
throw FileFormatException(
uri, "UNOIDL format: offset for string too large");
@@ -266,44 +275,6 @@ OUString MappedFile::readNameNul(sal_uInt32 offset) const {
return name;
}
-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 FileFormatException(
- uri, "UNOIDL format: name length high bit unset");
- }
- len &= ~0x80000000;
- } else {
- len &= ~0x80000000;
- if (newOffset != 0) {
- *newOffset = offset + 4 + len;
- }
- }
- if (len > SAL_MAX_INT32 || len > size - offset - 4) {
- throw FileFormatException(
- uri, "UNOIDL format: size of name is too large");
- }
- 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 FileFormatException(uri, "UNOIDL format: name is not ASCII");
- }
- return name;
-}
-
MappedFile::~MappedFile() {
oslFileError e = osl_unmapMappedFile(handle, address, size);
SAL_WARN_IF(e != osl_File_E_None, "unoidl", "cannot unmap: " << +e);
@@ -352,6 +323,42 @@ double MappedFile::getIso60599Binary64(sal_uInt32 offset) const {
static_cast< char const * >(address) + offset)->getIso60599Binary64();
}
+OUString MappedFile::readIdxString(
+ sal_uInt32 * offset, rtl_TextEncoding encoding) const
+{
+ assert(offset != 0);
+ sal_uInt32 len = read32(*offset);
+ sal_uInt32 off;
+ if ((len & 0x80000000) == 0) {
+ off = *offset;
+ *offset += 4 + len;
+ } else {
+ *offset += 4;
+ off = len & ~0x80000000;
+ len = read32(off);
+ if ((len & 0x80000000) != 0) {
+ throw FileFormatException(
+ uri, "UNOIDL format: string length high bit set");
+ }
+ }
+ if (len > SAL_MAX_INT32 || len > size - off - 4) {
+ throw FileFormatException(
+ uri, "UNOIDL format: size of string is too large");
+ }
+ OUString name;
+ if (!rtl_convertStringToUString(
+ &name.pData, static_cast< char const * >(address) + off + 4, len,
+ encoding,
+ (RTL_TEXTTOUNICODE_FLAGS_UNDEFINED_ERROR
+ | RTL_TEXTTOUNICODE_FLAGS_MBUNDEFINED_ERROR
+ | RTL_TEXTTOUNICODE_FLAGS_INVALID_ERROR)))
+ {
+ throw FileFormatException(
+ uri, "UNOIDL format: string bytes do not match encoding");
+ }
+ return name;
+}
+
// sizeof (MapEntry) == 8
struct MapEntry {
Memory32 name;
@@ -430,16 +437,40 @@ sal_uInt32 findInMap(
return off;
}
+std::vector< OUString > readAnnotations(
+ bool annotated, rtl::Reference< detail::MappedFile > const & file,
+ sal_uInt32 offset, sal_uInt32 * newOffset = 0)
+{
+ std::vector< OUString > ans;
+ if (annotated) {
+ sal_uInt32 n = file->read32(offset);
+ offset += 4;
+ for (sal_uInt32 i = 0; i != n; ++i) {
+ ans.push_back(file->readIdxString(&offset));
+ }
+ }
+ if (newOffset != 0) {
+ *newOffset = offset;
+ }
+ return ans;
+}
+
ConstantValue readConstant(
- rtl::Reference< detail::MappedFile > const & file, sal_uInt32 offset)
+ rtl::Reference< detail::MappedFile > const & file, sal_uInt32 offset,
+ sal_uInt32 * newOffset = 0, bool * annotated = 0)
{
assert(file.is());
int v = file->read8(offset);
int type = v & 0x7F;
- bool deprecated = (v & 0x80) != 0; (void)deprecated;//TODO
+ if (annotated != 0) {
+ *annotated = (v & 0x80) != 0;
+ }
switch (type) {
case 0: // BOOLEAN
v = file->read8(offset + 1);
+ if (newOffset != 0) {
+ *newOffset = offset + 2;
+ }
switch (v) {
case 0:
return ConstantValue(false);
@@ -452,33 +483,60 @@ ConstantValue readConstant(
+ OUString::number(v)));
}
case 1: // BYTE
+ if (newOffset != 0) {
+ *newOffset = offset + 2;
+ }
return ConstantValue(static_cast< 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
+ if (newOffset != 0) {
+ *newOffset = offset + 3;
+ }
return ConstantValue(
static_cast< 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
+ if (newOffset != 0) {
+ *newOffset = offset + 3;
+ }
return ConstantValue(file->read16(offset + 1));
case 4: // LONG
+ if (newOffset != 0) {
+ *newOffset = offset + 5;
+ }
return ConstantValue(
static_cast< 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
+ if (newOffset != 0) {
+ *newOffset = offset + 5;
+ }
return ConstantValue(file->read32(offset + 1));
case 6: // HYPER
+ if (newOffset != 0) {
+ *newOffset = offset + 9;
+ }
return ConstantValue(
static_cast< 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
+ if (newOffset != 0) {
+ *newOffset = offset + 9;
+ }
return ConstantValue(file->read64(offset + 1));
case 8: // FLOAT
+ if (newOffset != 0) {
+ *newOffset = offset + 5;
+ }
return ConstantValue(file->readIso60599Binary32(offset + 1));
case 9: // DOUBLE
+ if (newOffset != 0) {
+ *newOffset = offset + 9;
+ }
return ConstantValue(file->readIso60599Binary64(offset + 1));
default:
throw FileFormatException(
@@ -512,7 +570,7 @@ rtl::Reference< Entity > UnoidlCursor::getNext(OUString * name) {
assert(name != 0);
rtl::Reference< Entity > ent;
if (mapIndex_ != mapEnd_) {
- *name = file_->readNameNul(mapIndex_->name.getUnsigned32());
+ *name = file_->readNulName(mapIndex_->name.getUnsigned32());
ent = readEntity(file_, mapIndex_->data.getUnsigned32());
++mapIndex_;
}
@@ -547,7 +605,7 @@ private:
std::vector< OUString > UnoidlModuleEntity::getMemberNames() const {
std::vector< OUString > names;
for (sal_uInt32 i = 0; i != mapSize_; ++i) {
- names.push_back(file_->readNameNul(mapBegin_[i].name.getUnsigned32()));
+ names.push_back(file_->readNulName(mapBegin_[i].name.getUnsigned32()));
}
return names;
}
@@ -559,7 +617,7 @@ rtl::Reference< Entity > readEntity(
int v = file->read8(offset);
int type = v & 0x3F;
bool published = (v & 0x80) != 0;
- bool deprecated = (v & 0x40) != 0; (void)deprecated;//TODO
+ bool annotated = (v & 0x40) != 0;
bool flag = (v & 0x20) != 0;
switch (type) {
case 0: // module
@@ -592,16 +650,20 @@ rtl::Reference< Entity > readEntity(
offset += 5;
std::vector< EnumTypeEntity::Member > mems;
for (sal_uInt32 i = 0; i != n; ++i) {
- OUString memName(file->readNameLen(offset, &offset));
+ OUString memName(file->readIdxName(&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(EnumTypeEntity::Member(memName, memValue));
+ mems.push_back(
+ EnumTypeEntity::Member(
+ memName, memValue,
+ readAnnotations(annotated, file, offset, &offset)));
}
- return new EnumTypeEntity(published, mems);
+ return new EnumTypeEntity(
+ published, mems, readAnnotations(annotated, file, offset));
}
case 2: // plain struct type without base
case 2 | 0x20: // plain struct type with base
@@ -609,7 +671,7 @@ rtl::Reference< Entity > readEntity(
++offset;
OUString base;
if (flag) {
- base = file->readNameLen(offset, &offset);
+ base = file->readIdxName(&offset);
if (base.isEmpty()) {
throw FileFormatException(
file->uri,
@@ -627,11 +689,16 @@ rtl::Reference< Entity > readEntity(
offset += 4;
std::vector< PlainStructTypeEntity::Member > mems;
for (sal_uInt32 i = 0; i != n; ++i) {
- OUString memName(file->readNameLen(offset, &offset));
- OUString memType(file->readNameLen(offset, &offset));
- mems.push_back(PlainStructTypeEntity::Member(memName, memType));
+ OUString memName(file->readIdxName(&offset));
+ OUString memType(file->readIdxName(&offset));
+ mems.push_back(
+ PlainStructTypeEntity::Member(
+ memName, memType,
+ readAnnotations(annotated, file, offset, &offset)));
}
- return new PlainStructTypeEntity(published, base, mems);
+ return new PlainStructTypeEntity(
+ published, base, mems,
+ readAnnotations(annotated, file, offset));
}
case 3: // polymorphic struct type template
{
@@ -645,7 +712,7 @@ rtl::Reference< Entity > readEntity(
offset += 5;
std::vector< OUString > params;
for (sal_uInt32 i = 0; i != n; ++i) {
- params.push_back(file->readNameLen(offset, &offset));
+ params.push_back(file->readIdxName(&offset));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -659,8 +726,8 @@ rtl::Reference< Entity > readEntity(
for (sal_uInt32 i = 0; i != n; ++i) {
v = file->read8(offset);
++offset;
- OUString memName(file->readNameLen(offset, &offset));
- OUString memType(file->readNameLen(offset, &offset));
+ OUString memName(file->readIdxName(&offset));
+ OUString memType(file->readIdxName(&offset));
if (v > 1) {
throw FileFormatException(
file->uri,
@@ -670,10 +737,12 @@ rtl::Reference< Entity > readEntity(
}
mems.push_back(
PolymorphicStructTypeTemplateEntity::Member(
- memName, memType, v == 1));
+ memName, memType, v == 1,
+ readAnnotations(annotated, file, offset, &offset)));
}
return new PolymorphicStructTypeTemplateEntity(
- published, params, mems);
+ published, params, mems,
+ readAnnotations(annotated, file, offset));
}
case 4: // exception type without base
case 4 | 0x20: // exception type with base
@@ -681,7 +750,7 @@ rtl::Reference< Entity > readEntity(
++offset;
OUString base;
if (flag) {
- base = file->readNameLen(offset, &offset);
+ base = file->readIdxName(&offset);
if (base.isEmpty()) {
throw FileFormatException(
file->uri,
@@ -698,11 +767,16 @@ rtl::Reference< Entity > readEntity(
offset += 4;
std::vector< ExceptionTypeEntity::Member > mems;
for (sal_uInt32 i = 0; i != n; ++i) {
- OUString memName(file->readNameLen(offset, &offset));
- OUString memType(file->readNameLen(offset, &offset));
- mems.push_back(ExceptionTypeEntity::Member(memName, memType));
+ OUString memName(file->readIdxName(&offset));
+ OUString memType(file->readIdxName(&offset));
+ mems.push_back(
+ ExceptionTypeEntity::Member(
+ memName, memType,
+ readAnnotations(annotated, file, offset, &offset)));
}
- return new ExceptionTypeEntity(published, base, mems);
+ return new ExceptionTypeEntity(
+ published, base, mems,
+ readAnnotations(annotated, file, offset));
}
case 5: // interface type
{
@@ -714,9 +788,13 @@ rtl::Reference< Entity > readEntity(
" interface type"));
}
offset += 5;
- std::vector< OUString > mandBases;
+ std::vector< AnnotatedReference > mandBases;
for (sal_uInt32 i = 0; i != n; ++i) {
- mandBases.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ mandBases.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -726,9 +804,13 @@ rtl::Reference< Entity > readEntity(
" interface type"));
}
offset += 4;
- std::vector< OUString > optBases;
+ std::vector< AnnotatedReference > optBases;
for (sal_uInt32 i = 0; i != n; ++i) {
- optBases.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ optBases.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
sal_uInt32 nAttrs = file->read32(offset);
if (nAttrs > SAL_MAX_INT32) {
@@ -742,8 +824,8 @@ rtl::Reference< Entity > readEntity(
for (sal_uInt32 i = 0; i != nAttrs; ++i) {
v = file->read8(offset);
++offset;
- OUString attrName(file->readNameLen(offset, &offset));
- OUString attrType(file->readNameLen(offset, &offset));
+ OUString attrName(file->readIdxName(&offset));
+ OUString attrType(file->readIdxName(&offset));
if (v > 0x03) {
throw FileFormatException(
file->uri,
@@ -760,7 +842,7 @@ rtl::Reference< Entity > readEntity(
}
offset += 4;
for (sal_uInt32 j = 0; j != m; ++j) {
- getExcs.push_back(file->readNameLen(offset, &offset));
+ getExcs.push_back(file->readIdxName(&offset));
}
std::vector< OUString > setExcs;
if ((v & 0x02) == 0) {
@@ -774,13 +856,14 @@ rtl::Reference< Entity > readEntity(
}
offset += 4;
for (sal_uInt32 j = 0; j != m; ++j) {
- setExcs.push_back(file->readNameLen(offset, &offset));
+ setExcs.push_back(file->readIdxName(&offset));
}
}
attrs.push_back(
InterfaceTypeEntity::Attribute(
attrName, attrType, (v & 0x01) != 0, (v & 0x02) != 0,
- getExcs, setExcs));
+ getExcs, setExcs,
+ readAnnotations(annotated, file, offset, &offset)));
}
sal_uInt32 nMeths = file->read32(offset);
if (nMeths > SAL_MAX_INT32 - nAttrs) {
@@ -792,8 +875,8 @@ rtl::Reference< Entity > readEntity(
offset += 4;
std::vector< InterfaceTypeEntity::Method > meths;
for (sal_uInt32 i = 0; i != nMeths; ++i) {
- OUString methName(file->readNameLen(offset, &offset));
- OUString methType(file->readNameLen(offset, &offset));
+ OUString methName(file->readIdxName(&offset));
+ OUString methType(file->readIdxName(&offset));
sal_uInt32 m = file->read32(offset);
if (m > SAL_MAX_INT32) {
throw FileFormatException(
@@ -806,8 +889,8 @@ rtl::Reference< Entity > readEntity(
for (sal_uInt32 j = 0; j != m; ++j) {
v = file->read8(offset);
++offset;
- OUString paramName(file->readNameLen(offset, &offset));
- OUString paramType(file->readNameLen(offset, &offset));
+ OUString paramName(file->readIdxName(&offset));
+ OUString paramType(file->readIdxName(&offset));
InterfaceTypeEntity::Method::Parameter::Direction dir;
switch (v) {
case 0:
@@ -844,17 +927,24 @@ rtl::Reference< Entity > readEntity(
}
offset += 4;
for (sal_uInt32 j = 0; j != m; ++j) {
- excs.push_back(file->readNameLen(offset, &offset));
+ excs.push_back(file->readIdxName(&offset));
}
meths.push_back(
InterfaceTypeEntity::Method(
- methName, methType, params, excs));
+ methName, methType, params, excs,
+ readAnnotations(annotated, file, offset, &offset)));
}
return new InterfaceTypeEntity(
- published, mandBases, optBases, attrs, meths);
+ published, mandBases, optBases, attrs, meths,
+ readAnnotations(annotated, file, offset));
}
case 6: // typedef
- return new TypedefEntity(published, file->readNameLen(offset + 1));
+ {
+ ++offset;
+ OUString base(file->readIdxName(&offset));
+ return new TypedefEntity(
+ published, base, readAnnotations(annotated, file, offset));
+ }
case 7: // constant group
{
sal_uInt32 n = file->read32(offset + 1);
@@ -874,17 +964,23 @@ rtl::Reference< Entity > readEntity(
static_cast< char const * >(file->address) + offset + 5);
std::vector< ConstantGroupEntity::Member > mems;
for (sal_uInt32 i = 0; i != n; ++i) {
+ sal_uInt32 off = p[i].data.getUnsigned32();
+ bool ann;
+ ConstantValue val(readConstant(file, off, &off, &ann));
mems.push_back(
ConstantGroupEntity::Member(
- file->readNameNul(p[i].name.getUnsigned32()),
- readConstant(file, p[i].data.getUnsigned32())));
+ file->readNulName(p[i].name.getUnsigned32()), val,
+ readAnnotations(ann, file, off)));
}
- return new ConstantGroupEntity(published, mems);
+ return new ConstantGroupEntity(
+ published, mems,
+ readAnnotations(annotated, file, offset + 5 + 8 * n));
}
case 8: // single-interface--based service without default constructor
case 8 | 0x20: // single-interface--based service with default constructor
{
- OUString base(file->readNameLen(offset + 1, &offset));
+ ++offset;
+ OUString base(file->readIdxName(&offset));
std::vector< SingleInterfaceBasedServiceEntity::Constructor > ctors;
if (flag) {
ctors.push_back(
@@ -899,7 +995,7 @@ rtl::Reference< Entity > readEntity(
}
offset += 4;
for (sal_uInt32 i = 0; i != n; ++i) {
- OUString ctorName(file->readNameLen(offset, &offset));
+ OUString ctorName(file->readIdxName(&offset));
sal_uInt32 m = file->read32(offset);
if (m > SAL_MAX_INT32) {
throw FileFormatException(
@@ -915,8 +1011,8 @@ rtl::Reference< Entity > readEntity(
for (sal_uInt32 j = 0; j != m; ++j) {
v = file->read8(offset);
++offset;
- OUString paramName(file->readNameLen(offset, &offset));
- OUString paramType(file->readNameLen(offset, &offset));
+ OUString paramName(file->readIdxName(&offset));
+ OUString paramType(file->readIdxName(&offset));
bool rest;
switch (v) {
case 0:
@@ -949,15 +1045,17 @@ rtl::Reference< Entity > readEntity(
}
offset += 4;
for (sal_uInt32 j = 0; j != m; ++j) {
- excs.push_back(file->readNameLen(offset, &offset));
+ excs.push_back(file->readIdxName(&offset));
}
ctors.push_back(
SingleInterfaceBasedServiceEntity::Constructor(
- ctorName, params, excs));
+ ctorName, params, excs,
+ readAnnotations(annotated, file, offset, &offset)));
}
}
return new SingleInterfaceBasedServiceEntity(
- published, base, ctors);
+ published, base, ctors,
+ readAnnotations(annotated, file, offset));
}
case 9: // accumulation-based service
{
@@ -969,9 +1067,13 @@ rtl::Reference< Entity > readEntity(
" accumulation-based service"));
}
offset += 5;
- std::vector< OUString > mandServs;
+ std::vector< AnnotatedReference > mandServs;
for (sal_uInt32 i = 0; i != n; ++i) {
- mandServs.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ mandServs.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -981,9 +1083,13 @@ rtl::Reference< Entity > readEntity(
" accumulation-based service"));
}
offset += 4;
- std::vector< OUString > optServs;
+ std::vector< AnnotatedReference > optServs;
for (sal_uInt32 i = 0; i != n; ++i) {
- optServs.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ optServs.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -993,9 +1099,13 @@ rtl::Reference< Entity > readEntity(
" of accumulation-based service"));
}
offset += 4;
- std::vector< OUString > mandIfcs;
+ std::vector< AnnotatedReference > mandIfcs;
for (sal_uInt32 i = 0; i != n; ++i) {
- mandIfcs.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ mandIfcs.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -1005,9 +1115,13 @@ rtl::Reference< Entity > readEntity(
" of accumulation-based service"));
}
offset += 4;
- std::vector< OUString > optIfcs;
+ std::vector< AnnotatedReference > optIfcs;
for (sal_uInt32 i = 0; i != n; ++i) {
- optIfcs.push_back(file->readNameLen(offset, &offset));
+ OUString base(file->readIdxName(&offset));
+ optIfcs.push_back(
+ AnnotatedReference(
+ base,
+ readAnnotations(annotated, file, offset, &offset)));
}
n = file->read32(offset);
if (n > SAL_MAX_INT32) {
@@ -1021,8 +1135,8 @@ rtl::Reference< Entity > readEntity(
for (sal_uInt32 i = 0; i != n; ++i) {
sal_uInt16 attrs = file->read16(offset);
offset += 2;
- OUString propName(file->readNameLen(offset, &offset));
- OUString propType(file->readNameLen(offset, &offset));
+ OUString propName(file->readIdxName(&offset));
+ OUString propType(file->readIdxName(&offset));
if (attrs > 0x01FF) { // see css.beans.PropertyAttribute
throw FileFormatException(
file->uri,
@@ -1036,17 +1150,27 @@ rtl::Reference< Entity > readEntity(
static_cast<
AccumulationBasedServiceEntity::Property::
Attributes >(
- attrs)));
+ attrs),
+ readAnnotations(annotated, file, offset, &offset)));
}
return new AccumulationBasedServiceEntity(
- published, mandServs, optServs, mandIfcs, optIfcs, props);
+ published, mandServs, optServs, mandIfcs, optIfcs, props,
+ readAnnotations(annotated, file, offset));
}
case 10: // interface-based singleton
- return new InterfaceBasedSingletonEntity(
- published, file->readNameLen(offset + 1));
+ {
+ ++offset;
+ OUString base(file->readIdxName(&offset));
+ return new InterfaceBasedSingletonEntity(
+ published, base, readAnnotations(annotated, file, offset));
+ }
case 11: // service-based singleton
- return new ServiceBasedSingletonEntity(
- published, file->readNameLen(offset + 1));
+ {
+ ++offset;
+ OUString base(file->readIdxName(&offset));
+ return new ServiceBasedSingletonEntity(
+ published, base, readAnnotations(annotated, file, offset));
+ }
default:
throw FileFormatException(
file->uri, "UNOIDL format: bad type byte " + OUString::number(v));