-
Notifications
You must be signed in to change notification settings - Fork 79
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support image transport publishers in nodelet lazy #75
base: indigo-devel
Are you sure you want to change the base?
Support image transport publishers in nodelet lazy #75
Conversation
for (size_t i = 0; i < publishers_.size(); i++) | ||
BOOST_FOREACH (const ros::Publisher& pub, publishers_) | ||
{ | ||
if (pub.getNumSubscribers() > 0) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This code is the same for both types of subscribers.
I can factorize it into a templated method to avoid code duplication. I didn't do it b/c I think this way the intention and changes are cleaner in the diff. I can do that in another PR.
const std::string& topic, int queue_size, bool latch=false) | ||
{ | ||
boost::mutex::scoped_lock lock(connection_mutex_); | ||
image_transport::SubscriberStatusCallback connect_cb |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm reusing the connect_cb
callback for connection and disconnection.
I've changed the other advertise
method to do the same and also remove the _1
placeholder.
Note that the connectionCallback
argument isn't used, and it's actually shadowed in the code (in the for loop).
f8b1db2
to
894ccfd
Compare
Thanks @efernandez I will try to go over this PR soon and give feedback. As this breaks API / ABI, it will need to be released in Melodic or ROS-N but not in the already released distributions. At which point it may make sense to use c++11/14 features rather extending our use of boost. |
@mikaelarguedas I can give it another thought to use some template magic and avoid breaking API / ABI, but at first sight looks hard to me, or at least it'd be too verbose. Re. C++11/14, I'd be happy to contribute another PR with that, but I wouldn't do it in this one. Re. |
I haven't looked too much into the details of the API and this patch. But in my opinion the question is not if there is "a strong reason to avoid the dependency". The question is why should If certain information is currently not exposed or additional API is needed that can certainly be changed / added in nodelet to accommodate the requirements. |
Thanks @dirk-thomas . I'll try to see how far I can go, b/c the current implementation is specific for @mikaelarguedas Are you ok with me doing changes to this PR so it allows to extend I've just sent another commit the makes the Do you mind pointing to things you'll be willing to accept from my changes as a separate PR, meanwhile? |
d4e8ed7
to
2938455
Compare
@mikaelarguedas @dirk-thomas I've updated the PR so now it doesn't depend on |
@@ -57,6 +58,25 @@ enum ConnectionStatus | |||
SUBSCRIBED | |||
}; | |||
|
|||
/** |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a helper function, that can also be used in the child class.
@@ -135,7 +155,7 @@ class NodeletLazy: public nodelet::Nodelet | |||
/** @brief | |||
* callback function which is called when new subscriber come | |||
*/ | |||
virtual void connectionCallback(const ros::SingleSubscriberPublisher& pub) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This argument isn't used. It's not even in the doxygen documentation.
And I had to remove it because otherwise I can use it with an image_transport::Publisher
callback.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I left a few comments to help with the review.
@@ -144,28 +164,23 @@ class NodeletLazy: public nodelet::Nodelet | |||
if (lazy_) | |||
{ | |||
boost::mutex::scoped_lock lock(connection_mutex_); | |||
for (size_t i = 0; i < publishers_.size(); i++) | |||
if (hasSubscribers()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a very small and cosmetic change, but the diff is large because of one if
block getting into the method. I recommend hiding whitespace changes.
Now this method can be overridden by the child class to also check for the image_transport::Publisher
s.
} | ||
} | ||
if (connection_status_ == SUBSCRIBED) | ||
else if (connection_status_ == SUBSCRIBED) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The rest remains the same, but I changed the return;
inside the if
block to and if-else
block, which is equivalent and easier to read in my opinion. If you don't like it, I can remove this from the PR.
@@ -217,22 +232,29 @@ class NodeletLazy: public nodelet::Nodelet | |||
*/ | |||
template<class T> ros::Publisher | |||
advertise(ros::NodeHandle& nh, | |||
std::string topic, int queue_size, bool latch=false) | |||
const std::string& topic, int queue_size, bool latch=false) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The change to const &
is in a separate commit, so if you don't like it I can remove it from this PR, but we shouldn't be passing a std::string
by copy.
= boost::bind(&NodeletLazy::connectionCallback, this, _1); | ||
ros::SubscriberStatusCallback disconnect_cb | ||
= boost::bind(&NodeletLazy::connectionCallback, this, _1); | ||
= boost::bind(&NodeletLazy::connectionCallback, this); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note that I remove the _1
placeholder here, which is important after the change in connectionCallback
.
The change to use connect_cb
for both disconnection and connection is optional, but I think it's cleaner, since this was already declaring disconnect_cb
the same way as connect_cb
.
* @brief Checkes if at least one publisher has subscribers. | ||
* @return True if at least one publisher has subscribers; False otherwise. | ||
*/ | ||
virtual bool hasSubscribers() const |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A child class can overload this to support other type of publishers with something like this: return NodeletLazy::hasSubscribers() || nodelet_topic_tools::has_subscribers(image_transport_publishers_);
@dirk-thomas Any idea where can I contribute the child class that I have to support both ros::Publisher
and image_transport::Publisher
? For now I have it on a private repo.
Maybe image_transport
, but then it'd have to depend on nodelet_topic_tools
, which doesn't sound good.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe
image_transport
Sounds like the best option to me.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@vrabaud Could you comment on this?
Long story short, I've done some changes here so it's possible to extend the nodelet_topic_tools::NodeLazy
class to support both ros::Publisher
and image_transport::Publisher
.
Now I'm looking for a repo where I can contribute the derived class that provides that functionality. If you think image_transport
is a good place, where in there could it be? Maybe a new package, b/c this will need a dependency on nodelet_topic_tools
.
I think the test for 14:46:29 Traceback (most recent call last):
14:46:29 File "/usr/lib/python3/dist-packages/apt/cache.py", line 218, in __getitem__
14:46:29 return self._weakref[key]
14:46:29 File "/usr/lib/python3.6/weakref.py", line 137, in __getitem__
14:46:29 o = self.data[key]()
14:46:29 KeyError: 'ros-melodic-pluginlib' If you don't consider the change on |
@mikaelarguedas What do you think of my latest changes? I've just rebased on top of |
2938455
to
d1ff6a7
Compare
Add hasSubscribers and remove not-needed argument from connectionCallback, so we can overload the hasSubscriber check and support image_transport::Publisher. Also share connect and disconnect cb.
d1ff6a7
to
52a66c6
Compare
ping |
No description provided.