Claude-skill-registry add-repository
Add a new Git repository to the message registry for automatic message type loading. Use when the user wants to support message types from a new ROS2 repository, or when adding support for a new message package.
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/add-repository" ~/.claude/skills/majiayu000-claude-skill-registry-add-repository && rm -rf "$T"
skills/data/add-repository/SKILL.md- makes HTTP requests (curl)
Add Repository
This skill guides you through adding a new Git repository to the
zenoh_ros2_sdk/_repositories.py file to enable automatic message type loading.
When to Use
- User wants to add support for message types from a new ROS2 repository
- User asks to support a specific repository (e.g., "support geometry2", "add tf2_msgs")
- Message types are not found because the repository isn't registered
- Adding support for new message packages
1. Discover Repository Structure
First, identify the repository URL and explore its structure to find message packages.
A. Get Repository URL
The user may provide:
- Full GitHub URL (e.g.,
)https://github.com/ros2/geometry2.git - Repository name (e.g.,
)geometry2 - Package name (e.g.,
)tf2_msgs
B. Explore Repository Contents
Use curl to check the repository structure:
# List all directories in the repository curl -s https://api.github.com/repos/ros2/geometry2/contents | \ python3 -c "import sys, json; data = json.load(sys.stdin); \ dirs = [item['name'] for item in data if item['type'] == 'dir']; \ print('\n'.join(sorted(dirs)))"
C. Find Message Packages
Check which directories contain message definitions:
# Check if a package has a msg directory curl -s https://api.github.com/repos/ros2/geometry2/contents/tf2_msgs | \ python3 -c "import sys, json; data = json.load(sys.stdin); \ print('\n'.join([item['name'] for item in data if item['type'] == 'dir']))"
D. List Available Messages
Check what messages are in a package:
# List .msg files in a package curl -s https://api.github.com/repos/ros2/geometry2/contents/tf2_msgs/msg | \ python3 -c "import sys, json; data = json.load(sys.stdin); \ msgs = [item['name'] for item in data if item['name'].endswith('.msg')]; \ print('\n'.join(sorted(msgs)))"
2. Determine Repository Structure
Identify the repository layout pattern:
Pattern A: Meta-Repository (Multiple Packages)
Structure:
<repo_root>/<package>/msg/<message>.msg
- Example:
,common_interfaces
,rcl_interfacesgeometry2 - Contains multiple packages in subdirectories
- Each package has its own
directorymsg/
Pattern B: Single Package Repository
Structure:
<repo_root>/msg/<message>.msg or <repo_root>/<package>/msg/<message>.msg
- Example:
example_interfaces - Single package, messages at repo root or in package subdirectory
3. Determine Commit/Tag
Choose an appropriate commit or tag:
- Recommended: Use stable ROS2 distribution tags (e.g.,
,jazzy
,iron
) for consistency with other repositorieshumble - Default: Use
to match existing repositories (jazzy
,rcl_interfaces
,common_interfaces
,example_interfaces
)geometry2 - Rolling: Use
branch only if you need latest development featuresrolling - Specific version: Use commit SHA or version tag for reproducibility
Check available tags:
curl -s https://api.github.com/repos/ros2/geometry2/tags | \ python3 -c "import sys, json; data = json.load(sys.stdin); \ print('\n'.join([tag['name'] for tag in data[:10]]))"
4. Add Repository Entry
Edit
zenoh_ros2_sdk/_repositories.py and add a new entry to MESSAGE_REPOSITORIES:
Template for Meta-Repository
# Repository name (descriptive, matches repo name) "repository_name": MessageRepository( url="https://github.com/ros2/repository_name.git", commit="jazzy", # Use jazzy for consistency with other repositories cache_path="repository_name", # Local cache directory name msg_path="", # Empty for standard structure: <package>/msg/<message>.msg packages=[ "package1", # List all message packages in this repository "package2", # ... more packages ], ),
Template for Single Package Repository
"package_name": MessageRepository( url="https://github.com/ros2/package_name.git", commit="jazzy", # Use jazzy for consistency, or specific tag/commit cache_path="package_name", msg_path="", # Adjust if messages are at repo root vs package subdirectory packages=[ "package_name", # Single package ], ),
Example: Adding geometry2
# Geometry2 (contains tf2_msgs and other TF2-related packages) # This repository contains TF2 transform message definitions # Reference: https://github.com/ros2/geometry2 "geometry2": MessageRepository( url="https://github.com/ros2/geometry2.git", commit="jazzy", # Use specific commit/tag for reproducibility cache_path="geometry2", msg_path="", # Messages are at <package>/msg/<message>.msg packages=[ "tf2_msgs", # Contains TFMessage, TF2Error messages ], ),
5. Verify Package Mapping
The
PACKAGE_TO_REPOSITORY mapping is automatically generated at the bottom of the file. Verify it includes your new packages:
# Mapping from message package namespace to repository name PACKAGE_TO_REPOSITORY: Dict[str, str] = {} for repo_name, repo in MESSAGE_REPOSITORIES.items(): for package in repo.packages: PACKAGE_TO_REPOSITORY[package] = repo_name
This ensures packages like
tf2_msgs map to geometry2 repository.
6. Check for Linting Errors
Run linting to ensure code quality:
# Check for linting errors # (The linter will automatically check when you edit the file)
7. Test Message Loading (Optional)
Verify the repository works by testing message loading:
from zenoh_ros2_sdk import load_message_type, get_message_class # Load a message type from the new repository load_message_type("tf2_msgs/msg/TFMessage") TFMessage = get_message_class("tf2_msgs/msg/TFMessage") if TFMessage: print("Successfully loaded message from new repository!")
Common Repositories
Already Supported
- Core ROS2 interfaces (builtin_interfaces, action_msgs, etc.)rcl_interfaces
- Standard messages (std_msgs, geometry_msgs, sensor_msgs, etc.)common_interfaces
- Example messages and servicesexample_interfaces
- TF2 messages (tf2_msgs)geometry2
Potential Additions
- Additional ROS2 interfacesros2_interfaces
- Default message definitionsrosidl_defaults- Custom repositories with message definitions
Notes
- Cache Location: Repositories are cached in
(or~/.cache/zenoh_ros2_sdk/
)$ZENOH_ROS2_SDK_CACHE - Automatic Download: Messages are downloaded automatically when first requested
- Dependencies: Message dependencies are resolved automatically
- Consistency: Use
as the default commit tag to match existing repositories for consistency and reproducibilityjazzy