def watch(build_queue): while True: debug.set_prefix("repository_watcher") debug.message("Retrieving projects") try: projects = Api.get_projects() for project in projects: debug.message("Check repository status for project %s" % project["Name"]) repository = Git(get_path(project), get_origin_url(project)) commit_count = handle_incoming_commits(repository.check_for_new_commits_on_origin(), project, repository, build_queue) if commit_count > 0: repository.merge_origin() # Add <initial_nr_commits> commits if this is a new repository if project["Commits"] is None or len(project["Commits"]) == 0: handle_incoming_commits( repository.get_commits(registry.config["repositories"]["initial_nr_commits"]), project, repository, build_queue) except ValueError, e: debug.exception("Error retrieving projects", e) except GitError, e: debug.exception("Error with Git repository", e)