Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bponsler/rosautodoc
Automatically generate documentation for ROS nodes
https://github.com/bponsler/rosautodoc
Last synced: 2 months ago
JSON representation
Automatically generate documentation for ROS nodes
- Host: GitHub
- URL: https://github.com/bponsler/rosautodoc
- Owner: bponsler
- License: apache-2.0
- Created: 2017-10-06T05:01:32.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2020-11-13T15:09:07.000Z (about 4 years ago)
- Last Synced: 2024-08-03T02:02:40.527Z (5 months ago)
- Language: Python
- Size: 15.6 KB
- Stars: 19
- Watchers: 3
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ros-tools - rosautodoc - the rosautodoc project provides a python executable that can automatically generate documentation for ROS nodes that are running on the system. ![rosautodoc](https://img.shields.io/github/stars/bponsler/rosautodoc.svg?style=flat&label=Star&maxAge=86400) (Development Tools / Documentation)
README
# rosautodoc
The rosautodoc project provides a python executable that can automatically
generate documentation for ROS nodes that are running on the system.## Why should I care?
This tool makes it possible to quickly generate initial documentation of
the interface for a specific ROS node (or several nodes) based on how it
performs at runtime. This eliminates the need to search through your code
to make sure you document all the ROS parameters being used, or all the
topics that your node is subscribing to. This script manages all of that
for you -- you just need to fill in the descriptions of the API.## Installation
Follow these instructions to download and install this project:
git clone https://github.com/bponsler/rosautodoc
cd rosautodoc
sudo python setup.py install## How does this work?
The rosautodoc script creates a proxy server that stands between a ROS system and the
ROS master to intercept all requests made by nodes. This allows the proxy server to
keep track of all publishers, subscribers, parameters, and services used by each
node and then use this information to create documentation for the node.## Usage
This section describes how to use this project to automatically generate documentation.
$ rosautodoc --help
usage: rosautodoc [-h] [--output-dir OUTPUT_DIR] [--proxy-port PROXY_PORT]
[--doc-format DOC_FORMAT]
[node [node ...]]Automatically document the API for a ROS node.
positional arguments:
node The name of the nodes to document. If empty, all nodes
will be documentedoptional arguments:
-h, --help show this help message and exit
--output-dir OUTPUT_DIR
The directory where documentation should be written
--proxy-port PROXY_PORT
The port to use for the ROS master proxy server
--doc-format DOC_FORMAT
The format of the documentation to generate (markdown,
html)# Examples
First, run the ROS master in one terminal (using the default master URI http://localhost:11311):
roscore
Next, run the auto doc script in another terminal:
mkdir /tmp/my_documentation
rosautodoc --proxy-port=33133 --output=/tmp/my_documentationFinally, run your node in another terminal, and be sure to connect it to the same port that the rosautodoc script is using:
export ROS_MASTER_URI=http://localhost:33133
rosrun my_package my_nodeOnce your node has finished starting up, you can stop the rosautodoc process which will
write one documentation file for every node on the system. The documentation will be
located in the /tmp/my_documentation directory.Alternatively, you can document only a specific node:
rosautodoc --proxy-port=33133 --output=/tmp/my_documentation /ns/my_node_name
The following command can be used to generate HTML documentation:
rosautodoc --proxy-port=33133 --doc-format=html --output=/tmp/my_documentation
This will generate an HTML documentation page for every node in your system and
also a main index.html page that links to all the node documentation pages.You can also generate documentation for only a specific set of nodes.
rosautodoc --proxy-port=33133 node1 node2 node3
This command will generated a markdown (the default documentation format) file
for the three nodes provides: node1, node2, and node3. It will also generate
a main README.md file that links to the individual node documentation pages.Note that since the --output-dir argument was not provided, the documentation
will be generated in the current working directory by defualt.# Example documentation
For example documentation view one of the following pages:
- [Example Markdown documentation](examples/markdown_example/README.md)
- [Example HTML documentation (raw)](examples/html_example/index.html)
- [Example HTML documentation (rendered)](https://rawgit.com/bponsler/rosautodoc/master/examples/html_example/index.html)