Skip to content

Commit

Permalink
fix(tier4_autoware_utils): exception handling in tier4 autoware utils (
Browse files Browse the repository at this point in the history
…#1268)

* fix(tier4_autoware_utils): fix exception handling (WIP)

Signed-off-by: Fumiya Watanabe <rej55.g@gmail.com>

* fix(tier4_autoware_utils): fix for overlapping points and test

Signed-off-by: Fumiya Watanabe <rej55.g@gmail.com>

* fix(tier4_autoware_utils): formatting

Signed-off-by: Fumiya Watanabe <rej55.g@gmail.com>

* fix(trajectory_follower): fix for overlapping points and test

Signed-off-by: Fumiya Watanabe <rej55.g@gmail.com>

* ci(pre-commit): autofix

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
  • Loading branch information
rej55 and pre-commit-ci[bot] authored Jul 9, 2022
1 parent 56885ed commit e198fd8
Show file tree
Hide file tree
Showing 6 changed files with 300 additions and 105 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -38,12 +38,22 @@ namespace tier4_autoware_utils
template <>
inline boost::optional<geometry_msgs::msg::Point> calcLongitudinalOffsetPoint(
const std::vector<autoware_auto_planning_msgs::msg::PathPointWithLaneId> & points,
const size_t src_idx, const double offset)
const size_t src_idx, const double offset, const bool throw_exception)
{
validateNonEmpty(points);
try {
validateNonEmpty(points);
} catch (const std::exception & e) {
std::cerr << e.what() << std::endl;
return {};
}

if (points.size() - 1 < src_idx) {
throw std::out_of_range("Invalid source index");
const auto e = std::out_of_range("Invalid source index");
if (throw_exception) {
throw e;
}
std::cerr << e.what() << std::endl;
return {};
}

if (points.size() == 1) {
Expand Down Expand Up @@ -92,7 +102,12 @@ inline boost::optional<geometry_msgs::msg::Point> calcLongitudinalOffsetPoint(
const std::vector<autoware_auto_planning_msgs::msg::PathPointWithLaneId> & points,
const geometry_msgs::msg::Point & src_point, const double offset)
{
validateNonEmpty(points);
try {
validateNonEmpty(points);
} catch (const std::exception & e) {
std::cerr << e.what() << std::endl;
return {};
}

if (offset < 0.0) {
auto reverse_points = points;
Expand All @@ -117,12 +132,22 @@ inline boost::optional<geometry_msgs::msg::Point> calcLongitudinalOffsetPoint(
template <>
inline boost::optional<geometry_msgs::msg::Pose> calcLongitudinalOffsetPose(
const std::vector<autoware_auto_planning_msgs::msg::PathPointWithLaneId> & points,
const size_t src_idx, const double offset)
const size_t src_idx, const double offset, const bool throw_exception)
{
validateNonEmpty(points);
try {
validateNonEmpty(points);
} catch (const std::exception & e) {
std::cerr << e.what() << std::endl;
return {};
}

if (points.size() - 1 < src_idx) {
throw std::out_of_range("Invalid source index");
const auto e = std::out_of_range("Invalid source index");
if (throw_exception) {
throw e;
}
std::cerr << e.what() << std::endl;
return {};
}

if (points.size() == 1) {
Expand Down Expand Up @@ -184,7 +209,12 @@ inline boost::optional<geometry_msgs::msg::Pose> calcLongitudinalOffsetPose(
const std::vector<autoware_auto_planning_msgs::msg::PathPointWithLaneId> & points,
const geometry_msgs::msg::Point & src_point, const double offset)
{
validateNonEmpty(points);
try {
validateNonEmpty(points);
} catch (const std::exception & e) {
std::cerr << e.what() << std::endl;
return {};
}

const size_t src_seg_idx = findNearestSegmentIndex(points, src_point);
const double signed_length_src_offset =
Expand All @@ -206,7 +236,12 @@ inline boost::optional<size_t> insertTargetPoint(
std::vector<autoware_auto_planning_msgs::msg::PathPointWithLaneId> & points,
const double overlap_threshold)
{
validateNonEmpty(points);
try {
validateNonEmpty(points);
} catch (const std::exception & e) {
std::cerr << e.what() << std::endl;
return {};
}

// invalid segment index
if (seg_idx + 1 >= points.size()) {
Expand Down
Loading

0 comments on commit e198fd8

Please sign in to comment.