reposcan is a simple command-line tool written in Go that scans your filesystem for Git repositories and reports their status.
It helps you quickly find:
- Repositories with uncommitted files
- Repositories with unpushed commits (ahead of upstream)
- Repositories with unpulled changes (behind upstream) (todo)
It outputs results in both human-friendly tables and machine-friendly JSON, so you can use it interactively or integrate with scripts and future UIs.
🖼 Example output
Repo Scan Report
Generated at: 2025-08-31T08:44:54+03:00
Total repositories: 3 | Dirty: 2
Repo Branch Not-Commited Ahead Path
──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
empty main 0 0 /home/me/projects/empty
habitsss master 1 1 /home/me/projects/habitsss
reposcan main 1 3 /home/me/projects/reposcan
Details:
Repo: habitsss
Path: /home/me/projects/habitsss
- internal/db/models.go
- README.md
Repo: reposcan
Path: /home/me/projects/reposcan
- api/handlers.go- Daily cleanup: See which projects have dirty working trees before switching tasks.
- Context switch: Know which repos still have unpushed commits before you leave for the day.
- Housekeeping: Find old repos you forgot to commit/push.
- Automation: Export JSON reports to integrate with dashboards or other tools.
go install github.com/you/reposcan/cmd/reposcan@latestMake sure $GOPATH/bin (or $HOME/go/bin) is in your $PATH.
git clone https://github.com/MABD-dev/reposcan.git
cd reposcan
go build -o reposcan ./cmd/reposcanScan your home directory
reposcan --root $HOMEMultiple roots
reposcan --root ~/Code --root ~/workFlags
--root PATH # add a directory to scan (repeatable)
--only TYPE # filter repos: all|dirty
--output TYPE # stdout, options=table|json|none
--json-output-path PATH # output scan report in json format to desired locationBy default, reposcan looks for a config file in:
~/.config/reposcan/config.tomlExample
version = 1
# directories to search for git repos inside
roots = ["~/Code", "~/work"]
# Skip these directories (glob patterns)
dirIgnore = [
"/node_modules/",
"/.cache/",
"/.local/"
]
# options:
# 1. `dirty`: git repos with un-commited changes or unpushed changes
# 2. `all`: all git repos
only = "dirty"
# print scan result to stdout. Options:
# 1. `json`: json object containing scan report struct
# 2. `table`: human readable representation of scan report
# 3. `non`: prints nothing
Output = "table"
# output scan reports to this folder. All nested folders will be created
# if they don't exist
JsonOutputPath = '/home/me/Documents/code/projects/Go/reposcan/output-samples'You can still override everything via CLI flags.
- check config in
~/.config/reposcan/config.toml - check cli flags and override those in step 1
- Scan filesystem for repos
- Detect uncommitted files
- Stdout Ouput in 3 formats: json, table, none
- Read user customizable
config.tomlfile - Support ahead of remote
- Export Report to json file
- Support behind remote
- Support dirignore
- Detect ahead/behind commits
- Worker pool for speed
- Support git worktrees
- Use cobra for better cli support
PRs, bug reports, and feature requests are welcome.