Skip to content

Commit

Permalink
don't cache defaultParserMap: allowed might change between calls
Browse files Browse the repository at this point in the history
  • Loading branch information
rhaschke committed Sep 21, 2022
1 parent 1f1e18e commit 42af95b
Showing 1 changed file with 6 additions and 7 deletions.
13 changes: 6 additions & 7 deletions urdf/src/sensor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -91,12 +91,12 @@ SensorParserMap getSensorParsers(const std::vector<std::string> &allowed)
{
static boost::mutex PARSER_PLUGIN_LOCK;
static boost::shared_ptr<pluginlib::ClassLoader<urdf::SensorParser> > PARSER_PLUGIN_LOADER;
static SensorParserMap defaultParserMap;

boost::mutex::scoped_lock _(PARSER_PLUGIN_LOCK);

SensorParserMap parserMap;
try
{
if (!PARSER_PLUGIN_LOADER) {
if (!PARSER_PLUGIN_LOADER)
PARSER_PLUGIN_LOADER.reset(new pluginlib::ClassLoader<urdf::SensorParser>("urdf", "urdf::SensorParser"));

const std::vector<std::string> &classes = PARSER_PLUGIN_LOADER->getDeclaredClasses();
Expand All @@ -112,18 +112,17 @@ SensorParserMap getSensorParsers(const std::vector<std::string> &allowed)
} catch(const pluginlib::PluginlibException& ex) {
ROS_ERROR_STREAM("Failed to create sensor parser: " << classes[i] << "\n" << ex.what());
}
defaultParserMap.insert(std::make_pair(classes[i], parser));
parserMap.insert(std::make_pair(classes[i], parser));
ROS_DEBUG_STREAM("added sensor parser: " << classes[i]);
}
if (defaultParserMap.empty())
if (parserMap.empty())
ROS_WARN_STREAM("No sensor parsers found");
}
}
catch(const pluginlib::PluginlibException& ex)
{
ROS_ERROR_STREAM("Exception while creating sensor plugin loader " << ex.what());
}
return defaultParserMap;
return parserMap;
}

SensorParserMap getSensorParser(const std::string &name)
Expand Down

0 comments on commit 42af95b

Please sign in to comment.