-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Signed-off-by: Shane Loretz <shane.loretz@gmail.com> (cherry picked from commit 12cc86a) Co-authored-by: Shane Loretz <sloretz@osrfoundation.org>
- Loading branch information
1 parent
d5641e2
commit b78154f
Showing
3 changed files
with
137 additions
and
114 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
132 changes: 132 additions & 0 deletions
132
source/How-To-Guides/Migrating-from-ROS1/Migrating-Package-XML.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,132 @@ | ||
Migrating your package.xml to format 2 | ||
====================================== | ||
|
||
.. contents:: Table of Contents | ||
:depth: 2 | ||
:local: | ||
|
||
ROS 2 requires ``package.xml`` files to use at least `format 2 <https://ros.org/reps/rep-0140.html>`__. | ||
This guide shows how to migrate a ``package.xml`` from format 1 to format 2. | ||
|
||
If the ``<package>`` tag at the start of your ``package.xml`` looks like either of the following, then it is using format 1 and you must migrate it. | ||
|
||
.. code-block:: xml | ||
<package> | ||
.. code-block:: xml | ||
<package format="1"> | ||
Prerequisites | ||
------------- | ||
|
||
You should have a working ROS 1 installation. | ||
This enables you to check that the converted ``package.xml`` is valid by building and testing the package, since ROS 1 supports all ``package.xml`` format versions. | ||
|
||
Migrate from format 1 to 2 | ||
-------------------------- | ||
|
||
Format 1 and format 2 differ in how they specify dependencies. | ||
Read the `compatibility section in REP-0140 <https://www.ros.org/reps/rep-0140.html#compatibility>`__ for a summary of the differences. | ||
|
||
Add ``format`` attribute to ``<package>`` | ||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
Add or set the ``format`` attribute to ``2`` to indicate that the ``package.xml`` uses format 2. | ||
|
||
.. code:: xml | ||
<package format="2"> | ||
Replace ``<run_depend>`` | ||
~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
The ``<run_depend>`` tag is no longer allowed. | ||
If you have a dependency specified like this: | ||
|
||
.. code:: xml | ||
<run_depend>foo</run_depend> | ||
then replace it with one or both of these tags: | ||
|
||
.. code:: xml | ||
<build_export_depend>foo</build_export_depend> | ||
<exec_depend>foo</exec_depend> | ||
If the dependency is needed when something in your package is executed, then use the ``<exec_depend>`` tag. | ||
If packages that depend on your package need the dependency when they are built, then use the ``<build_export_depend>`` tag. | ||
Use both tags if you are unsure. | ||
|
||
Convert some ``<build_depend>`` to ``<test_depend>`` | ||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
In format 1 ``<test_depend>`` declares dependencies that are needed when running your package's tests. | ||
It still does that in format 2, but it additionally declares dependencies that are needed when building your package's tests. | ||
|
||
Because of the limitations of this tag in format 1, your package may have a test-only dependency specified as a ``<build_depend>`` like this: | ||
|
||
.. code:: xml | ||
<build_depend>testfoo</build_depend> | ||
If so, change it to a ``<test_depend>``. | ||
|
||
.. code:: xml | ||
<test_depend>testfoo</test_depend> | ||
.. note:: | ||
|
||
If you are using CMake, then make sure your test dependencies are only referenced within a ``if(BUILD_TESTING)`` block: | ||
|
||
.. code:: cmake | ||
if (BUILD_TESTING) | ||
find_package(testfoo REQUIRED) | ||
endif() | ||
Begin using ``<doc_depend>`` | ||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
Use the new ``<doc_depend>`` tag to declare dependencies needed for building your package's documentation. | ||
For example, C++ packages might have this dependency: | ||
|
||
.. code:: xml | ||
<doc_depend>doxygen</doc_depend> | ||
while Python packages might have this one: | ||
|
||
.. code:: xml | ||
<doc_depend>python3-sphinx</doc_depend> | ||
See :doc:`the guide on documenting ROS 2 packages <../Documenting-a-ROS-2-Package>` for more information. | ||
|
||
Simplify dependencies with ``<depend>`` | ||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
|
||
``<depend>`` is a new tag that makes ``package.xml`` files more concise. | ||
If your ``package.xml`` has these three tags for the same dependency: | ||
|
||
.. code:: | ||
<build_depend>foo</build_depend> | ||
<build_export_depend>foo</build_export_depend> | ||
<exec_depend>foo</exec_depend> | ||
then replace them with a single ``<depend>`` like this: | ||
|
||
.. code:: xml | ||
<depend>foo</depend> | ||
Test your new ``package.xml`` | ||
----------------------------- | ||
|
||
Build and test your package as you normally do using ``catkin_make``, ``cakin_make_isolated``, or the ``catkin`` build tool. | ||
If everything succeeds, then your ``package.xml`` is valid. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters