Before you start writing code in ROS, you need to create a workspace. A workspace is a set of directories (or folders) where you store related pieces of ROS code. The official name for workspaces in ROS is catkin workspaces. The word ‘catkin’ comes from the tail-shaped flower cluster found on willow trees (see photo below) — a reference to Willow Garage, the original developers of ROS.
data:image/s3,"s3://crabby-images/3fc12/3fc12ea4a34c5d9437aca9b9d5a459cf7be3fd7e" alt="willow_catkins_blossom_bloom"
All the ROS packages that you create need to reside inside a catkin workspace. The name of this catkin workspace is typically called catkin_ws.
The official instructions for creating a ROS workspace are at ROS.org, but I will walk you through the process below so you can see how it is done.
Directions
Open up a new terminal window (I’m assuming you are using ROS on Ubuntu Linux), and type the following commands to create and build at catkin workspace.
mkdir -p ~/catkin_ws/src
cd ~/catkin_ws/
catkin_make
data:image/s3,"s3://crabby-images/85ab7/85ab71f174795f29af3a32e4a80c4f91874fc92d" alt="1-catkin-workspace"
Type the dir command, and you will see three folders inside of this directory: build, devel, and src.
data:image/s3,"s3://crabby-images/e0157/e0157a2620afb073811e5b6715bff8e7d0eec5b6" alt="2-dir-command"
Now we need to source the setup.bash file. This file sets the path of the workspace so that packages and code inside the workspace can be found.
source devel/setup.bash
data:image/s3,"s3://crabby-images/fd593/fd5932dac1e44c494449d2f6cbe8210a9a3c05de" alt="3-set-path"
Make sure the workspace is properly overlayed by the setup script (which we ran above).
echo $ROS_PACKAGE_PATH
data:image/s3,"s3://crabby-images/640f6/640f640b3eb15ec372a3042b64a574c8db813d45" alt="4-make-sure"
So we don’t have to source the setup.bash file every time we open a new Linux terminal, let’s add the ~/catkin_ws/devel/setup.bash command to the .bashrc file. Open a new Linux terminal window.
Type the following command to edit the .bashrc text file:
gedit ~/.bashrc
Add this line to the end of the .bashrc file:
source ~/catkin_ws/devel/setup.bash
data:image/s3,"s3://crabby-images/09e51/09e5178444ea30c6230104f0085ef7d4379c9007" alt="5-edit-bashrc-file"
That’s it! You’re all done. Just click Save and exit the text editor.