Skip to content

Commit

Permalink
Merge pull request #288 from orocos-toolchain/fix/component-path
Browse files Browse the repository at this point in the history
Change component loader behaviour to consider a component found on first valid path
  • Loading branch information
meyerj authored May 6, 2019
2 parents c5904a7 + a434694 commit 93db31f
Showing 1 changed file with 1 addition and 34 deletions.
35 changes: 1 addition & 34 deletions rtt/deployment/ComponentLoader.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -385,39 +385,6 @@ bool ComponentLoader::import( std::string const& path_list )
// If the path is not complete (not absolute), look it up in the search directories:
log(Debug) << "No such directory: " << p<< endlog();
}
#if 0
// Repeat for path/OROCOS_TARGET: (already done in other import function)
p = path(*it) / OROCOS_TARGET_NAME;
if (is_directory(p))
{
log(Info) << "Importing component libraries from directory " << p.string() << " ..."<<endlog();
for (directory_iterator itr(p); itr != directory_iterator(); ++itr)
{
log(Debug) << "Scanning file " << itr->path().string() << " ...";
if (is_regular_file(itr->status()) && isLoadableLibrary(itr->path()) ) {
found = true;
#if BOOST_VERSION >= 104600
all_good = loadInProcess( itr->path().string(), makeShortFilename(itr->path().filename().string() ), true) && all_good;
#else
all_good = loadInProcess( itr->path().string(), makeShortFilename(itr->path().filename() ), true) && all_good;
#endif
}else {
if (!is_regular_file(itr->status()))
log(Debug) << "not a regular file: ignored."<<endlog();
else
log(Debug) << "not a " + SO_EXT + " library: ignored."<<endlog();
}
}
log(Info) << "Importing plugins and typekits from directory " << p.string() << " ..."<<endlog();
try {
found = PluginLoader::Instance()->loadTypekits( p.string() ) || found;
found = PluginLoader::Instance()->loadPlugins( p.string() ) || found;
} catch (std::exception& e) {
all_good = false;
log(Error) << e.what() <<endlog();
}
}
#endif
}
if (!all_good)
throw std::runtime_error("Some found plugins could not be loaded !");
Expand Down Expand Up @@ -497,7 +464,7 @@ bool ComponentLoader::importInstalledPackage(std::string const& package, std::st
} // else: we allow to import a subdirectory of '.'.
}
// append '/package' or 'target/package' to each plugin path in order to search all of them:
for(vector<string>::iterator it = vpaths.begin(); it != vpaths.end(); ++it) {
for(vector<string>::iterator it = vpaths.begin(); !path_found && it != vpaths.end(); ++it) {
p = *it;
p = p / package;
// we only search in existing directories:
Expand Down

0 comments on commit 93db31f

Please # to comment.