Our rover codebase depends on many third-party libraries (mostly for
sensor drivers) that would normally have to be compiled and installed
from source; this repository allows Ubuntu users to install these
libraries via the system's apt
package manager.
- Install cURL and
wget
, used to download files:
sudo apt install curl wget
- Add the public key used to verify the packages' signatures:
curl -s --compressed "https://huskyroboticsteam.github.io/ubuntu-repo/KEY.gpg" | sudo apt-key add -
- Add the repository to your system's list of software sources:
sudo wget -P /etc/apt/sources.list.d "https://huskyroboticsteam.github.io/ubuntu-repo/husky_robotics.list"
- Update the package catalog:
sudo apt update
- Done! You should now be able to install packages from the
repository with
sudo apt install <package>
.
If at some point in the future you decide you no longer want to get
packages from this repository, you can simply delete the
/etc/apt/sources.list.d/husky_robotics.list
file (or rename it to
something that does not end in .list
).
These instructions will indicate how to create new builds if dependencies have changed.
If you haven't already, add the HRT gpg key to your keyring. First, download the gpg key from the leadership drive, located at /Software/uwrobots-pkg-key.gpg
. Then, import it.
gpg --import <path to key>
It will prompt you for a password, which you can find in the "Accounts & Passwords" spreadsheet in the leadership drive, under the name "Software GPG Key".
You will need to cross-compile packages, since we have both x86_64 and ARM systems. If your machine is x86_64, then install the ARM toolchains:
sudo apt-get install gcc-aarch64-linux-gnu
If your system is ARM, then you might be screwed, since I'm not sure if the scripts support it. There's probably some way to do it though!
If you need to build a specific version (indicated by a tag in the dependency repo) then edit scripts/build-packages.sh
and set the second command of BUILD
(in the if-else tree) to the required tag. If there is no second argument, it will build the default branch.
If you want to rebuild all packages:
./scripts/build-packages.sh
If you want to build a specific package:
./scripts/build-packages.sh <package name> # look inside the script to see package names
To cross-compile for ARM, prepend BUILD_ARM="true"
to the command, i.e.:
BUILD_ARM="true" ./scripts/build-packages.sh hindsightcan
You may have to re-enter the password while building.
Now commit and push, and the dependencies should be updated! Note that all dev machines will need to update their version of these dependencies.