summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--unoidl/source/legacyprovider.cxx6
-rw-r--r--unoidl/source/sourcefileprovider.cxx22
-rw-r--r--unoidl/source/sourceprovider-parser.y260
-rw-r--r--unoidl/source/unoidl-check.cxx188
-rw-r--r--unoidl/source/unoidl-read.cxx362
-rw-r--r--unoidl/source/unoidl-write.cxx413
-rw-r--r--unoidl/source/unoidl.cxx14
7 files changed, 442 insertions, 823 deletions
diff --git a/unoidl/source/legacyprovider.cxx b/unoidl/source/legacyprovider.cxx
index 7b2d45babdf1..7edcdb6b2279 100644
--- a/unoidl/source/legacyprovider.cxx
+++ b/unoidl/source/legacyprovider.cxx
@@ -384,7 +384,7 @@ rtl::Reference< Entity > readEntity(
}
std::vector< PlainStructTypeEntity::Member > mems;
n = reader.getFieldCount();
- for (sal_uInt16 j = 0; j < n; ++j) {
+ for (sal_uInt16 j = 0; j != n; ++j) {
mems.emplace_back(
reader.getFieldName(j),
reader.getFieldTypeName(j).replace('/', '.'),
@@ -403,13 +403,13 @@ rtl::Reference< Entity > readEntity(
" with key " + sub.getName()));
}
std::vector< OUString > params;
- for (sal_uInt16 j = 0; j < n; ++j) {
+ for (sal_uInt16 j = 0; j != n; ++j) {
params.push_back(
reader.getReferenceTypeName(j).replace('/', '.'));
}
std::vector< PolymorphicStructTypeTemplateEntity::Member > mems;
n = reader.getFieldCount();
- for (sal_uInt16 j = 0; j < n; ++j) {
+ for (sal_uInt16 j = 0; j != n; ++j) {
mems.emplace_back(
reader.getFieldName(j),
reader.getFieldTypeName(j).replace('/', '.'),
diff --git a/unoidl/source/sourcefileprovider.cxx b/unoidl/source/sourcefileprovider.cxx
index 18a6d666cf02..3a3d639bb05e 100644
--- a/unoidl/source/sourcefileprovider.cxx
+++ b/unoidl/source/sourcefileprovider.cxx
@@ -63,11 +63,8 @@ private:
std::vector<rtl::OUString> Module::getMemberNames() const {
std::vector<rtl::OUString> names;
- for (std::map< OUString, rtl::Reference<Entity> >::const_iterator i(
- map.begin());
- i != map.end(); ++i)
- {
- names.push_back(i->first);
+ for (auto & i: map) {
+ names.push_back(i.first);
}
return names;
}
@@ -81,18 +78,15 @@ SourceFileProvider::SourceFileProvider(
if (!parse(uri, &data)) {
throw NoSuchFileException(uri);
}
- for (std::map<OUString, SourceProviderEntity>::iterator i(
- data.entities.begin());
- i != data.entities.end(); ++i)
- {
- if (i->second.kind == SourceProviderEntity::KIND_LOCAL) {
- assert(i->second.entity.is());
- assert(i->second.entity->getSort() != Entity::SORT_MODULE);
+ for (auto & i: data.entities) {
+ if (i.second.kind == SourceProviderEntity::KIND_LOCAL) {
+ assert(i.second.entity.is());
+ assert(i.second.entity->getSort() != Entity::SORT_MODULE);
std::map< OUString, rtl::Reference<Entity> > * map = &rootMap_;
for (sal_Int32 j = 0;;) {
- OUString id(i->first.getToken(0, '.', j));
+ OUString id(i.first.getToken(0, '.', j));
if (j == -1) {
- map->insert(std::make_pair(id, i->second.entity));
+ map->insert(std::make_pair(id, i.second.entity));
break;
}
std::map< OUString, rtl::Reference<Entity> >::const_iterator k(
diff --git a/unoidl/source/sourceprovider-parser.y b/unoidl/source/sourceprovider-parser.y
index 945ebea0f488..1a662d7f2e0b 100644
--- a/unoidl/source/sourceprovider-parser.y
+++ b/unoidl/source/sourceprovider-parser.y
@@ -262,9 +262,7 @@ unoidl::detail::SourceProviderEntity * findEntity_(
assert(name != 0);
OUString n;
if (!name->startsWith(".", &n)) {
- for (std::vector<OUString>::reverse_iterator i(data->modules.rbegin());
- i != data->modules.rend(); ++i)
- {
+ for (auto i(data->modules.rbegin()); i != data->modules.rend(); ++i) {
n = *i + "." + *name;
std::map<OUString, unoidl::detail::SourceProviderEntity>::iterator j(
data->entities.find(n));
@@ -837,12 +835,9 @@ bool checkInstantiatedPolymorphicStructTypeArgument(
if (type.type
== unoidl::detail::SourceProviderType::TYPE_INSTANTIATED_POLYMORPHIC_STRUCT)
{
- for (std::vector<unoidl::detail::SourceProviderType>::const_iterator i(
- type.subtypes.begin());
- i != type.subtypes.end(); ++i)
- {
- if (checkInstantiatedPolymorphicStructTypeArgument(*i, name)
- || i->getName() == name) // no need to worry about typedef
+ for (auto & i: type.subtypes) {
+ if (checkInstantiatedPolymorphicStructTypeArgument(i, name)
+ || i.getName() == name) // no need to worry about typedef
{
return true;
}
@@ -1329,11 +1324,8 @@ structMember:
dynamic_cast<unoidl::detail::SourceProviderPlainStructTypeEntityPad *>(
ent->pad.get());
if (p1 != 0) {
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::iterator i(
- p1->members.begin());
- i != p1->members.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: p1->members) {
+ if (id == i.name) {
error(
@3, yyscanner,
("plain struct type " + data->currentName
@@ -1344,9 +1336,7 @@ structMember:
}
if (p1->baseEntity.is()) {
OUString baseName(p1->baseName);
- for (rtl::Reference<unoidl::PlainStructTypeEntity> baseEnt(
- p1->baseEntity);;)
- {
+ for (auto baseEnt(p1->baseEntity);;) {
if (nameHasSameIdentifierAs(baseName, id)) {
error(
@3, yyscanner,
@@ -1356,11 +1346,8 @@ structMember:
+ baseName));
YYERROR;
}
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::const_iterator i(
- baseEnt->getDirectMembers().begin());
- i != baseEnt->getDirectMembers().end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: baseEnt->getDirectMembers()) {
+ if (id == i.name) {
error(
@3, yyscanner,
("plain struct type " + data->currentName
@@ -1403,11 +1390,8 @@ structMember:
p2 = dynamic_cast<unoidl::detail::SourceProviderPolymorphicStructTypeTemplateEntityPad *>(
ent->pad.get());
if (p2 != 0) {
- for (std::vector<unoidl::PolymorphicStructTypeTemplateEntity::Member>::iterator i(
- p2->members.begin());
- i != p2->members.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: p2->members) {
+ if (id == i.name) {
error(
@3, yyscanner,
("polymorphic struct type template "
@@ -1425,11 +1409,8 @@ structMember:
= dynamic_cast<unoidl::detail::SourceProviderExceptionTypeEntityPad *>(
ent->pad.get());
assert(p3 != 0);
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::iterator i(
- p3->members.begin());
- i != p3->members.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: p3->members) {
+ if (id == i.name) {
error(
@3, yyscanner,
("exception type " + data->currentName
@@ -1440,9 +1421,7 @@ structMember:
}
if (p3->baseEntity.is()) {
OUString baseName(p3->baseName);
- for (rtl::Reference<unoidl::ExceptionTypeEntity> baseEnt(
- p3->baseEntity);;)
- {
+ for (auto baseEnt(p3->baseEntity);;) {
if (nameHasSameIdentifierAs(baseName, id)) {
error(
@3, yyscanner,
@@ -1452,11 +1431,8 @@ structMember:
+ baseName));
YYERROR;
}
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::const_iterator i(
- baseEnt->getDirectMembers().begin());
- i != baseEnt->getDirectMembers().end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: baseEnt->getDirectMembers()) {
+ if (id == i.name) {
error(
@3, yyscanner,
("exception type " + data->currentName
@@ -1613,18 +1589,12 @@ interfaceDefn:
}
}
std::vector<unoidl::AnnotatedReference> mbases;
- for (std::vector<unoidl::detail::SourceProviderInterfaceTypeEntityPad::DirectBase>::const_iterator
- i(pad->directMandatoryBases.begin());
- i != pad->directMandatoryBases.end(); ++i)
- {
- mbases.emplace_back(i->name, i->annotations);
+ for (auto & i: pad->directMandatoryBases) {
+ mbases.emplace_back(i.name, i.annotations);
}
std::vector<unoidl::AnnotatedReference> obases;
- for (std::vector<unoidl::detail::SourceProviderInterfaceTypeEntityPad::DirectBase>::const_iterator
- i(pad->directOptionalBases.begin());
- i != pad->directOptionalBases.end(); ++i)
- {
- obases.emplace_back(i->name, i->annotations);
+ for (auto & i: pad->directOptionalBases) {
+ obases.emplace_back(i.name, i.annotations);
}
ent->entity = new unoidl::InterfaceTypeEntity(
pad->isPublished(), mbases, obases, pad->directAttributes,
@@ -1886,11 +1856,8 @@ methodParam:
default:
break;
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method::Parameter>::iterator
- i(pad->directMethods.back().parameters.begin());
- i != pad->directMethods.back().parameters.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: pad->directMethods.back().parameters) {
+ if (id == i.name) {
error(
@5, yyscanner,
("interface type " + data->currentName + " direct method "
@@ -2374,20 +2341,14 @@ singleInterfaceBasedServiceDefn:
assert(pad != 0);
std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor> ctors;
if ($7) {
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor>::iterator
- i(pad->constructors.begin());
- i != pad->constructors.end(); ++i)
- {
+ for (auto & i: pad->constructors) {
std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter> parms;
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor::Parameter>::iterator
- j(i->parameters.begin());
- j != i->parameters.end(); ++j)
- {
- parms.emplace_back(j->name, j->type.getName(), j->rest);
+ for (auto & j: i.parameters) {
+ parms.emplace_back(j.name, j.type.getName(), j.rest);
}
ctors.push_back(
unoidl::SingleInterfaceBasedServiceEntity::Constructor(
- i->name, parms, i->exceptions, i->annotations));
+ i.name, parms, i.exceptions, i.annotations));
}
} else {
assert(pad->constructors.empty());
@@ -2419,11 +2380,8 @@ ctor:
rtl::Reference<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad>
pad(getCurrentPad<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad>(
data));
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor>::iterator
- i(pad->constructors.begin());
- i != pad->constructors.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: pad->constructors) {
+ if (id == i.name) {
error(
@2, yyscanner,
("single-interface--based service " + data->currentName
@@ -2447,15 +2405,14 @@ ctor:
pad->constructors.back().exceptions = *$7;
delete $7;
}
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor>::iterator
- i(pad->constructors.begin());
- i != pad->constructors.end() - 1; ++i)
+ for (auto i(pad->constructors.begin()); i != pad->constructors.end() - 1;
+ ++i)
{
if (i->parameters.size()
== pad->constructors.back().parameters.size())
{
bool same = true;
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor::Parameter>::iterator
+ for (auto
j(i->parameters.begin()),
k(pad->constructors.back().parameters.begin());
j != i->parameters.end(); ++j, ++k)
@@ -2549,11 +2506,8 @@ ctorParam:
+ " rest parameter must be last parameter"));
YYERROR;
}
- for (std::vector<unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad::Constructor::Parameter>::iterator
- i(pad->constructors.back().parameters.begin());
- i != pad->constructors.back().parameters.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: pad->constructors.back().parameters) {
+ if (id == i.name) {
error(
@6, yyscanner,
("single-interface--based service " + data->currentName
@@ -2665,10 +2619,8 @@ serviceBase:
std::vector<unoidl::AnnotatedReference> & v(
opt
? pad->directOptionalBaseServices : pad->directMandatoryBaseServices);
- for (std::vector<unoidl::AnnotatedReference>::iterator i(v.begin());
- i != v.end(); ++i)
- {
- if (name == i->name) {
+ for (auto & i: v) {
+ if (name == i.name) {
error(
@4, yyscanner,
("accumulation-based service " + data->currentName
@@ -2744,10 +2696,8 @@ serviceInterfaceBase:
opt
? pad->directOptionalBaseInterfaces
: pad->directMandatoryBaseInterfaces);
- for (std::vector<unoidl::AnnotatedReference>::iterator i(v.begin());
- i != v.end(); ++i)
- {
- if (name == i->name) {
+ for (auto & i: v) {
+ if (name == i.name) {
error(
@4, yyscanner,
("accumulation-based service " + data->currentName
@@ -2833,11 +2783,8 @@ serviceProperty:
rtl::Reference<unoidl::detail::SourceProviderAccumulationBasedServiceEntityPad>
pad(getCurrentPad<unoidl::detail::SourceProviderAccumulationBasedServiceEntityPad>(
data));
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::iterator
- i(pad->directProperties.begin());
- i != pad->directProperties.end(); ++i)
- {
- if (id == i->name) {
+ for (auto & i: pad->directProperties) {
+ if (id == i.name) {
error(
@4, yyscanner,
("accumulation-based service " + data->currentName
@@ -3522,12 +3469,9 @@ primaryExpr:
unoidl::detail::SourceProviderEnumTypeEntityPad * p1 = dynamic_cast<
unoidl::detail::SourceProviderEnumTypeEntityPad *>(pad.get());
if (p1 != 0) {
- for (std::vector<unoidl::EnumTypeEntity::Member>::const_iterator
- j(p1->members.begin());
- j != p1->members.end(); ++j)
- {
- if (j->name == name) {
- v = unoidl::ConstantValue(j->value);
+ for (auto & j: p1->members) {
+ if (j.name == name) {
+ v = unoidl::ConstantValue(j.value);
found = true;
break;
}
@@ -3538,12 +3482,9 @@ primaryExpr:
unoidl::detail::SourceProviderConstantGroupEntityPad *>(
pad.get());
if (p2 != 0) {
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- j(p2->members.begin());
- j != p2->members.end(); ++j)
- {
- if (j->name == name) {
- v = j->value;
+ for (auto & j: p2->members) {
+ if (j.name == name) {
+ v = j.value;
found = true;
break;
}
@@ -3571,12 +3512,9 @@ primaryExpr:
static_cast<unoidl::ConstantGroupEntity *>(
ent->entity.get())->
getMembers());
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator j(
- mems.begin());
- j != mems.end(); ++j)
- {
- if (j->name == id) {
- v = j->value;
+ for (auto & j: mems) {
+ if (j.name == id) {
+ v = j.value;
found = true;
unpub
= !static_cast<unoidl::ConstantGroupEntity *>(
@@ -3591,12 +3529,9 @@ primaryExpr:
unoidl::detail::SourceProviderConstantGroupEntityPad *>(
ent->pad.get());
if (pad != 0) {
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator j(
- pad->members.begin());
- j != pad->members.end(); ++j)
- {
- if (j->name == id) {
- v = j->value;
+ for (auto & j: pad->members) {
+ if (j.name == id) {
+ v = j.value;
found = true;
unpub = !ent->pad->isPublished();
break;
@@ -4083,10 +4018,7 @@ OUString SourceProviderType::getName() const {
case unoidl::detail::SourceProviderType::TYPE_INSTANTIATED_POLYMORPHIC_STRUCT:
{
OUString n(name + "<");
- for (std::vector<SourceProviderType>::const_iterator i(
- subtypes.begin());
- i != subtypes.end(); ++i)
- {
+ for (auto i(subtypes.begin()); i != subtypes.end(); ++i) {
if (i != subtypes.begin()) {
n += ",";
}
@@ -4105,8 +4037,7 @@ bool SourceProviderType::equals(SourceProviderType const & other) const {
{
return false;
}
- for (std::vector<SourceProviderType>::const_iterator
- i(subtypes.begin()), j(other.subtypes.begin());
+ for (auto i(subtypes.begin()), j(other.subtypes.begin());
i != subtypes.end(); ++i, ++j)
{
if (!i->equals(*j)) {
@@ -4204,11 +4135,8 @@ bool SourceProviderInterfaceTypeEntityPad::checkBaseClashes(
}
}
if (direct || !optional) {
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- entity->getDirectMandatoryBases().begin());
- j != entity->getDirectMandatoryBases().end(); ++j)
- {
- OUString n("." + j->name);
+ for (auto & j: entity->getDirectMandatoryBases()) {
+ OUString n("." + j.name);
unoidl::detail::SourceProviderEntity const * p;
if (findEntity(location, yyscanner, data, true, &n, &p, 0, 0)
== FOUND_ERROR)
@@ -4235,11 +4163,8 @@ bool SourceProviderInterfaceTypeEntityPad::checkBaseClashes(
return false;
}
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- entity->getDirectOptionalBases().begin());
- j != entity->getDirectOptionalBases().end(); ++j)
- {
- OUString n("." + j->name);
+ for (auto & j: entity->getDirectOptionalBases()) {
+ OUString n("." + j.name);
unoidl::detail::SourceProviderEntity const * p;
if (findEntity(location, yyscanner, data, true, &n, &p, 0, 0)
== FOUND_ERROR)
@@ -4266,23 +4191,17 @@ bool SourceProviderInterfaceTypeEntityPad::checkBaseClashes(
return false;
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
- j(entity->getDirectAttributes().begin());
- j != entity->getDirectAttributes().end(); ++j)
- {
+ for (auto & j: entity->getDirectAttributes()) {
if (!checkMemberClashes(
- location, yyscanner, data, name, j->name,
+ location, yyscanner, data, name, j.name,
!outerOptional))
{
return false;
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator
- j(entity->getDirectMethods().begin());
- j != entity->getDirectMethods().end(); ++j)
- {
+ for (auto & j: entity->getDirectMethods()) {
if (!checkMemberClashes(
- location, yyscanner, data, name, j->name,
+ location, yyscanner, data, name, j.name,
!outerOptional))
{
return false;
@@ -4311,11 +4230,8 @@ bool SourceProviderInterfaceTypeEntityPad::checkMemberClashes(
return false;
}
} else if (checkOptional) {
- for (std::set<OUString>::const_iterator j(
- i->second.optional.begin());
- j != i->second.optional.end(); ++j)
- {
- if (*j != interfaceName) {
+ for (auto & j: i->second.optional) {
+ if (j != interfaceName) {
error(
location, yyscanner,
("interface type " + data->currentName
@@ -4347,11 +4263,8 @@ bool SourceProviderInterfaceTypeEntityPad::addBase(
p.first->second = kind;
}
if (!optional && !seen) {
- for (std::vector<unoidl::AnnotatedReference>::const_iterator i(
- entity->getDirectMandatoryBases().begin());
- i != entity->getDirectMandatoryBases().end(); ++i)
- {
- OUString n("." + i->name);
+ for (auto & i: entity->getDirectMandatoryBases()) {
+ OUString n("." + i.name);
unoidl::detail::SourceProviderEntity const * q;
if (findEntity(location, yyscanner, data, true, &n, &q, 0, 0)
== FOUND_ERROR)
@@ -4376,11 +4289,9 @@ bool SourceProviderInterfaceTypeEntityPad::addBase(
return false;
}
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator i(
- entity->getDirectOptionalBases().begin());
- i != entity->getDirectOptionalBases().end(); ++i)
+ for (auto & i: entity->getDirectOptionalBases())
{
- OUString n("." + i->name);
+ OUString n("." + i.name);
unoidl::detail::SourceProviderEntity const * q;
if (findEntity(location, yyscanner, data, true, &n, &q, 0, 0)
== FOUND_ERROR)
@@ -4405,19 +4316,13 @@ bool SourceProviderInterfaceTypeEntityPad::addBase(
return false;
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
- i(entity->getDirectAttributes().begin());
- i != entity->getDirectAttributes().end(); ++i)
- {
+ for (auto & i: entity->getDirectAttributes()) {
allMembers.insert(
- std::map<OUString, Member>::value_type(i->name, Member(name)));
+ std::map<OUString, Member>::value_type(i.name, Member(name)));
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator i(
- entity->getDirectMethods().begin());
- i != entity->getDirectMethods().end(); ++i)
- {
+ for (auto & i: entity->getDirectMethods()) {
allMembers.insert(
- std::map<OUString, Member>::value_type(i->name, Member(name)));
+ std::map<OUString, Member>::value_type(i.name, Member(name)));
}
}
return true;
@@ -4429,11 +4334,8 @@ bool SourceProviderInterfaceTypeEntityPad::addOptionalBaseMembers(
rtl::Reference<unoidl::InterfaceTypeEntity> const & entity)
{
assert(entity.is());
- for (std::vector<unoidl::AnnotatedReference>::const_iterator i(
- entity->getDirectMandatoryBases().begin());
- i != entity->getDirectMandatoryBases().end(); ++i)
- {
- OUString n("." + i->name);
+ for (auto & i: entity->getDirectMandatoryBases()) {
+ OUString n("." + i.name);
unoidl::detail::SourceProviderEntity const * p;
if (findEntity(location, yyscanner, data, true, &n, &p, 0, 0)
== FOUND_ERROR)
@@ -4457,27 +4359,19 @@ bool SourceProviderInterfaceTypeEntityPad::addOptionalBaseMembers(
return false;
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator i(
- entity->getDirectAttributes().begin());
- i != entity->getDirectAttributes().end(); ++i)
- {
+ for (auto & i: entity->getDirectAttributes()) {
Member & m(
allMembers.insert(
- std::map<OUString, Member>::value_type(
- i->name, Member("")))
+ std::map<OUString, Member>::value_type(i.name, Member("")))
.first->second);
if (m.mandatory.isEmpty()) {
m.optional.insert(name);
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator i(
- entity->getDirectMethods().begin());
- i != entity->getDirectMethods().end(); ++i)
- {
+ for (auto & i: entity->getDirectMethods()) {
Member & m(
allMembers.insert(
- std::map<OUString, Member>::value_type(
- i->name, Member("")))
+ std::map<OUString, Member>::value_type(i.name, Member("")))
.first->second);
if (m.mandatory.isEmpty()) {
m.optional.insert(name);
diff --git a/unoidl/source/unoidl-check.cxx b/unoidl/source/unoidl-check.cxx
index b54aeaeb697f..e5f8bb0f68c6 100644
--- a/unoidl/source/unoidl-check.cxx
+++ b/unoidl/source/unoidl-check.cxx
@@ -225,7 +225,7 @@ void checkMap(
<< ent2B->getMembers().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::EnumTypeEntity::Member>::const_iterator
+ for (auto
i(ent2A->getMembers().begin()),
j(ent2B->getMembers().begin());
i != ent2A->getMembers().end(); ++i, ++j)
@@ -272,7 +272,7 @@ void checkMap(
<< ent2B->getDirectMembers().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::const_iterator
+ for (auto
i(ent2A->getDirectMembers().begin()),
j(ent2B->getDirectMembers().begin());
i != ent2A->getDirectMembers().end(); ++i, ++j)
@@ -310,7 +310,7 @@ void checkMap(
<< ent2B->getTypeParameters().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<OUString>::const_iterator
+ for (auto
i(ent2A->getTypeParameters().begin()),
j(ent2B->getTypeParameters().begin());
i != ent2A->getTypeParameters().end(); ++i, ++j)
@@ -335,7 +335,7 @@ void checkMap(
<< ent2B->getMembers().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::PolymorphicStructTypeTemplateEntity::Member>::const_iterator
+ for (auto
i(ent2A->getMembers().begin()),
j(ent2B->getMembers().begin());
i != ent2A->getMembers().end(); ++i, ++j)
@@ -389,7 +389,7 @@ void checkMap(
<< ent2B->getDirectMembers().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::const_iterator
+ for (auto
i(ent2A->getDirectMembers().begin()),
j(ent2B->getDirectMembers().begin());
i != ent2A->getDirectMembers().end(); ++i, ++j)
@@ -424,7 +424,7 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
+ for (auto
i(ent2A->getDirectMandatoryBases().begin()),
j(ent2B->getDirectMandatoryBases().begin());
i != ent2A->getDirectMandatoryBases().end(); ++i, ++j)
@@ -451,7 +451,7 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
+ for (auto
i(ent2A->getDirectOptionalBases().begin()),
j(ent2B->getDirectOptionalBases().begin());
i != ent2A->getDirectOptionalBases().end(); ++i, ++j)
@@ -477,7 +477,7 @@ void checkMap(
<< ent2B->getDirectAttributes().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
+ for (auto
i(ent2A->getDirectAttributes().begin()),
j(ent2B->getDirectAttributes().begin());
i != ent2A->getDirectAttributes().end(); ++i, ++j)
@@ -516,7 +516,7 @@ void checkMap(
<< ent2B->getDirectMethods().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator
+ for (auto
i(ent2A->getDirectMethods().begin()),
j(ent2B->getDirectMethods().begin());
i != ent2A->getDirectMethods().end(); ++i, ++j)
@@ -543,7 +543,7 @@ void checkMap(
<< j->parameters.size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method::Parameter>::const_iterator
+ for (auto
k(i->parameters.begin()),
l(j->parameters.begin());
k != i->parameters.end(); ++k, ++l)
@@ -597,20 +597,14 @@ void checkMap(
static_cast<unoidl::ConstantGroupEntity *>(entA.get()));
rtl::Reference<unoidl::ConstantGroupEntity> ent2B(
static_cast<unoidl::ConstantGroupEntity *>(entB.get()));
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- i(ent2A->getMembers().begin());
- i != ent2A->getMembers().end(); ++i)
- {
+ for (auto & i: ent2A->getMembers()) {
bool found = false;
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- j(ent2B->getMembers().begin());
- j != ent2B->getMembers().end(); ++j)
- {
- if (i->name == j->name) {
- if (i->value != j->value) {
+ for (auto & j: ent2B->getMembers()) {
+ if (i.name == j.name) {
+ if (i.value != j.value) {
std::cerr
<< "constant group " << name
- << " member " << i->name
+ << " member " << i.name
<< " changed value" << std::endl;
std::exit(EXIT_FAILURE);
}
@@ -621,7 +615,7 @@ void checkMap(
if (!found) {
std::cerr
<< "A constant group " << name << " member "
- << i->name << " is not present in B"
+ << i.name << " is not present in B"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -656,7 +650,7 @@ void checkMap(
<< ent2B->getConstructors().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor>::const_iterator
+ for (auto
i(ent2A->getConstructors().begin()),
j(ent2B->getConstructors().begin());
i != ent2A->getConstructors().end(); ++i, ++j)
@@ -704,7 +698,7 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
+ for (auto
i(ent2A->getDirectMandatoryBaseServices().begin()),
j(ent2B->getDirectMandatoryBaseServices().begin());
i != ent2A->getDirectMandatoryBaseServices().end();
@@ -736,20 +730,16 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
- i(ent2A->getDirectOptionalBaseServices().begin());
- i != ent2A->getDirectOptionalBaseServices().end();
- ++i)
- {
+ for (auto & i: ent2A->getDirectOptionalBaseServices()) {
if (std::find_if(
ent2B->getDirectOptionalBaseServices().begin(),
ent2B->getDirectOptionalBaseServices().end(),
- EqualsAnnotation(i->name))
+ EqualsAnnotation(i.name))
== ent2B->getDirectOptionalBaseServices().end())
{
std::cerr
<< "accumulation-based service " << name
- << " direct optional base service " << i->name
+ << " direct optional base service " << i.name
<< " was removed" << std::endl;
std::exit(EXIT_FAILURE);
}
@@ -767,7 +757,7 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
+ for (auto
i(ent2A->getDirectMandatoryBaseInterfaces()
.begin()),
j(ent2B->getDirectMandatoryBaseInterfaces()
@@ -801,22 +791,17 @@ void checkMap(
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator
- i(ent2A->getDirectOptionalBaseInterfaces()
- .begin());
- i != ent2A->getDirectOptionalBaseInterfaces().end();
- ++i)
- {
+ for (auto & i: ent2A->getDirectOptionalBaseInterfaces()) {
if (std::find_if(
(ent2B->getDirectOptionalBaseInterfaces()
.begin()),
ent2B->getDirectOptionalBaseInterfaces().end(),
- EqualsAnnotation(i->name))
+ EqualsAnnotation(i.name))
== ent2B->getDirectOptionalBaseInterfaces().end())
{
std::cerr
<< "accumulation-based service " << name
- << " direct optional base interface " << i->name
+ << " direct optional base interface " << i.name
<< " was removed" << std::endl;
std::exit(EXIT_FAILURE);
}
@@ -831,7 +816,7 @@ void checkMap(
<< ent2B->getDirectProperties().size() << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::const_iterator
+ for (auto
i(ent2A->getDirectProperties().begin()),
j(ent2B->getDirectProperties().begin());
i != ent2A->getDirectProperties().end(); ++i, ++j)
@@ -851,7 +836,7 @@ void checkMap(
std::exit(EXIT_FAILURE);
}
}
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::const_iterator
+ for (auto
i(ent2B->getDirectProperties().begin()
+ ent2A->getDirectProperties().size());
i != ent2B->getDirectProperties().end(); ++i)
@@ -948,13 +933,10 @@ void checkIds(
if (!entA.is()) {
rtl::Reference<unoidl::EnumTypeEntity> ent2B(
static_cast<unoidl::EnumTypeEntity *>(entB.get()));
- for (std::vector<unoidl::EnumTypeEntity::Member>::const_iterator
- i(ent2B->getMembers().begin());
- i != ent2B->getMembers().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getMembers()) {
+ if (!valid(i.name)) {
std::cerr
- << "enum type " << name << " member " << i->name
+ << "enum type " << name << " member " << i.name
<< " uses an invalid identifier" << std::endl;
std::exit(EXIT_FAILURE);
}
@@ -966,14 +948,11 @@ void checkIds(
rtl::Reference<unoidl::PlainStructTypeEntity> ent2B(
static_cast<unoidl::PlainStructTypeEntity *>(
entB.get()));
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::const_iterator
- i(ent2B->getDirectMembers().begin());
- i != ent2B->getDirectMembers().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getDirectMembers()) {
+ if (!valid(i.name)) {
std::cerr
<< "plain struct type " << name << " direct member "
- << i->name << " uses an invalid identifier"
+ << i.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -987,26 +966,20 @@ void checkIds(
static_cast<
unoidl::PolymorphicStructTypeTemplateEntity *>(
entB.get()));
- for (std::vector<OUString>::const_iterator i(
- ent2B->getTypeParameters().begin());
- i != ent2B->getTypeParameters().end(); ++i)
- {
- if (!valid(*i)) {
+ for (auto & i: ent2B->getTypeParameters()) {
+ if (!valid(i)) {
std::cerr
<< "polymorphic struct type template " << name
- << " type parameter " << *i
+ << " type parameter " << i
<< " uses an invalid identifier" << std::endl;
std::exit(EXIT_FAILURE);
}
}
- for (std::vector<unoidl::PolymorphicStructTypeTemplateEntity::Member>::const_iterator
- i(ent2B->getMembers().begin());
- i != ent2B->getMembers().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getMembers()) {
+ if (!valid(i.name)) {
std::cerr
<< "polymorphic struct type template " << name
- << " member " << i->name
+ << " member " << i.name
<< " uses an invalid identifier" << std::endl;
std::exit(EXIT_FAILURE);
}
@@ -1017,14 +990,11 @@ void checkIds(
if (!entA.is()) {
rtl::Reference<unoidl::ExceptionTypeEntity> ent2B(
static_cast<unoidl::ExceptionTypeEntity *>(entB.get()));
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::const_iterator
- i(ent2B->getDirectMembers().begin());
- i != ent2B->getDirectMembers().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getDirectMembers()) {
+ if (!valid(i.name)) {
std::cerr
<< "exception type " << name << " direct member "
- << i->name << " uses an invalid identifier"
+ << i.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -1035,38 +1005,29 @@ void checkIds(
if (!entA.is()) {
rtl::Reference<unoidl::InterfaceTypeEntity> ent2B(
static_cast<unoidl::InterfaceTypeEntity *>(entB.get()));
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
- i(ent2B->getDirectAttributes().begin());
- i != ent2B->getDirectAttributes().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getDirectAttributes()) {
+ if (!valid(i.name)) {
std::cerr
<< "interface type " << name << " direct attribute "
- << i->name << " uses an invalid identifier"
+ << i.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator
- i(ent2B->getDirectMethods().begin());
- i != ent2B->getDirectMethods().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getDirectMethods()) {
+ if (!valid(i.name)) {
std::cerr
<< "interface type " << name << " direct method "
- << i->name << " uses an invalid identifier"
+ << i.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method::Parameter>::const_iterator
- j(i->parameters.begin());
- j != i->parameters.end(); ++j)
- {
- if (!valid(j->name)) {
+ for (auto & j: i.parameters) {
+ if (!valid(j.name)) {
std::cerr
<< "interface type " << name
- << " direct method " << i->name << " parameter "
- << j->name << " uses an invalid identifier"
+ << " direct method " << i.name << " parameter "
+ << j.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -1082,29 +1043,23 @@ void checkIds(
{
rtl::Reference<unoidl::ConstantGroupEntity> ent2B(
static_cast<unoidl::ConstantGroupEntity *>(entB.get()));
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- i(ent2B->getMembers().begin());
- i != ent2B->getMembers().end(); ++i)
- {
+ for (auto & i: ent2B->getMembers()) {
bool found = false;
if (entA.is()) {
rtl::Reference<unoidl::ConstantGroupEntity> ent2A(
static_cast<unoidl::ConstantGroupEntity *>(
entA.get()));
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- j(ent2A->getMembers().begin());
- j != ent2A->getMembers().end(); ++j)
- {
- if (i->name == j->name) {
+ for (auto & j: ent2A->getMembers()) {
+ if (i.name == j.name) {
found = true;
break;
}
}
}
- if (!(found || valid(i->name))) {
+ if (!(found || valid(i.name))) {
std::cerr
<< "Constant group " << name << " member "
- << i->name << " uses an invalid identifier"
+ << i.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -1117,26 +1072,20 @@ void checkIds(
ent2B(
static_cast<unoidl::SingleInterfaceBasedServiceEntity *>(
entB.get()));
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor>::const_iterator
- i(ent2B->getConstructors().begin());
- i != ent2B->getConstructors().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getConstructors()) {
+ if (!valid(i.name)) {
std::cerr
<< "single-interface--based service " << name
- << " constructor " << i->name
+ << " constructor " << i.name
<< " uses an invalid identifier" << std::endl;
std::exit(EXIT_FAILURE);
}
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter>::const_iterator
- j(i->parameters.begin());
- j != i->parameters.end(); ++j)
- {
- if (!valid(j->name)) {
+ for (auto & j: i.parameters) {
+ if (!valid(j.name)) {
std::cerr
<< "single-interface--based service " << name
- << " constructor " << i->name << " parameter "
- << j->name << " uses an invalid identifier"
+ << " constructor " << i.name << " parameter "
+ << j.name << " uses an invalid identifier"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -1156,14 +1105,11 @@ void checkIds(
->getDirectProperties().size())
: 0);
assert(n <= ent2B->getDirectProperties().size());
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::const_iterator
- i(ent2B->getDirectProperties().begin() + n);
- i != ent2B->getDirectProperties().end(); ++i)
- {
- if (!valid(i->name)) {
+ for (auto & i: ent2B->getDirectProperties()) {
+ if (!valid(i.name)) {
std::cerr
<< "accumulation-based service " << name
- << " direct property " << i->name
+ << " direct property " << i.name
<< " uses an invalid identifier" << std::endl;
std::exit(EXIT_FAILURE);
}
diff --git a/unoidl/source/unoidl-read.cxx b/unoidl/source/unoidl-read.cxx
index e0ea73f4e13a..32bd012d8bac 100644
--- a/unoidl/source/unoidl-read.cxx
+++ b/unoidl/source/unoidl-read.cxx
@@ -180,10 +180,8 @@ void insertEntityDependencies(
std::map<OUString, Entity>::iterator const & iterator,
std::vector<OUString> const & names)
{
- for (std::vector<OUString>::const_iterator i(names.begin());
- i != names.end(); ++i)
- {
- insertEntityDependency(manager, iterator, *i);
+ for (auto & i: names) {
+ insertEntityDependency(manager, iterator, i);
}
}
@@ -192,11 +190,8 @@ void insertEntityDependencies(
std::map<OUString, Entity>::iterator const & iterator,
std::vector<unoidl::AnnotatedReference> const & references)
{
- for (std::vector<unoidl::AnnotatedReference>::const_iterator i(
- references.begin());
- i != references.end(); ++i)
- {
- insertEntityDependency(manager, iterator, i->name);
+ for (auto & i: references) {
+ insertEntityDependency(manager, iterator, i.name);
}
}
@@ -211,10 +206,8 @@ void insertTypeDependency(
OUString nucl(decomposeType(type, &rank, &args, &entity));
if (entity) {
insertEntityDependency(manager, iterator, nucl, true);
- for (std::vector<OUString>::iterator i(args.begin()); i != args.end();
- ++i)
- {
- insertTypeDependency(manager, iterator, *i);
+ for (auto & i: args) {
+ insertTypeDependency(manager, iterator, i);
}
}
}
@@ -264,11 +257,8 @@ void scanMap(
insertEntityDependency(
manager, i, ent2->getDirectBase());
}
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::const_iterator
- j(ent2->getDirectMembers().begin());
- j != ent2->getDirectMembers().end(); ++j)
- {
- insertTypeDependency(manager, i, j->type);
+ for (auto & j: ent2->getDirectMembers()) {
+ insertTypeDependency(manager, i, j.type);
}
break;
}
@@ -278,12 +268,9 @@ void scanMap(
ent2(
static_cast<unoidl::PolymorphicStructTypeTemplateEntity *>(
ent.get()));
- for (std::vector<unoidl::PolymorphicStructTypeTemplateEntity::Member>::const_iterator
- j(ent2->getMembers().begin());
- j != ent2->getMembers().end(); ++j)
- {
- if (!j->parameterized) {
- insertTypeDependency(manager, i, j->type);
+ for (auto & j: ent2->getMembers()) {
+ if (!j.parameterized) {
+ insertTypeDependency(manager, i, j.type);
}
}
break;
@@ -296,11 +283,8 @@ void scanMap(
insertEntityDependency(
manager, i, ent2->getDirectBase());
}
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::const_iterator
- j(ent2->getDirectMembers().begin());
- j != ent2->getDirectMembers().end(); ++j)
- {
- insertTypeDependency(manager, i, j->type);
+ for (auto & j: ent2->getDirectMembers()) {
+ insertTypeDependency(manager, i, j.type);
}
break;
}
@@ -313,24 +297,15 @@ void scanMap(
manager, i, ent2->getDirectMandatoryBases());
insertEntityDependencies(
manager, i, ent2->getDirectOptionalBases());
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
- j(ent2->getDirectAttributes().begin());
- j != ent2->getDirectAttributes().end(); ++j)
- {
- insertTypeDependency(manager, i, j->type);
+ for (auto & j: ent2->getDirectAttributes()) {
+ insertTypeDependency(manager, i, j.type);
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator
- j(ent2->getDirectMethods().begin());
- j != ent2->getDirectMethods().end(); ++j)
- {
- insertTypeDependency(manager, i, j->returnType);
- for (std::vector<unoidl::InterfaceTypeEntity::Method::Parameter>::const_iterator
- k(j->parameters.begin());
- k != j->parameters.end(); ++k)
- {
- insertTypeDependency(manager, i, k->type);
+ for (auto & j: ent2->getDirectMethods()) {
+ insertTypeDependency(manager, i, j.returnType);
+ for (auto & k: j.parameters) {
+ insertTypeDependency(manager, i, k.type);
}
- insertEntityDependencies(manager, i, j->exceptions);
+ insertEntityDependencies(manager, i, j.exceptions);
}
break;
}
@@ -348,17 +323,11 @@ void scanMap(
static_cast<unoidl::SingleInterfaceBasedServiceEntity *>(
ent.get()));
insertEntityDependency(manager, i, ent2->getBase());
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor>::const_iterator
- j(ent2->getConstructors().begin());
- j != ent2->getConstructors().end(); ++j)
- {
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter>::const_iterator
- k(j->parameters.begin());
- k != j->parameters.end(); ++k)
- {
- insertTypeDependency(manager, i, k->type);
+ for (auto & j: ent2->getConstructors()) {
+ for (auto & k: j.parameters) {
+ insertTypeDependency(manager, i, k.type);
}
- insertEntityDependencies(manager, i, j->exceptions);
+ insertEntityDependencies(manager, i, j.exceptions);
}
break;
}
@@ -375,11 +344,8 @@ void scanMap(
manager, i, ent2->getDirectMandatoryBaseInterfaces());
insertEntityDependencies(
manager, i, ent2->getDirectOptionalBaseInterfaces());
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::const_iterator
- j(ent2->getDirectProperties().begin());
- j != ent2->getDirectProperties().end(); ++j)
- {
- insertTypeDependency(manager, i, j->type);
+ for (auto & j: ent2->getDirectProperties()) {
+ insertTypeDependency(manager, i, j.type);
}
break;
}
@@ -408,10 +374,8 @@ void propagateRelevant(std::map<OUString, Entity> & entities, Entity & entity) {
if (!entity.relevant) {
entity.relevant = true;
if (entity.sorted != Entity::Sorted::YES) {
- for (std::set<OUString>::iterator i(entity.dependencies.begin());
- i != entity.dependencies.end(); ++i)
- {
- std::map<OUString, Entity>::iterator j(entities.find(*i));
+ for (auto & i: entity.dependencies) {
+ std::map<OUString, Entity>::iterator j(entities.find(i));
if (j != entities.end()) {
propagateRelevant(entities, j->second);
}
@@ -428,11 +392,8 @@ void visit(
switch (iterator->second.sorted) {
case Entity::Sorted::NO:
iterator->second.sorted = Entity::Sorted::ACTIVE;
- for (std::set<OUString>::iterator i(
- iterator->second.dependencies.begin());
- i != iterator->second.dependencies.end(); ++i)
- {
- std::map<OUString, Entity>::iterator j(entities.find(*i));
+ for (auto & i: iterator->second.dependencies) {
+ std::map<OUString, Entity>::iterator j(entities.find(i));
if (j != entities.end()) {
if (iterator->second.relevant) {
propagateRelevant(entities, j->second);
@@ -456,9 +417,7 @@ void visit(
std::vector<OUString> sort(std::map<OUString, Entity> & entities) {
std::vector<OUString> res;
- for (std::map<OUString, Entity>::iterator i(entities.begin());
- i != entities.end(); ++i)
- {
+ for (auto i(entities.begin()); i != entities.end(); ++i) {
visit(entities, i, res);
}
return res;
@@ -474,7 +433,8 @@ void indent(std::vector<OUString> const & modules, unsigned int extra = 0) {
}
void closeModules(
- std::vector<OUString> & modules, std::vector<OUString>::size_type n) {
+ std::vector<OUString> & modules, std::vector<OUString>::size_type n)
+{
for (std::vector<OUString>::size_type i = 0; i != n; ++i) {
assert(!modules.empty());
modules.pop_back();
@@ -521,11 +481,9 @@ void writeName(OUString const & name) {
void writeAnnotations(std::vector<OUString> const & annotations) {
if (!annotations.empty()) {
std::cout << "/**";
- for (std::vector<OUString>::const_iterator i(annotations.begin());
- i != annotations.end(); ++i)
- {
- //TODO: i->indexOf("*/") == -1
- std::cout << " @" << *i;
+ for (auto & i: annotations) {
+ //TODO: i.indexOf("*/") == -1
+ std::cout << " @" << i;
}
std::cout << " */ ";
}
@@ -561,9 +519,7 @@ void writeType(OUString const & type) {
}
if (!args.empty()) {
std::cout << "< ";
- for (std::vector<OUString>::iterator i(args.begin()); i != args.end();
- ++i)
- {
+ for (auto i(args.begin()); i != args.end(); ++i) {
if (i != args.begin()) {
std::cout << ", ";
}
@@ -579,9 +535,7 @@ void writeType(OUString const & type) {
void writeExceptionSpecification(std::vector<OUString> const & exceptions) {
if (!exceptions.empty()) {
std::cout << " raises (";
- for (std::vector<OUString>::const_iterator i(exceptions.begin());
- i != exceptions.end(); ++i)
- {
+ for (auto i(exceptions.begin()); i != exceptions.end(); ++i) {
if (i != exceptions.begin()) {
std::cout << ", ";
}
@@ -599,18 +553,15 @@ void writeEntity(
if (i != entities.end() && i->second.relevant) {
assert(!i->second.written);
i->second.written = true;
- for (std::set<OUString>::iterator j(
- i->second.interfaceDependencies.begin());
- j != i->second.interfaceDependencies.end(); ++j)
- {
- std::map<OUString, Entity>::iterator k(entities.find(*j));
+ for (auto & j: i->second.interfaceDependencies) {
+ std::map<OUString, Entity>::iterator k(entities.find(j));
if (k != entities.end() && !k->second.written) {
- OUString id(openModulesFor(modules, *j));
+ OUString id(openModulesFor(modules, j));
if (k->second.entity->getSort()
!= unoidl::Entity::SORT_INTERFACE_TYPE)
{
std::cerr
- << "Entity " << *j << " should be an interface type"
+ << "Entity " << j << " should be an interface type"
<< std::endl;
std::exit(EXIT_FAILURE);
}
@@ -633,8 +584,7 @@ void writeEntity(
static_cast<unoidl::EnumTypeEntity *>(ent.get()));
writeAnnotationsPublished(ent);
std::cout << "enum " << id << " {\n";
- for (std::vector<unoidl::EnumTypeEntity::Member>::const_iterator
- j(ent2->getMembers().begin());
+ for (auto j(ent2->getMembers().begin());
j != ent2->getMembers().end(); ++j)
{
indent(modules, 1);
@@ -660,14 +610,11 @@ void writeEntity(
writeName(ent2->getDirectBase());
}
std::cout << " {\n";
- for (std::vector<unoidl::PlainStructTypeEntity::Member>::const_iterator
- j(ent2->getDirectMembers().begin());
- j != ent2->getDirectMembers().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMembers()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
- writeType(j->type);
- std::cout << ' ' << j->name << ";\n";
+ writeAnnotations(j.annotations);
+ writeType(j.type);
+ std::cout << ' ' << j.name << ";\n";
}
indent(modules);
std::cout << "};\n";
@@ -681,8 +628,7 @@ void writeEntity(
ent.get()));
writeAnnotationsPublished(ent);
std::cout << "struct " << id << '<';
- for (std::vector<OUString>::const_iterator j(
- ent2->getTypeParameters().begin());
+ for (auto j(ent2->getTypeParameters().begin());
j != ent2->getTypeParameters().end(); ++j)
{
if (j != ent2->getTypeParameters().begin()) {
@@ -691,18 +637,15 @@ void writeEntity(
std::cout << *j;
}
std::cout << "> {\n";
- for (std::vector<unoidl::PolymorphicStructTypeTemplateEntity::Member>::const_iterator
- j(ent2->getMembers().begin());
- j != ent2->getMembers().end(); ++j)
- {
+ for (auto & j: ent2->getMembers()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
- if (j->parameterized) {
- std::cout << j->type;
+ writeAnnotations(j.annotations);
+ if (j.parameterized) {
+ std::cout << j.type;
} else {
- writeType(j->type);
+ writeType(j.type);
}
- std::cout << ' ' << j->name << ";\n";
+ std::cout << ' ' << j.name << ";\n";
}
indent(modules);
std::cout << "};\n";
@@ -719,14 +662,11 @@ void writeEntity(
writeName(ent2->getDirectBase());
}
std::cout << " {\n";
- for (std::vector<unoidl::ExceptionTypeEntity::Member>::const_iterator
- j(ent2->getDirectMembers().begin());
- j != ent2->getDirectMembers().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMembers()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
- writeType(j->type);
- std::cout << ' ' << j->name << ";\n";
+ writeAnnotations(j.annotations);
+ writeType(j.type);
+ std::cout << ' ' << j.name << ";\n";
}
indent(modules);
std::cout << "};\n";
@@ -739,74 +679,60 @@ void writeEntity(
ent.get()));
writeAnnotationsPublished(ent);
std::cout << "interface " << id << " {\n";
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectMandatoryBases().begin());
- j != ent2->getDirectMandatoryBases().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMandatoryBases()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "interface ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectOptionalBases().begin());
- j != ent2->getDirectOptionalBases().end(); ++j)
- {
+ for (auto & j: ent2->getDirectOptionalBases()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "[optional] interface ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::InterfaceTypeEntity::Attribute>::const_iterator
- j(ent2->getDirectAttributes().begin());
- j != ent2->getDirectAttributes().end(); ++j)
- {
+ for (auto & j: ent2->getDirectAttributes()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "[attribute";
- if (j->bound) {
+ if (j.bound) {
std::cout << ", bound";
}
- if (j->readOnly) {
+ if (j.readOnly) {
std::cout << ", readonly";
}
std::cout << "] ";
- writeType(j->type);
- std::cout << ' ' << j->name;
- if (!(j->getExceptions.empty() && j->setExceptions.empty()))
- {
+ writeType(j.type);
+ std::cout << ' ' << j.name;
+ if (!(j.getExceptions.empty() && j.setExceptions.empty())) {
std::cout << " {\n";
- if (!j->getExceptions.empty()) {
+ if (!j.getExceptions.empty()) {
indent(modules, 2);
std::cout << "get";
- writeExceptionSpecification(j->getExceptions);
+ writeExceptionSpecification(j.getExceptions);
std::cout << ";\n";
}
- if (!j->setExceptions.empty()) {
+ if (!j.setExceptions.empty()) {
indent(modules, 2);
std::cout << "set";
- writeExceptionSpecification(j->setExceptions);
+ writeExceptionSpecification(j.setExceptions);
std::cout << ";\n";
}
std::cout << " }";
}
std::cout << ";\n";
}
- for (std::vector<unoidl::InterfaceTypeEntity::Method>::const_iterator
- j(ent2->getDirectMethods().begin());
- j != ent2->getDirectMethods().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMethods()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
- writeType(j->returnType);
- std::cout << ' ' << j->name << '(';
- for (std::vector<unoidl::InterfaceTypeEntity::Method::Parameter>::const_iterator
- k(j->parameters.begin());
- k != j->parameters.end(); ++k)
+ writeAnnotations(j.annotations);
+ writeType(j.returnType);
+ std::cout << ' ' << j.name << '(';
+ for (auto k(j.parameters.begin()); k != j.parameters.end();
+ ++k)
{
- if (k != j->parameters.begin()) {
+ if (k != j.parameters.begin()) {
std::cout << ", ";
}
switch (k->direction) {
@@ -824,7 +750,7 @@ void writeEntity(
std::cout << ' ' << k->name;
}
std::cout << ')';
- writeExceptionSpecification(j->exceptions);
+ writeExceptionSpecification(j.exceptions);
std::cout << ";\n";
}
indent(modules);
@@ -847,14 +773,11 @@ void writeEntity(
static_cast<unoidl::ConstantGroupEntity *>(ent.get()));
writeAnnotationsPublished(ent);
std::cout << "constants " << id << " {\n";
- for (std::vector<unoidl::ConstantGroupEntity::Member>::const_iterator
- j(ent2->getMembers().begin());
- j != ent2->getMembers().end(); ++j)
- {
+ for (auto & j: ent2->getMembers()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "const ";
- switch (j->value.type) {
+ switch (j.value.type) {
case unoidl::ConstantValue::TYPE_BOOLEAN:
std::cout << "boolean";
break;
@@ -886,37 +809,37 @@ void writeEntity(
std::cout << "double";
break;
}
- std::cout << ' ' << j->name << " = ";
- switch (j->value.type) {
+ std::cout << ' ' << j.name << " = ";
+ switch (j.value.type) {
case unoidl::ConstantValue::TYPE_BOOLEAN:
- std::cout << (j->value.booleanValue ? "TRUE" : "FALSE");
+ std::cout << (j.value.booleanValue ? "TRUE" : "FALSE");
break;
case unoidl::ConstantValue::TYPE_BYTE:
- std::cout << int(j->value.byteValue);
+ std::cout << int(j.value.byteValue);
break;
case unoidl::ConstantValue::TYPE_SHORT:
- std::cout << j->value.shortValue;
+ std::cout << j.value.shortValue;
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_SHORT:
- std::cout << j->value.unsignedShortValue;
+ std::cout << j.value.unsignedShortValue;
break;
case unoidl::ConstantValue::TYPE_LONG:
- std::cout << j->value.longValue;
+ std::cout << j.value.longValue;
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_LONG:
- std::cout << j->value.unsignedLongValue;
+ std::cout << j.value.unsignedLongValue;
break;
case unoidl::ConstantValue::TYPE_HYPER:
- std::cout << j->value.hyperValue;
+ std::cout << j.value.hyperValue;
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_HYPER:
- std::cout << j->value.unsignedHyperValue;
+ std::cout << j.value.unsignedHyperValue;
break;
case unoidl::ConstantValue::TYPE_FLOAT:
- std::cout << j->value.floatValue;
+ std::cout << j.value.floatValue;
break;
case unoidl::ConstantValue::TYPE_DOUBLE:
- std::cout << j->value.doubleValue;
+ std::cout << j.value.doubleValue;
break;
}
std::cout << ";\n";
@@ -937,18 +860,14 @@ void writeEntity(
|| !ent2->getConstructors().front().defaultConstructor)
{
std::cout << " {\n";
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor>::const_iterator
- j(ent2->getConstructors().begin());
- j != ent2->getConstructors().end(); ++j)
- {
+ for (auto & j: ent2->getConstructors()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
- std::cout << j->name << '(';
- for (std::vector<unoidl::SingleInterfaceBasedServiceEntity::Constructor::Parameter>::const_iterator
- k(j->parameters.begin());
- k != j->parameters.end(); ++k)
+ writeAnnotations(j.annotations);
+ std::cout << j.name << '(';
+ for (auto k(j.parameters.begin());
+ k != j.parameters.end(); ++k)
{
- if (k != j->parameters.begin()) {
+ if (k != j.parameters.begin()) {
std::cout << ", ";
}
std::cout << "[in] ";
@@ -959,7 +878,7 @@ void writeEntity(
std::cout << ' ' << k->name;
}
std::cout << ')';
- writeExceptionSpecification(j->exceptions);
+ writeExceptionSpecification(j.exceptions);
std::cout << ";\n";
}
indent(modules);
@@ -975,110 +894,95 @@ void writeEntity(
ent.get()));
writeAnnotationsPublished(ent);
std::cout << "service " << id << " {\n";
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectMandatoryBaseServices().begin());
- j != ent2->getDirectMandatoryBaseServices().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMandatoryBaseServices()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "service ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectOptionalBaseServices().begin());
- j != ent2->getDirectOptionalBaseServices().end(); ++j)
- {
+ for (auto & j: ent2->getDirectOptionalBaseServices()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "[optional] service ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectMandatoryBaseInterfaces().begin());
- j != ent2->getDirectMandatoryBaseInterfaces().end(); ++j)
- {
+ for (auto & j: ent2->getDirectMandatoryBaseInterfaces()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "interface ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::AnnotatedReference>::const_iterator j(
- ent2->getDirectOptionalBaseInterfaces().begin());
- j != ent2->getDirectOptionalBaseInterfaces().end(); ++j)
- {
+ for (auto & j: ent2->getDirectOptionalBaseInterfaces()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "[optional] interface ";
- writeName(j->name);
+ writeName(j.name);
std::cout << ";\n";
}
- for (std::vector<unoidl::AccumulationBasedServiceEntity::Property>::const_iterator
- j(ent2->getDirectProperties().begin());
- j != ent2->getDirectProperties().end(); ++j)
- {
+ for (auto & j: ent2->getDirectProperties()) {
indent(modules, 1);
- writeAnnotations(j->annotations);
+ writeAnnotations(j.annotations);
std::cout << "[property";
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_BOUND)
!= 0)
{
std::cout << ", bound";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_CONSTRAINED)
!= 0)
{
std::cout << ", constrained";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_MAYBE_AMBIGUOUS)
!= 0)
{
std::cout << ", maybeambiguous";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_MAYBE_DEFAULT)
!= 0)
{
std::cout << ", maybedefault";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_MAYBE_VOID)
!= 0)
{
std::cout << ", maybevoid";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_OPTIONAL)
!= 0)
{
std::cout << ", optional";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_READ_ONLY)
!= 0)
{
std::cout << ", readonly";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_REMOVABLE)
!= 0)
{
std::cout << ", removable";
}
- if ((j->attributes
+ if ((j.attributes
& unoidl::AccumulationBasedServiceEntity::Property::ATTRIBUTE_TRANSIENT)
!= 0)
{
std::cout << ", transient";
}
std::cout << "] ";
- writeType(j->type);
- std::cout << ' ' << j->name << ";\n";
+ writeType(j.type);
+ std::cout << ' ' << j.name << ";\n";
}
indent(modules);
std::cout << "};\n";
@@ -1140,10 +1044,8 @@ SAL_IMPLEMENT_MAIN() {
scanMap(mgr, prov->createRootCursor(), published, "", ents);
std::vector<OUString> sorted(sort(ents));
std::vector<OUString> mods;
- for (std::vector<OUString>::iterator i(sorted.begin());
- i != sorted.end(); ++i)
- {
- writeEntity(ents, mods, *i);
+ for (auto & i: sorted) {
+ writeEntity(ents, mods, i);
}
closeModules(mods, mods.size());
return EXIT_SUCCESS;
diff --git a/unoidl/source/unoidl-write.cxx b/unoidl/source/unoidl-write.cxx
index 01d22baffd52..d95dbb0b5c95 100644
--- a/unoidl/source/unoidl-write.cxx
+++ b/unoidl/source/unoidl-write.cxx
@@ -271,10 +271,8 @@ void writeAnnotations(
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));
+ for (auto & i: annotations) {
+ writeIdxString(file, toUtf8(i));
}
}
}
@@ -449,35 +447,29 @@ void mapCursor(
sal_uInt64 writeMap(
osl::File & file, std::map< OUString, Item > & map, std::size_t * rootSize)
{
- for (std::map< OUString, Item >::iterator i(map.begin()); i != map.end();
- ++i)
- {
- switch (i->second.entity->getSort()) {
+ for (auto & i: map) {
+ switch (i.second.entity->getSort()) {
case unoidl::Entity::SORT_MODULE:
- i->second.dataOffset = writeMap(file, i->second.module, nullptr);
+ i.second.dataOffset = writeMap(file, i.second.module, nullptr);
break;
case unoidl::Entity::SORT_ENUM_TYPE:
{
rtl::Reference< unoidl::EnumTypeEntity > ent2(
static_cast< unoidl::EnumTypeEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector< unoidl::EnumTypeEntity::Member >::
- const_iterator j(ent2->getMembers().begin());
+ for (auto j(ent2->getMembers().begin());
!ann && j != ent2->getMembers().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
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)
- {
- writeIdxName(file, j->name);
- write32(file, static_cast< sal_uInt32 >(j->value));
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getMembers()) {
+ writeIdxName(file, j.name);
+ write32(file, static_cast< sal_uInt32 >(j.value));
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -486,28 +478,24 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::PlainStructTypeEntity > ent2(
static_cast< unoidl::PlainStructTypeEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector< unoidl::PlainStructTypeEntity::Member >::
- const_iterator j(ent2->getDirectMembers().begin());
+ for (auto j(ent2->getDirectMembers().begin());
!ann && j != ent2->getDirectMembers().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(
file, ent2.get(), ann, !ent2->getDirectBase().isEmpty());
if (!ent2->getDirectBase().isEmpty()) {
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)
- {
- writeIdxName(file, j->name);
- writeIdxName(file, j->type);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectMembers()) {
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.type);
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -518,40 +506,29 @@ sal_uInt64 writeMap(
ent2(
static_cast<
unoidl::PolymorphicStructTypeTemplateEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector<
- unoidl::PolymorphicStructTypeTemplateEntity::Member >::
- const_iterator j(
- ent2->getMembers().begin());
+ for (auto j(ent2->getMembers().begin());
!ann && j != ent2->getMembers().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
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)
- {
- writeIdxName(file, *j);
+ for (auto & j: ent2->getTypeParameters()) {
+ writeIdxName(file, j);
}
write32(file, ent2->getMembers().size());
- for (std::vector<
- unoidl::PolymorphicStructTypeTemplateEntity::Member >::
- const_iterator j(
- ent2->getMembers().begin());
- j != ent2->getMembers().end(); ++j)
- {
+ for (auto & j: ent2->getMembers()) {
sal_uInt64 f = 0;
- if (j->parameterized) {
+ if (j.parameterized) {
f |= 0x01;
}
write8(file, f);
- writeIdxName(file, j->name);
- writeIdxName(file, j->type);
- writeAnnotations(file, ann, j->annotations);
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.type);
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -560,28 +537,24 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::ExceptionTypeEntity > ent2(
static_cast< unoidl::ExceptionTypeEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector< unoidl::ExceptionTypeEntity::Member >::
- const_iterator j(ent2->getDirectMembers().begin());
+ for (auto j(ent2->getDirectMembers().begin());
!ann && j != ent2->getDirectMembers().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(
file, ent2.get(), ann, !ent2->getDirectBase().isEmpty());
if (!ent2->getDirectBase().isEmpty()) {
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)
- {
- writeIdxName(file, j->name);
- writeIdxName(file, j->type);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectMembers()) {
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.type);
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -590,108 +563,79 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::InterfaceTypeEntity > ent2(
static_cast< unoidl::InterfaceTypeEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectMandatoryBases().begin());
+ for (auto 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());
+ for (auto 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());
+ for (auto 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());
+ for (auto j(ent2->getDirectMethods().begin());
!ann && j != ent2->getDirectMethods().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
write32(file, ent2->getDirectMandatoryBases().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectMandatoryBases().begin());
- j != ent2->getDirectMandatoryBases().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectMandatoryBases()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectOptionalBases().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectOptionalBases().begin());
- j != ent2->getDirectOptionalBases().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectOptionalBases()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectAttributes().size());
- for (std::vector< unoidl::InterfaceTypeEntity::Attribute >::
- const_iterator j(ent2->getDirectAttributes().begin());
- j != ent2->getDirectAttributes().end(); ++j)
- {
+ for (auto & j: ent2->getDirectAttributes()) {
sal_uInt64 f = 0;
- if (j->bound) {
+ if (j.bound) {
f |= 0x01;
}
- if (j->readOnly) {
+ if (j.readOnly) {
f |= 0x02;
}
write8(file, f);
- 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)
- {
- writeIdxName(file, *k);
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.type);
+ write32(file, j.getExceptions.size());
+ for (auto & k: j.getExceptions) {
+ writeIdxName(file, k);
}
- if (!j->readOnly) {
- write32(file, j->setExceptions.size());
- for (std::vector< OUString >::const_iterator k(
- j->setExceptions.begin());
- k != j->setExceptions.end(); ++k)
- {
- writeIdxName(file, *k);
+ if (!j.readOnly) {
+ write32(file, j.setExceptions.size());
+ for (auto & k: j.setExceptions) {
+ writeIdxName(file, k);
}
}
- writeAnnotations(file, ann, j->annotations);
+ 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)
- {
- writeIdxName(file, j->name);
- writeIdxName(file, j->returnType);
- write32(file, j->parameters.size());
- for (std::vector<
- unoidl::InterfaceTypeEntity::Method::Parameter >::
- const_iterator k(j->parameters.begin());
- k != j->parameters.end(); ++k)
- {
- write8(file, k->direction);
- writeIdxName(file, k->name);
- writeIdxName(file, k->type);
+ for (auto & j: ent2->getDirectMethods()) {
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.returnType);
+ write32(file, j.parameters.size());
+ for (auto & k: j.parameters) {
+ write8(file, k.direction);
+ 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)
- {
- writeIdxName(file, *k);
+ write32(file, j.exceptions.size());
+ for (auto & k: j.exceptions) {
+ writeIdxName(file, k);
}
- writeAnnotations(file, ann, j->annotations);
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -700,9 +644,9 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::TypedefEntity > ent2(
static_cast< unoidl::TypedefEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
writeIdxName(file, ent2->getType());
writeAnnotations(file, ann, ent2->getAnnotations());
@@ -712,102 +656,91 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::ConstantGroupEntity > ent2(
static_cast< unoidl::ConstantGroupEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
std::map< OUString, ConstItem > cmap;
- for (std::vector< unoidl::ConstantGroupEntity::Member >::
- const_iterator j(ent2->getMembers().begin());
- j != ent2->getMembers().end(); ++j)
- {
+ for (auto & j: ent2->getMembers()) {
if (!cmap.insert(
std::make_pair(
- j->name, ConstItem(j->value, j->annotations))).
+ j.name, ConstItem(j.value, j.annotations))).
second)
{
std::cout
<< "Duplicate constant group member name \""
- << j->name << '"' << std::endl;
+ << j.name << '"' << std::endl;
std::exit(EXIT_FAILURE);
}
}
- for (std::map< OUString, ConstItem >::iterator j(cmap.begin());
- j != cmap.end(); ++j)
- {
- j->second.dataOffset = getOffset(file);
- sal_uInt64 v = j->second.constant.type;
- if (!j->second.annotations.empty()) {
+ for (auto & j: cmap) {
+ j.second.dataOffset = getOffset(file);
+ sal_uInt64 v = j.second.constant.type;
+ if (!j.second.annotations.empty()) {
v |= 0x80;
}
write8(file, v);
- switch (j->second.constant.type) {
+ switch (j.second.constant.type) {
case unoidl::ConstantValue::TYPE_BOOLEAN:
- write8(file, j->second.constant.booleanValue ? 1 : 0);
+ write8(file, j.second.constant.booleanValue ? 1 : 0);
break;
case unoidl::ConstantValue::TYPE_BYTE:
write8(
file,
static_cast< sal_uInt8 >(
- j->second.constant.byteValue));
+ j.second.constant.byteValue));
break;
case unoidl::ConstantValue::TYPE_SHORT:
write16(
file,
static_cast< sal_uInt16 >(
- j->second.constant.shortValue));
+ j.second.constant.shortValue));
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_SHORT:
- write16(file, j->second.constant.unsignedShortValue);
+ write16(file, j.second.constant.unsignedShortValue);
break;
case unoidl::ConstantValue::TYPE_LONG:
write32(
file,
static_cast< sal_uInt32 >(
- j->second.constant.longValue));
+ j.second.constant.longValue));
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_LONG:
- write32(file, j->second.constant.unsignedLongValue);
+ write32(file, j.second.constant.unsignedLongValue);
break;
case unoidl::ConstantValue::TYPE_HYPER:
write64(
file,
static_cast< sal_uInt64 >(
- j->second.constant.hyperValue));
+ j.second.constant.hyperValue));
break;
case unoidl::ConstantValue::TYPE_UNSIGNED_HYPER:
- write64(file, j->second.constant.unsignedHyperValue);
+ write64(file, j.second.constant.unsignedHyperValue);
break;
case unoidl::ConstantValue::TYPE_FLOAT:
writeIso60599Binary32(
- file, j->second.constant.floatValue);
+ file, j.second.constant.floatValue);
break;
case unoidl::ConstantValue::TYPE_DOUBLE:
writeIso60599Binary64(
- file, j->second.constant.doubleValue);
+ file, j.second.constant.doubleValue);
break;
default:
for (;;) { std::abort(); } // this cannot happen
}
writeAnnotations(
- file, !j->second.annotations.empty(),
- j->second.annotations);
+ file, !j.second.annotations.empty(),
+ j.second.annotations);
}
- for (std::map< OUString, ConstItem >::iterator j(
- cmap.begin());
- j != cmap.end(); ++j)
- {
- j->second.nameOffset = writeNulName(file, j->first);
+ for (auto & j: cmap) {
+ j.second.nameOffset = writeNulName(file, j.first);
}
bool ann = !ent2->getAnnotations().empty();
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
write32(file, cmap.size());
// overflow from std::map::size_type -> sal_uInt64 is
// unrealistic
- for (std::map< OUString, ConstItem >::iterator j(
- cmap.begin());
- j != cmap.end(); ++j)
- {
- write32(file, j->second.nameOffset);
- write32(file, j->second.dataOffset);
+ for (auto & j: cmap) {
+ write32(file, j.second.nameOffset);
+ write32(file, j.second.dataOffset);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -818,61 +751,45 @@ sal_uInt64 writeMap(
ent2(
static_cast<
unoidl::SingleInterfaceBasedServiceEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool dfltCtor = ent2->getConstructors().size() == 1
&& ent2->getConstructors()[0].defaultConstructor;
bool ann = !ent2->getAnnotations().empty();
if (!dfltCtor) {
- for (std::vector<
- unoidl::SingleInterfaceBasedServiceEntity::
- Constructor >::const_iterator j(
- ent2->getConstructors().begin());
+ for (auto j(ent2->getConstructors().begin());
!ann && j != ent2->getConstructors().end(); ++j)
{
ann = !j->annotations.empty();
}
}
- i->second.dataOffset = getOffset(file);
+ 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<
- unoidl::SingleInterfaceBasedServiceEntity::
- Constructor >::const_iterator j(
- ent2->getConstructors().begin());
- j != ent2->getConstructors().end(); ++j)
- {
- if (j->defaultConstructor) {
+ for (auto & j: ent2->getConstructors()) {
+ if (j.defaultConstructor) {
std::cout
<< "Unexpected default constructor \""
- << j->name << '"' << std::endl;
+ << j.name << '"' << std::endl;
std::exit(EXIT_FAILURE);
}
- writeIdxName(file, j->name);
- write32(file, j->parameters.size());
- for (std::vector<
- unoidl::SingleInterfaceBasedServiceEntity::
- Constructor::Parameter >::const_iterator k(
- j->parameters.begin());
- k != j->parameters.end(); ++k)
- {
+ writeIdxName(file, j.name);
+ write32(file, j.parameters.size());
+ for (auto & k: j.parameters) {
sal_uInt64 f = 0;
- if (k->rest) {
+ if (k.rest) {
f |= 0x04;
}
write8(file, f);
- writeIdxName(file, k->name);
- writeIdxName(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)
- {
- writeIdxName(file, *k);
+ write32(file, j.exceptions.size());
+ for (auto & k: j.exceptions) {
+ writeIdxName(file, k);
}
- writeAnnotations(file, ann, j->annotations);
+ writeAnnotations(file, ann, j.annotations);
}
}
writeAnnotations(file, ann, ent2->getAnnotations());
@@ -882,90 +799,66 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::AccumulationBasedServiceEntity > ent2(
static_cast< unoidl::AccumulationBasedServiceEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectMandatoryBaseServices().begin());
+ for (auto 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());
+ for (auto 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());
+ for (auto 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());
+ for (auto 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());
+ for (auto j(ent2->getDirectProperties().begin());
!ann && j != ent2->getDirectProperties().end(); ++j)
{
ann = !j->annotations.empty();
}
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
write32(file, ent2->getDirectMandatoryBaseServices().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectMandatoryBaseServices().begin());
- j != ent2->getDirectMandatoryBaseServices().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectMandatoryBaseServices()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectOptionalBaseServices().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectOptionalBaseServices().begin());
- j != ent2->getDirectOptionalBaseServices().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectOptionalBaseServices()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectMandatoryBaseInterfaces().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectMandatoryBaseInterfaces().begin());
- j != ent2->getDirectMandatoryBaseInterfaces().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectMandatoryBaseInterfaces()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectOptionalBaseInterfaces().size());
- for (std::vector< unoidl::AnnotatedReference >::const_iterator
- j(ent2->getDirectOptionalBaseInterfaces().begin());
- j != ent2->getDirectOptionalBaseInterfaces().end(); ++j)
- {
- writeIdxName(file, j->name);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectOptionalBaseInterfaces()) {
+ writeIdxName(file, j.name);
+ writeAnnotations(file, ann, j.annotations);
}
write32(file, ent2->getDirectProperties().size());
- for (std::vector<
- unoidl::AccumulationBasedServiceEntity::Property >::
- const_iterator j(
- ent2->getDirectProperties().begin());
- j != ent2->getDirectProperties().end(); ++j)
- {
- write16(file, static_cast< sal_uInt16 >(j->attributes));
- writeIdxName(file, j->name);
- writeIdxName(file, j->type);
- writeAnnotations(file, ann, j->annotations);
+ for (auto & j: ent2->getDirectProperties()) {
+ write16(file, static_cast< sal_uInt16 >(j.attributes));
+ writeIdxName(file, j.name);
+ writeIdxName(file, j.type);
+ writeAnnotations(file, ann, j.annotations);
}
writeAnnotations(file, ann, ent2->getAnnotations());
break;
@@ -974,9 +867,9 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::InterfaceBasedSingletonEntity > ent2(
static_cast< unoidl::InterfaceBasedSingletonEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
writeIdxName(file, ent2->getBase());
writeAnnotations(file, ann, ent2->getAnnotations());
@@ -986,9 +879,9 @@ sal_uInt64 writeMap(
{
rtl::Reference< unoidl::ServiceBasedSingletonEntity > ent2(
static_cast< unoidl::ServiceBasedSingletonEntity * >(
- i->second.entity.get()));
+ i.second.entity.get()));
bool ann = !ent2->getAnnotations().empty();
- i->second.dataOffset = getOffset(file);
+ i.second.dataOffset = getOffset(file);
writeKind(file, ent2.get(), ann);
writeIdxName(file, ent2->getBase());
writeAnnotations(file, ann, ent2->getAnnotations());
@@ -996,10 +889,8 @@ sal_uInt64 writeMap(
}
}
}
- for (std::map< OUString, Item >::iterator i(map.begin()); i != map.end();
- ++i)
- {
- i->second.nameOffset = writeNulName(file, i->first);
+ for (auto & i: map) {
+ i.second.nameOffset = writeNulName(file, i.first);
}
sal_uInt64 off = getOffset(file);
if (rootSize == nullptr) {
@@ -1010,11 +901,9 @@ sal_uInt64 writeMap(
*rootSize = map.size();
// overflow from std::map::size_type -> std::size_t is unrealistic
}
- for (std::map< OUString, Item >::iterator i(map.begin()); i != map.end();
- ++i)
- {
- write32(file, i->second.nameOffset);
- write32(file, i->second.dataOffset);
+ for (auto & i: map) {
+ write32(file, i.second.nameOffset);
+ write32(file, i.second.dataOffset);
}
return off;
}
diff --git a/unoidl/source/unoidl.cxx b/unoidl/source/unoidl.cxx
index 56761e1e315b..26236a4e27d2 100644
--- a/unoidl/source/unoidl.cxx
+++ b/unoidl/source/unoidl.cxx
@@ -49,11 +49,8 @@ private:
std::vector< OUString > AggregatingModule::getMemberNames() const {
std::set< OUString > names;
- for (std::vector< rtl::Reference< Provider > >::const_iterator i(
- providers_.begin());
- i != providers_.end(); ++i)
- {
- rtl::Reference< Entity > ent((*i)->findEntity(name_));
+ for (auto & i: providers_) {
+ rtl::Reference< Entity > ent(i->findEntity(name_));
if (ent.is() && ent->getSort() == Entity::SORT_MODULE) {
std::vector< OUString > ns(
static_cast< ModuleEntity * >(ent.get())->getMemberNames());
@@ -179,11 +176,8 @@ rtl::Reference< Provider > Manager::addProvider(OUString const & uri) {
rtl::Reference< Entity > Manager::findEntity(rtl::OUString const & name) const {
//TODO: caching? (here or in cppuhelper::TypeManager?)
osl::MutexGuard g(mutex_);
- for (std::vector< rtl::Reference< Provider > >::const_iterator i(
- providers_.begin());
- i != providers_.end(); ++i)
- {
- rtl::Reference< Entity > ent((*i)->findEntity(name));
+ for (auto & i: providers_) {
+ rtl::Reference< Entity > ent(i->findEntity(name));
if (ent.is()) {
return ent;
}