I wrote the answer to #q264600, but I don't believe things have changed with ROS 2.
it looks like the foxy build/install in ~/ros2_foxy would be our workspace.
this sounds like you are planning to build Foxy itself from source, as well as your own packages.
Is it typical to consider a robots custom packages/applications etc as an overlay?
Technically, all workspaces are overlays, unless they contain the "base ROS packages" I would say (ie: form the base layer) and bootstrap your ROS install.
Eg. would/should we track our overlay in git?
You'd track individual packages (or coherent sets of those), never entire workspaces/overlays.
Edit:
What would we track in git in that case?
As always: packages. You always only place packages in a VCS. And with packages I mean: the source code. So not the binary artefacts (ie: no .zip
s, nor .deb
s or other form of packages which are the result of a build process).
Or sets of packages for which it makes sense to version them together in a single repository.
A .repo file like the ros2.repo but with our packages and put all of that inside of a directory as recommended for an overlay?
This sounds like a different issue: whether you store source artefacts in a VCS and how, does not immediately affect how you would then use that VCS to seed your workspace.
A .repos
file is only really just input to a tool like vcs
which you use to help you seed your workspace. It does not immediately have any implications on how you then store your packages in a VCS.
I'm new to Ros to apologizes for lack of proper terminology
The terminology is fine. In the end there is nothing really ROS-specific here I believe.
How do you normally version your C++ libraries or applications or Python packages or applications? To me, it makes a lot of sense to not lump everything together in a single, big repository, but to separate libraries from applications (fi) and to not put things together when they don't need to be stored together.
It's exactly the same here. It's just that we call things ROS packages. But in the end it's all just a bunch of files that happen to "belong with each other" for whatever reason.
An example on github would be great but I'm not sure what to look for even or if those would match what you as experts would recommend.
Well, could you clarify what you exactly would like to see an example of? I'd say any of the repositories in the github/ros2 organisation would be examples. They are laid out in exactly the way I described above:
- only contain source artefacts
- (try to) only put packages together which belong together
- applications are typically separate from libraries
- some repositories contain only
.repos
files which are consumed by tools like vcs
and used to seed workspaces ...
(more)