summaryrefslogtreecommitdiff
path: root/unoidl
diff options
context:
space:
mode:
Diffstat (limited to 'unoidl')
-rw-r--r--unoidl/source/sourceprovider-parser.y89
-rw-r--r--unoidl/source/sourcetreeprovider.cxx3
2 files changed, 35 insertions, 57 deletions
diff --git a/unoidl/source/sourceprovider-parser.y b/unoidl/source/sourceprovider-parser.y
index f504d515832f..c491d23daea8 100644
--- a/unoidl/source/sourceprovider-parser.y
+++ b/unoidl/source/sourceprovider-parser.y
@@ -273,12 +273,11 @@ unoidl::detail::SourceProviderEntity * findEntity_(
rtl::Reference<unoidl::Entity> ent(data->manager->findEntity(n));
if (ent.is()) {
std::map<OUString, unoidl::detail::SourceProviderEntity>::iterator
- k(data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ k(data->entities.emplace(
n,
unoidl::detail::SourceProviderEntity(
unoidl::detail::SourceProviderEntity::KIND_EXTERNAL,
- ent))).
+ ent)).
first);
*name = n;
return &k->second;
@@ -295,12 +294,11 @@ unoidl::detail::SourceProviderEntity * findEntity_(
rtl::Reference<unoidl::Entity> ent(data->manager->findEntity(n));
if (ent.is()) {
std::map<OUString, unoidl::detail::SourceProviderEntity>::iterator
- j(data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ j(data->entities.emplace(
n,
unoidl::detail::SourceProviderEntity(
unoidl::detail::SourceProviderEntity::KIND_EXTERNAL,
- ent))).
+ ent)).
first);
*name = n;
return &j->second;
@@ -959,11 +957,10 @@ moduleDecl:
OUString name(convertToFullName(data, $2));
data->modules.push_back(name);
std::pair<std::map<OUString, unoidl::detail::SourceProviderEntity>::iterator, bool> p(
- data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ data->entities.emplace(
name,
unoidl::detail::SourceProviderEntity(
- unoidl::detail::SourceProviderEntity::KIND_MODULE))));
+ unoidl::detail::SourceProviderEntity::KIND_MODULE)));
if (!p.second
&& (p.first->second.kind
!= unoidl::detail::SourceProviderEntity::KIND_MODULE))
@@ -981,12 +978,11 @@ enumDefn:
unoidl::detail::SourceProviderScannerData * data = yyget_extra(yyscanner);
data->publishedContext = $2;
convertToCurrentName(data, $4);
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderEnumTypeEntityPad(
- $2)))).
+ $2))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -1113,12 +1109,11 @@ plainStructDefn:
YYERROR;
}
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderPlainStructTypeEntityPad(
- $2, baseName, baseEnt)))).
+ $2, baseName, baseEnt))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -1147,12 +1142,11 @@ polymorphicStructTemplateDefn:
unoidl::detail::SourceProviderScannerData * data = yyget_extra(yyscanner);
data->publishedContext = $2;
convertToCurrentName(data, $4);
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderPolymorphicStructTypeTemplateEntityPad(
- $2)))).
+ $2))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -1244,12 +1238,11 @@ exceptionDefn:
YYERROR;
}
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderExceptionTypeEntityPad(
- $2, baseName, baseEnt)))).
+ $2, baseName, baseEnt))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -1940,13 +1933,12 @@ typedefDefn:
default:
break;
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
name,
unoidl::detail::SourceProviderEntity(
unoidl::detail::SourceProviderEntity::KIND_LOCAL,
new unoidl::TypedefEntity(
- $2, t.getName(), annotations($1))))).
+ $2, t.getName(), annotations($1)))).
second)
{
error(@5, yyscanner, "multiple entities named " + name);
@@ -1962,12 +1954,11 @@ constantGroupDefn:
unoidl::detail::SourceProviderScannerData * data = yyget_extra(yyscanner);
data->publishedContext = $2;
convertToCurrentName(data, $4);
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderConstantGroupEntityPad(
- $2)))).
+ $2))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -2326,12 +2317,11 @@ singleInterfaceBasedServiceDefn:
+ " base " + base + " is unpublished"));
YYERROR;
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderSingleInterfaceBasedServiceEntityPad(
- $2, base)))).
+ $2, base))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -2540,12 +2530,11 @@ accumulationBasedServiceDefn:
unoidl::detail::SourceProviderScannerData * data = yyget_extra(yyscanner);
data->publishedContext = $2;
convertToCurrentName(data, $4);
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
data->currentName,
unoidl::detail::SourceProviderEntity(
new unoidl::detail::SourceProviderAccumulationBasedServiceEntityPad(
- $2)))).
+ $2))).
second)
{
error(@4, yyscanner, "multiple entities named " + data->currentName);
@@ -2857,13 +2846,12 @@ interfaceBasedSingletonDefn:
+ " is unpublished"));
YYERROR;
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
name,
unoidl::detail::SourceProviderEntity(
unoidl::detail::SourceProviderEntity::KIND_LOCAL,
new unoidl::InterfaceBasedSingletonEntity(
- $2, base, annotations($1))))).
+ $2, base, annotations($1)))).
second)
{
error(@4, yyscanner, "multiple entities named " + name);
@@ -2908,13 +2896,12 @@ serviceBasedSingletonDefn:
+ " is unpublished"));
YYERROR;
}
- if (!data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ if (!data->entities.emplace(
name,
unoidl::detail::SourceProviderEntity(
unoidl::detail::SourceProviderEntity::KIND_LOCAL,
new unoidl::ServiceBasedSingletonEntity(
- $2, base, annotations($1))))).
+ $2, base, annotations($1)))).
second)
{
error(@4, yyscanner, "multiple entities named " + name);
@@ -3020,13 +3007,12 @@ interfaceDecl:
data->publishedContext = $2;
OUString name(convertToFullName(data, $4));
std::pair<std::map<OUString, unoidl::detail::SourceProviderEntity>::iterator, bool> p(
- data->entities.insert(
- std::map<OUString, unoidl::detail::SourceProviderEntity>::value_type(
+ data->entities.emplace(
name,
unoidl::detail::SourceProviderEntity(
$2
? unoidl::detail::SourceProviderEntity::KIND_PUBLISHED_INTERFACE_DECL
- : unoidl::detail::SourceProviderEntity::KIND_INTERFACE_DECL))));
+ : unoidl::detail::SourceProviderEntity::KIND_INTERFACE_DECL)));
if (!p.second) {
switch (p.first->second.kind) {
case unoidl::detail::SourceProviderEntity::KIND_INTERFACE_DECL:
@@ -4087,9 +4073,7 @@ bool SourceProviderInterfaceTypeEntityPad::addDirectMember(
if (!checkMemberClashes(location, yyscanner, data, "", name, true)) {
return false;
}
- allMembers.insert(
- std::map<OUString, Member>::value_type(
- name, Member(data->currentName)));
+ allMembers.emplace(name, Member(data->currentName));
return true;
}
@@ -4270,8 +4254,7 @@ bool SourceProviderInterfaceTypeEntityPad::addBase(
? direct ? BASE_DIRECT_OPTIONAL : BASE_INDIRECT_OPTIONAL
: direct ? BASE_DIRECT_MANDATORY : BASE_INDIRECT_MANDATORY;
std::pair<std::map<OUString, BaseKind>::iterator, bool> p(
- allBases.insert(
- std::map<OUString, BaseKind>::value_type(name, kind)));
+ allBases.emplace(name, kind));
bool seen = !p.second && p.first->second >= BASE_INDIRECT_MANDATORY;
if (!p.second && kind > p.first->second) {
p.first->second = kind;
@@ -4333,12 +4316,10 @@ bool SourceProviderInterfaceTypeEntityPad::addBase(
}
}
for (auto & i: entity->getDirectAttributes()) {
- allMembers.insert(
- std::map<OUString, Member>::value_type(i.name, Member(name)));
+ allMembers.emplace(i.name, Member(name));
}
for (auto & i: entity->getDirectMethods()) {
- allMembers.insert(
- std::map<OUString, Member>::value_type(i.name, Member(name)));
+ allMembers.emplace(i.name, Member(name));
}
}
return true;
@@ -4378,8 +4359,7 @@ bool SourceProviderInterfaceTypeEntityPad::addOptionalBaseMembers(
}
for (auto & i: entity->getDirectAttributes()) {
Member & m(
- allMembers.insert(
- std::map<OUString, Member>::value_type(i.name, Member("")))
+ allMembers.emplace(i.name, Member(""))
.first->second);
if (m.mandatory.isEmpty()) {
m.optional.insert(name);
@@ -4387,8 +4367,7 @@ bool SourceProviderInterfaceTypeEntityPad::addOptionalBaseMembers(
}
for (auto & i: entity->getDirectMethods()) {
Member & m(
- allMembers.insert(
- std::map<OUString, Member>::value_type(i.name, Member("")))
+ allMembers.emplace(i.name, Member(""))
.first->second);
if (m.mandatory.isEmpty()) {
m.optional.insert(name);
diff --git a/unoidl/source/sourcetreeprovider.cxx b/unoidl/source/sourcetreeprovider.cxx
index 55dd2ac68d98..da1770ca0704 100644
--- a/unoidl/source/sourcetreeprovider.cxx
+++ b/unoidl/source/sourcetreeprovider.cxx
@@ -201,8 +201,7 @@ rtl::Reference<Entity> SourceTreeProvider::findEntity(OUString const & name)
"<" << uri << "> does not define entity " << name);
}
}
- cache_.insert(
- std::map< OUString, rtl::Reference<Entity> >::value_type(name, ent));
+ cache_.emplace(name, ent);
return ent;
}