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)
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.
🖼 Demo
Screen.Recording.2025-11-06.at.12.34.12.PM.online-video-cutter.com.mp4
- 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/mabd-dev/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 -r $HOMEMultiple roots
reposcan -r ~/Code -r ~/workCommon flags
-d, --dirIgnore stringArray # (default [$HOME])
-f, --filter string # Repository filter: all|dirty|uncommitted|unpushed|unpulled (default "dirty")
-h, --help # help for reposcan
--json-output-path string # Write scan report JSON files to this directory (optional)
-w, --max-workers int # Number of concurrent git checks (default 8)
-o, --output string # Output format: json|table|interactive|none (default "table")
-r, --root stringArray # Root directory to scan (repeatable). Defaults to $HOME if unset in config. (default [$HOME])
, --debug # Enable/Disable debug modeHelp
reposcan --helpMore details on flags and config mapping can be found in docs/cli-flags.md.
By default, reposcan looks for a config file in:
~/.config/reposcan/config.tomlExample
version = 1
debug = false
# directories to search for git repos inside
roots = ["~/Code", "~/work"]
only = "dirty"
# Skip these directories (glob patterns)
dirIgnore = [
"/node_modules/",
"/.cache/",
"/.local/"
]
[output]
type = "interactive"
jsonPath = "/somewhere/nice"
You can still override everything via CLI flags.
check sample/config.toml for detailed configuration with examples
- Load default values
- Config in
~/.config/reposcan/config.toml(if exists) - Cli flags (if exists) Each step overrides the one before it
- Scan filesystem for repos
- Detect uncommitted files, unpushed commits and unpulled commits
- Stdout Ouput in 3 formats: json, table, interactive, none
- Read user customizable
config.tomlfile - Export Report to json file
- Support dirignore
- Worker pool for speed
- Support git worktrees
- Perform git push/pull/fetch on repos
- Show branches with their states on each repo
PRs, bug reports, and feature requests are welcome.