Skip to content

Commit

Permalink
Fix fixed-size Array visualization (#81)
Browse files Browse the repository at this point in the history
* Fix fixed-size Array visualization

Don't assume that has_maximum_size means that a maximum_size field
exists on the object. In the case of an Array object, has_maximum_size
is True, but there is no 'maximum_size' field, only 'size'.

Fixes: #77

Signed-off-by: Michael Jeronimo <[email protected]>

* Update src/rqt_plot/plot_widget.py

Co-authored-by: Chris Lalancette <[email protected]>

Co-authored-by: Chris Lalancette <[email protected]>
  • Loading branch information
Michael Jeronimo and clalancette authored Apr 18, 2022
1 parent d2e7329 commit e68d1f7
Showing 1 changed file with 7 additions and 3 deletions.
10 changes: 7 additions & 3 deletions src/rqt_plot/plot_widget.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,12 +122,16 @@ def get_plot_fields(node, topic_name):

if is_array_or_sequence:
if not has_index:
return [], base_error_msg + f'{name} is a nested type but not index provided'
return [], base_error_msg + f'{name} is a nested type but no index provided'

if current_type.has_maximum_size():
if index >= current_type.maximum_size:
# has_maximum_size() doesn't necessarily mean that the object has a 'maximum_size' field. The meaning
# appears to be that the object is bounded in its size and has either a 'maximum_size' or 'size' field.
size = current_type.maximum_size if hasattr(current_type, 'maximum_size') else current_type.size
if index >= size:
return [], (
base_error_msg +
f"index '{index}' out of bounds, maximum size is {current_type.maximum_size}")
f"index '{index}' out of bounds, maximum size is {size}")
current_type = current_type.value_type
elif has_index:
return [], base_error_msg + "{name} is not an array or sequence"
Expand Down

0 comments on commit e68d1f7

Please sign in to comment.