Skip to content

Commit

Permalink
Leverage tesseract_common loadYamlFile and loadYamlString
Browse files Browse the repository at this point in the history
  • Loading branch information
Levi-Armstrong committed Jan 4, 2025
1 parent f6c8709 commit 2cf803b
Show file tree
Hide file tree
Showing 19 changed files with 92 additions and 55 deletions.
2 changes: 1 addition & 1 deletion tesseract_examples/src/basic_cartesian_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,7 @@ bool BasicCartesianExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("cartesian_program", ManipulatorInfo("manipulator", "base_link", "tool0"));
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/car_seat_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,7 @@ bool CarSeatExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Get manipulator
JointGroup::ConstPtr joint_group = env_->getJointGroup("manipulator");
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/freespace_hybrid_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ bool FreespaceHybridExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("FREESPACE", ManipulatorInfo("manipulator", "base_link", "tool0"));
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/freespace_ompl_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ bool FreespaceOMPLExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("FREESPACE", ManipulatorInfo("manipulator", "base_link", "tool0"));
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/glass_upright_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -166,7 +166,7 @@ bool GlassUprightExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("UPRIGHT", ManipulatorInfo("manipulator", "base_link", "tool0"));
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/pick_and_place_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -181,7 +181,7 @@ bool PickAndPlaceExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction pick_program("DEFAULT", ManipulatorInfo("manipulator", LINK_BASE_NAME, LINK_END_EFFECTOR_NAME));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ bool PuzzlePieceAuxillaryAxesExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("DEFAULT", mi);
Expand Down
2 changes: 1 addition & 1 deletion tesseract_examples/src/puzzle_piece_example.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ bool PuzzlePieceExample::run()
// Create Task Composer Plugin Factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *env_->getResourceLocator());

// Create Program
CompositeInstruction program("DEFAULT", mi);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -113,19 +113,19 @@ class TaskComposerPluginFactory
* @brief Load plugins from yaml node
* @param config The config node
*/
TaskComposerPluginFactory(const YAML::Node& config);
TaskComposerPluginFactory(const YAML::Node& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from file path
* @param config The config file path
*/
TaskComposerPluginFactory(const tesseract_common::fs::path& config);
TaskComposerPluginFactory(const tesseract_common::fs::path& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from string
* @param config The config string
*/
TaskComposerPluginFactory(const std::string& config);
TaskComposerPluginFactory(const std::string& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Loads plugins from a configuration object
Expand All @@ -137,19 +137,19 @@ class TaskComposerPluginFactory
* @brief Load plugins from yaml node
* @param config The config node
*/
void loadConfig(const YAML::Node& config);
void loadConfig(const YAML::Node& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from file path
* @param config The config file path
*/
void loadConfig(const tesseract_common::fs::path& config);
void loadConfig(const tesseract_common::fs::path& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from string
* @param config The config string
*/
void loadConfig(const std::string& config);
void loadConfig(const std::string& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Add location for the plugin loader to search
Expand Down Expand Up @@ -307,6 +307,8 @@ class TaskComposerPluginFactory
private:
struct Implementation;
std::unique_ptr<Implementation> impl_;

void loadConfig(const YAML::Node& config);
};
} // namespace tesseract_planning
#endif // TESSERACT_TASK_COMPOSER_TASK_COMPOSER_FACTORY_H
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ TESSERACT_COMMON_IGNORE_WARNINGS_PUSH
#include <map>
TESSERACT_COMMON_IGNORE_WARNINGS_POP

#include <tesseract_common/fwd.h>
#include <tesseract_common/filesystem.h>

namespace YAML
Expand Down Expand Up @@ -62,19 +63,19 @@ class TaskComposerServer
* @brief Load plugins from yaml node
* @param config The config node
*/
void loadConfig(const YAML::Node& config);
void loadConfig(const YAML::Node& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from file path
* @param config The config file path
*/
void loadConfig(const tesseract_common::fs::path& config);
void loadConfig(const tesseract_common::fs::path& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Load plugins from string
* @param config The config string
*/
void loadConfig(const std::string& config);
void loadConfig(const std::string& config, const tesseract_common::ResourceLocator& locator);

/**
* @brief Add a executors (thread pool)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,9 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP
#include <tesseract_task_composer/core/task_composer_plugin_factory.h>
#include <tesseract_task_composer/core/nodes/done_task.h>

#include <tesseract_common/resource_locator.h>
#include <tesseract_common/yaml_utils.h>

namespace tesseract_planning::test_suite
{
template <typename T>
Expand Down Expand Up @@ -78,6 +81,7 @@ void runTaskComposerExecutorTest()
test_suite::runSerializationPointerTest(executor, "TaskComposerExecutorTests");
}

tesseract_common::GeneralResourceLocator locator;
std::string str = R"(task_composer_plugins:
search_paths:
- /usr/local/lib
Expand Down Expand Up @@ -154,7 +158,7 @@ void runTaskComposerExecutorTest()
destinations: [AbortTask, DoneTask]
terminals: [AbortTask, DoneTask])";

TaskComposerPluginFactory factory(str);
TaskComposerPluginFactory factory(str, locator);

{ // Pipeline
std::string str2 = R"(config:
Expand Down
33 changes: 24 additions & 9 deletions tesseract_task_composer/core/src/task_composer_plugin_factory.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ TESSERACT_COMMON_IGNORE_WARNINGS_PUSH
#include <utility>
TESSERACT_COMMON_IGNORE_WARNINGS_POP

#include <tesseract_common/resource_locator.h>
#include <tesseract_common/plugin_loader.hpp>
#include <tesseract_common/yaml_utils.h>
#include <tesseract_common/yaml_extenstions.h>
Expand Down Expand Up @@ -73,20 +74,25 @@ TaskComposerPluginFactory::TaskComposerPluginFactory(const tesseract_common::Tas
loadConfig(config);
}

TaskComposerPluginFactory::TaskComposerPluginFactory(const YAML::Node& config) : TaskComposerPluginFactory()
TaskComposerPluginFactory::TaskComposerPluginFactory(const YAML::Node& config,
const tesseract_common::ResourceLocator& locator)
: TaskComposerPluginFactory()
{
loadConfig(config);
loadConfig(config, locator);
}

TaskComposerPluginFactory::TaskComposerPluginFactory(const tesseract_common::fs::path& config)
TaskComposerPluginFactory::TaskComposerPluginFactory(const tesseract_common::fs::path& config,
const tesseract_common::ResourceLocator& locator)
: TaskComposerPluginFactory()
{
loadConfig(config);
loadConfig(config, locator);
}

TaskComposerPluginFactory::TaskComposerPluginFactory(const std::string& config) : TaskComposerPluginFactory()
TaskComposerPluginFactory::TaskComposerPluginFactory(const std::string& config,
const tesseract_common::ResourceLocator& locator)
: TaskComposerPluginFactory()
{
loadConfig(config);
loadConfig(config, locator);
}

// This prevents it from being defined inline.
Expand Down Expand Up @@ -120,12 +126,21 @@ void TaskComposerPluginFactory::loadConfig(const YAML::Node& config)
}
}

void TaskComposerPluginFactory::loadConfig(const tesseract_common::fs::path& config)
void TaskComposerPluginFactory::loadConfig(const YAML::Node& config, const tesseract_common::ResourceLocator& locator)
{
loadConfig(YAML::LoadFile(config.string()));
loadConfig(tesseract_common::processYamlIncludeDirective(config, locator));
}

void TaskComposerPluginFactory::loadConfig(const std::string& config) { loadConfig(YAML::Load(config)); }
void TaskComposerPluginFactory::loadConfig(const tesseract_common::fs::path& config,
const tesseract_common::ResourceLocator& locator)
{
loadConfig(tesseract_common::loadYamlFile(config.string(), locator));
}

void TaskComposerPluginFactory::loadConfig(const std::string& config, const tesseract_common::ResourceLocator& locator)
{
loadConfig(tesseract_common::loadYamlString(config, locator));
}

void TaskComposerPluginFactory::addSearchPath(const std::string& path)
{
Expand Down
14 changes: 8 additions & 6 deletions tesseract_task_composer/core/src/task_composer_server.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,26 +36,28 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP
#include <tesseract_task_composer/core/task_composer_node.h>
#include <tesseract_task_composer/core/task_composer_data_storage.h>
#include <tesseract_task_composer/core/task_composer_plugin_factory.h>
#include <tesseract_common/resource_locator.h>

namespace tesseract_planning
{
TaskComposerServer::TaskComposerServer() : plugin_factory_(std::make_shared<TaskComposerPluginFactory>()) {}

void TaskComposerServer::loadConfig(const YAML::Node& config)
void TaskComposerServer::loadConfig(const YAML::Node& config, const tesseract_common::ResourceLocator& locator)
{
plugin_factory_->loadConfig(config);
plugin_factory_->loadConfig(config, locator);
loadPlugins();
}

void TaskComposerServer::loadConfig(const tesseract_common::fs::path& config)
void TaskComposerServer::loadConfig(const tesseract_common::fs::path& config,
const tesseract_common::ResourceLocator& locator)
{
plugin_factory_->loadConfig(config);
plugin_factory_->loadConfig(config, locator);
loadPlugins();
}

void TaskComposerServer::loadConfig(const std::string& config)
void TaskComposerServer::loadConfig(const std::string& config, const tesseract_common::ResourceLocator& locator)
{
plugin_factory_->loadConfig(config);
plugin_factory_->loadConfig(config, locator);
loadPlugins();
}

Expand Down
4 changes: 3 additions & 1 deletion tesseract_task_composer/examples/task_composer_example.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@

#include <iostream>
#include <tesseract_common/utils.h>
#include <tesseract_common/resource_locator.h>
#include <tesseract_task_composer/core/task_composer_context.h>
#include <tesseract_task_composer/core/task_composer_future.h>
#include <tesseract_task_composer/core/task_composer_node_info.h>
Expand Down Expand Up @@ -124,8 +125,9 @@ int main()
task_composer.addEdges(task2_id, { task3_id });

const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::GeneralResourceLocator locator;
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, locator);

auto task_executor = factory.createTaskComposerExecutor("TaskflowExecutor");
TaskComposerFuture::UPtr future = task_executor->run(task_composer, std::move(task_data));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ int main()
// Get plugin factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *locator);

// Create raster task
TaskComposerNode::UPtr task = factory.createTaskComposerNode("RasterFtPipeline");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP

#include <tesseract_common/types.h>
#include <tesseract_common/utils.h>
#include <tesseract_common/resource_locator.h>
#include <tesseract_state_solver/state_solver.h>
#include <tesseract_environment/environment.h>
#include <tesseract_command_language/composite_instruction.h>
Expand Down Expand Up @@ -53,7 +54,7 @@ int main()
// Get plugin factory
const std::string share_dir(TESSERACT_TASK_COMPOSER_DIR);
tesseract_common::fs::path config_path(share_dir + "/config/task_composer_plugins.yaml");
TaskComposerPluginFactory factory(config_path);
TaskComposerPluginFactory factory(config_path, *locator);

// Create trajopt pipeline
TaskComposerNode::UPtr task = factory.createTaskComposerNode("TrajOptPipeline");
Expand Down
Loading

0 comments on commit 2cf803b

Please sign in to comment.