Warning
You're reading the documentation for a version of ROS 2 that has reached its EOL (end-of-life), and is no longer officially supported. If you want up-to-date information, please have a look at Jazzy.
Building ROS 2 on Linux with Eclipse Oxygen [community-contributed]
Warning
Some people have reported issues about this tutorial. If the steps work for you please leave a comment on https://github.com/ros2/ros2/issues/495 . If they don’t then please comment with the first step that didn’t work.
This tutorial is based on a clean ubuntu-16.04.2 install and eclipse oxygen with egit. It uses RTI Connext as middleware for Realtime performance. The original Install page is perhaps more up-to-date, so check it for info.
Install:
sudo sh -c 'echo "deb http://packages.ros.org/ros/ubuntu `lsb_release -cs` main" > /etc/apt/sources.list.d/dashing.list'
sudo apt-key adv --keyserver ha.pool.sks-keyservers.net --recv-keys 421C365BD9FF1F717815A3895523BAEEB01FA116
sudo apt update
sudo apt install git wget build-essential cppcheck cmake libopencv-dev python-empy python3-dev python3-empy python3-nose python3-pip python3-pyparsing python3-setuptools python3-vcstool python3-yaml libtinyxml-dev libeigen3-dev clang-format pydocstyle pyflakes python3-coverage python3-mock python3-pep8 uncrustify libasio-dev libtinyxml2-dev libcurl4-openssl-dev libqt5core5a libqt5gui5 libqt5opengl5 libqt5widgets5 libxaw7-dev libgles2-mesa-dev libglu1-mesa-dev qtbase5-dev
Then install
sudo pip3 install argcomplete flake8 flake8-blind-except flake8-builtins flake8-class-newline flake8-comprehensions flake8-deprecated flake8-docstrings flake8-import-order flake8-quotes pytest pytest-cov pytest-runner
Create a eclipse workspace named ros2_ws. (The name is not needed to be ros2_ws)
data:image/s3,"s3://crabby-images/b811d/b811d0b765b2ca4cc6f267d96bd081cdafc2413b" alt="eclipse-1"
Inside this eclipse-workspace we create a C++ Project. With this option we have a indexer for code-completion.
data:image/s3,"s3://crabby-images/110e3/110e32ade5a42da11ece5b0218120546d34b9b7f" alt="eclipse-1"
We name the project ros2_ws
data:image/s3,"s3://crabby-images/f95b3/f95b346ce11c8d0f3f2ac3737b939d739e259c1e" alt="eclipse-1"
We see our project and some includes. These includes dont reside in our workspace, so dont remove, they are for the indexer.
data:image/s3,"s3://crabby-images/99a16/99a1662e439bbac807249a17898d486da68e520d" alt="eclipse-1"
We create a folder inside our project, named “src”
data:image/s3,"s3://crabby-images/dd3ca/dd3cac45b8e5604cece720c2cafe5e725bd6cf8b" alt="eclipse-1"
We see the folder in our project. This folder also exist in our workspace. After that we go to a console and switch to directory /home/ros/ros2_ws/ros2_ws there we enter
wget https://raw.githubusercontent.com/ros2/ros2/dashing/ros2.repos
vcs-import src < ros2.repos
add export RTI_LICENSE_FILE=/home/ros/rti_connext_dds-5.3.1/rti_license.dat to .bashrc and source it.
data:image/s3,"s3://crabby-images/5a246/5a246740fb8b9deb99d18fcdbbef31f585e1c396" alt="eclipse-1"
We now need a RTI license, which we get on their website. Refer to Linux Development Setup page. The RTI license file will be directly send per email after sign-up.
In the email is a link to the RTI software to download. We run the .run file after chmod +x
data:image/s3,"s3://crabby-images/3b720/3b720e65bdb08861dc1fce087d6c99fa856006ae" alt="eclipse-1"
data:image/s3,"s3://crabby-images/4c699/4c699b3929e7460f1317bea975fb989299805334" alt="eclipse-1"
We choose our home directory to install
data:image/s3,"s3://crabby-images/cc250/cc250847f016854b43a26d72b64a918fcc92b1e4" alt="eclipse-1"
data:image/s3,"s3://crabby-images/d9e0d/d9e0d650f14fe3ff3c64ee1ae85c6743c78fe5ce" alt="eclipse-1"
data:image/s3,"s3://crabby-images/9d24e/9d24e16b6d9a543f3af79db6e361bb92d4400de8" alt="eclipse-1"
In the Launcher which started, we select our RTI license file and copy it global
data:image/s3,"s3://crabby-images/54f4a/54f4aa20278b98b60be78d4f9a8fabc26a16e537" alt="eclipse-1"
select in the down-left side the install-button
data:image/s3,"s3://crabby-images/b1c62/b1c62afce0dea1ec28f6b713a2f8573e99f4c4e1" alt="eclipse-1"
install the security package from RTI software
data:image/s3,"s3://crabby-images/23dd9/23dd9f3e821978406ba45adbeb180174ae4d0d47" alt="eclipse-1"
and the openssl package
data:image/s3,"s3://crabby-images/5941b/5941b855c2fd1a8691dd83a58b92c1f7359794c2" alt="eclipse-1"
Unpack the openssl-1.0.2n package and copy it to the RTI install directory. source /home/ros/rti_connext_dds-5.3.1/resource/scripts/rtisetenv_x64Linux3gcc5.4.0.bash on a console and export RMW_IMPLEMENTATION=rmw_connext_cpp.
Close eclipse-IDE and open it from the shell we sourced all the scripts from above.We now open in Eclipse the Project->Preferences and go to Environment.
data:image/s3,"s3://crabby-images/3aa77/3aa776dfe11e6ec2af45183092b5ccba6903e101" alt="eclipse-1"
We enter environment variables. We can get the vars simply by opening a bash console, then we run “env > /tmp/out”, then source the ROS 2 local_setup.bash, then “env > /tmp/out1” and “diff /tmp/out /tmp/out1”. The output that diff is showing, is what we enter in eclipse environment vars, so that eclipse knows about e.g. the new PATH var.
data:image/s3,"s3://crabby-images/26a43/26a4342f93416d0bf79f42bb97fbe23edf5c2a7a" alt="eclipse-1"
data:image/s3,"s3://crabby-images/2849c/2849c745cbc4373c66f430742aaebf8192e77e68" alt="eclipse-1"
Then we go to Builders and click the “New” button.
data:image/s3,"s3://crabby-images/1e2fc/1e2fcc7f40003db857ddc7944ff0b04e40481ed2" alt="eclipse-1"
We enter the amen.py settings
data:image/s3,"s3://crabby-images/a620a/a620aa8e73eee5e7ea5251292996a6bc45104ef4" alt="eclipse-1"
After that we unselect CDT-Builder
data:image/s3,"s3://crabby-images/d8235/d823578b96e995eddf1a81c921180d0c3ab0d138" alt="eclipse-1"
Then we go to C++ Build and delete the build command make, because we use ament.py (Dont know really if this is needed as we disabled CDT-Builder before?)
data:image/s3,"s3://crabby-images/af55c/af55c2eb78bda4b3785a804f012a2bd4700b9876" alt="eclipse-1"
We now can right-click and run “Build Project”.
HINT if it happens: error: NDDSHOME set to but could neither find all optimized libraries nor all debug libraries I deleted dir /home/ros/rti_connext_dds-5.3.1/lib/x64Linux3gcc5.4.0/5.3.1/5.3.1 with doubled libs
data:image/s3,"s3://crabby-images/213ff/213ff6404175f25143bf566cba0bef3287eed9c0" alt="eclipse-1"
We can then open two console, source ros2_ws/install/local_setup.bash in both consoles and run talker and listener
data:image/s3,"s3://crabby-images/99bdd/99bdd35256da229387ce495fe25d034182602d47" alt="eclipse-1"
We see our Project in eclipse, go to git-repositories-view and import local repo
data:image/s3,"s3://crabby-images/9210f/9210f820f9dae8f5e9cca557f5b64e1037360b4d" alt="eclipse-1"
We select our directory and select the repository we are interresting in seeing e.g. git-infos like author of code-line, or switching to other branches, etc.
data:image/s3,"s3://crabby-images/b14fc/b14fc325faad31fa7282cf8d17ceec021fd4757a" alt="eclipse-1"
After adding the git-repo to the git-repository-view, we can right-click on it and select “Import projects”
data:image/s3,"s3://crabby-images/ac975/ac97506e4bc13153e51d8902e5795052544dcc7c" alt="eclipse-1"
The import source is the directory of our project
data:image/s3,"s3://crabby-images/5fc42/5fc42422def805af71c96591fb09dd1788f669e3" alt="eclipse-1"
We see in the down-left side in the project-explorer view, that this project is beside our ros2_ws project. But they both use the same files.But one is linked with Egit and can show git-annotations, etc. the other not. So open files from the project which is linked to Egit.
data:image/s3,"s3://crabby-images/c2a5a/c2a5a05c4312deef93a30135b03108a122f702fc" alt="eclipse-1"
File linked with Egit. Right-click beside the line-number in the editor and choose “Show Revision information” from the pop-up dialog, then you could see e.g. the author, and other stuff like commit message if you hover over it with the mouse.
data:image/s3,"s3://crabby-images/28367/2836775f5a379a638525a1fce9b9d63428036ec2" alt="eclipse-1"