diff --git a/src/rosdistro/rosdistro.py b/src/rosdistro/rosdistro.py index 4033ac25b..1affddf23 100644 --- a/src/rosdistro/rosdistro.py +++ b/src/rosdistro/rosdistro.py @@ -197,6 +197,8 @@ def __init__(self, name, repository): def _fetch_package_xml(self, rosdistro): repo = self.repository + supported_non_githubs = [ 'gitlab', 'bitbucket' ] + if 'github.com' in repo.url: url = repo.url release_tag = 'release/{0}/{1}/{2}'.format(rosdistro, self.name, repo.version) @@ -222,7 +224,18 @@ def _fetch_package_xml(self, rosdistro): self._release_tags[rosdistro] = release_tag return package_xml, release_tag else: - raise Exception("Non-github repositories are net yet supported by the rosdistro tool") + release_tag = 'release/{0}/{1}/{2}'.format(rosdistro, self.name, repo.version) + url = repo.url + try: + # URL extension for GitLab/BitBucket repos + url = url.replace('.git', '/raw/{0}/package.xml'.format(release_tag)) + package_xml = urlopen(url).read() + self._package_xmls[rosdistro] = package_xml + self._release_tags[rosdistro] = release_tag + return package_xml, release_tag + except Exception as e: + msg = "Failed to read package.xml file from url '{0}': {1}".format(url, e)) + raise RuntimeError(msg) def get_package_xml(self, rosdistro): if rosdistro not in self._package_xmls: