Go to file
Shik Chen 9bf8236c24 logging: Fix log formatting with colored output
The log message is already formatted before being passed to the colorer.
To avoid the exception "TypeError: not enough arguments for format
string", we should use the `nofmt_colorer` instead.

This bug occurs only when the formatted string still contains '%'
character. The following snippet can reproduce the bug:

```
from repo_logging import RepoLogger
RepoLogger(__name__).error("%s", "100% failed")
```

Change-Id: I4e3977b3d21aec4e0deb95fc1c6dd1e59272d695
Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/432017
Tested-by: Shik Chen <shik@google.com>
Commit-Queue: Shik Chen <shik@google.com>
Reviewed-by: Mike Frysinger <vapier@google.com>
2024-07-02 06:24:31 +00:00
.github/workflows tests: added python 3.12 2023-10-17 13:58:33 +00:00
docs git: raise soft version to 2.7.4 2024-03-20 21:11:26 +00:00
hooks release: update-hooks: helper for automatically syncing hooks 2024-04-23 18:31:51 +00:00
man upload: add a --topic option for setting topic explicitly 2024-07-01 17:54:19 +00:00
release release: update-hooks: helper for automatically syncing hooks 2024-04-23 18:31:51 +00:00
subcmds upload: add a --topic option for setting topic explicitly 2024-07-01 17:54:19 +00:00
tests logging: Fix log formatting with colored output 2024-07-02 06:24:31 +00:00
.flake8 flake8: exclude venv and .tox folder 2023-08-15 15:46:52 +00:00
.gitattributes Adds additional crlf clobber avoidance. 2016-06-22 08:36:45 +00:00
.gitignore Add parallelism to 'branches' command 2020-12-14 23:35:12 +00:00
.gitreview git-review: add config file 2021-11-15 01:39:36 +00:00
.isort.cfg isort: format codebase 2023-08-22 18:32:22 +00:00
.mailmap Update .mailmap 2020-02-13 04:49:55 +00:00
.project Set correct name in PyDev and Eclipse project config 2013-04-19 09:35:43 +09:00
.pydevproject Leverage the next keyword from python 2.7 2018-12-19 11:06:35 -08:00
color.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
command.py cleanup: use new dict & set generator styles 2023-10-21 00:55:01 +00:00
completion.bash bash-completion: complete projects with repo forall 2021-07-27 06:20:52 +00:00
editor.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
error.py gitc: drop support 2023-08-15 22:14:52 +00:00
event_log.py delete Python 2 (object) compat 2023-10-20 04:51:01 +00:00
fetch.py isort: format codebase 2023-08-22 18:32:22 +00:00
git_command.py git_command: unify soft/hard versions with requirements.json 2024-03-21 21:20:50 +00:00
git_config.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
git_refs.py cleanup: convert exceptions to OSError 2023-10-21 00:56:10 +00:00
git_ssh add license header to a few more files 2019-06-13 13:23:19 -04:00
git_superproject.py git_superproject: tell git that superproject is bare 2023-11-09 22:13:17 +00:00
git_trace2_event_log_base.py git_trace2: Add socket timeout 2023-12-19 19:38:52 +00:00
git_trace2_event_log.py Log ErrorEvent for failing GitCommands 2023-09-06 18:22:33 +00:00
hooks.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
LICENSE setup.py: add basic packaging files 2019-12-02 04:23:31 +00:00
main.py main: Stringify project name in error_info 2024-03-15 19:26:10 +00:00
manifest_xml.py gitc: delete a few more dead references 2024-04-18 02:30:06 +00:00
MANIFEST.in setup.py: add basic packaging files 2019-12-02 04:23:31 +00:00
pager.py isort: format codebase 2023-08-22 18:32:22 +00:00
platform_utils_win32.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
platform_utils.py Remove platform_utils.realpath 2024-03-27 17:13:58 +00:00
progress.py cleanup: Update codebase to expect Python 3.6 2023-10-31 16:03:54 +00:00
project.py upload: add a --topic option for setting topic explicitly 2024-07-01 17:54:19 +00:00
pyproject.toml tests: added python 3.12 2023-10-17 13:58:33 +00:00
README.md update links from monorail to issuetracker 2023-06-14 21:19:58 +00:00
repo git_command: unify soft/hard versions with requirements.json 2024-03-21 21:20:50 +00:00
repo_logging.py logging: Fix log formatting with colored output 2024-07-02 06:24:31 +00:00
repo_trace.py cleanup: delete redundant "r" open mode 2023-10-21 00:55:33 +00:00
requirements.json git: raise hard version to 1.9.1 2024-05-01 15:23:50 +00:00
run_tests release: update-hooks: helper for automatically syncing hooks 2024-04-23 18:31:51 +00:00
run_tests.vpython3 isort: format codebase 2023-08-22 18:32:22 +00:00
setup.py isort: format codebase 2023-08-22 18:32:22 +00:00
ssh.py ssh: Set git protocol version 2 on SSH ControlMaster 2024-05-16 13:26:46 +00:00
SUBMITTING_PATCHES.md SUBMITTING_PATCHES: update with commit queue details 2023-05-11 19:27:57 +00:00
tox.ini tox: Remove pylint timeout 2023-12-08 22:55:22 +00:00
wrapper.py git_command: unify soft/hard versions with requirements.json 2024-03-21 21:20:50 +00:00

repo

Repo is a tool built on top of Git. Repo helps manage many Git repositories, does the uploads to revision control systems, and automates parts of the development workflow. Repo is not meant to replace Git, only to make it easier to work with Git. The repo command is an executable Python script that you can put anywhere in your path.

Contact

Please use the repo-discuss mailing list or issue tracker for questions.

You can file a new bug report under the "repo" component.

Please do not e-mail individual developers for support. They do not have the bandwidth for it, and often times questions have already been asked on repo-discuss or bugs posted to the issue tracker. So please search those sites first.

Install

Many distros include repo, so you might be able to install from there.

# Debian/Ubuntu.
$ sudo apt-get install repo

# Gentoo.
$ sudo emerge dev-vcs/repo

You can install it manually as well as it's a single script.

$ mkdir -p ~/.bin
$ PATH="${HOME}/.bin:${PATH}"
$ curl https://storage.googleapis.com/git-repo-downloads/repo > ~/.bin/repo
$ chmod a+rx ~/.bin/repo