01 · Roasts
Mirror, Mirror on the Wall
tango — your most-starred repo at 823 ⭐ — is literally flagged as a mirror that 'moved to gitea.com/lunny/tango'. Your most impressive GitHub trophy is a redirect sign.
The 367 PRs You're Hiding
You opened 367 PRs this year but your public repos only show 286 commits. Either you're speed-running someone else's codebase or you've forgotten your own repos exist.
70% Graveyard
staleRepoRatio = 0.70 — seven out of every ten repos you own haven't been touched in over 2 years. That's not a portfolio, that's a digital museum of abandoned Go experiments.
README: '1', '111', '333'
test-pr-force-push has a README with literally the content '1', '111', '333'. Lunny, you have 1143 followers watching this.
87% Go or Die
87% Go, 7% Python, 5% MDX — you've been writing Go so long you probably dream in goroutines. Diversity is a word you've heard of but apparently never needed.
Built using
Zoral
Shadows one worker for a week, then takes over their job with zero extra setup. Behaves exactly like the original.
zoral.ai
02 · Category breakdown
- Impact25% weight61C
- Consistency20% weight50D
- Quality20% weight67C
- Depth15% weight50D
- Breadth10% weight40D
- Community10% weight65C
03 · Stats
365-day commit heatmap
340 active days
Language distribution
- Go87%
- Python7%
- MDX5%
- Makefile1%
- Perl0%
- Shell0%
04 · Numbers
Owned repos
non-fork
44
Commits
last 12 months
286
Followers
1,143
Joined GitHub
May 2009
05 · Top repos
lunny /
tango
Go web framework with 823 stars, comprehensive middleware ecosystem, complete test coverage, and CI/CD. However, marked as mirror and moved to gitea.com/lunny/tango; last push May 2019 suggests limited active maintenance.
lunny /
nodb
NoDB is a pure-Go NoSQL library forking LedisDB, supporting KV/List/Hash/ZSet/Set/Bitmap with LevelDB backend. Typed Go + tests + README, but lightweight docs and stale (last push 2018). Appropriate for embedded projects.
lunny /
test-pr-force-push
Minimal experimental repo with near-empty content (2 KB), placeholder README, and sparse commit history (3 of last 30). No tests, CI, license, or meaningful code artifacts.
06 · Timeline
- May 5, 2009Joined GitHub
- Sep 17, 2014Created nodb — Moved https://gitea.com/lunny/nodb
- Dec 17, 2014Created tango — This is only a mirror and Moved to https://gitea.com/lunny/tango
- Jan 27, 2026Created test-pr-force-push
- Feb 17, 2026Most recent push to test-pr-force-push
07 · Compare
08 · Rubric
How this score was produced
Overall = Σ (category × weight) + gentle top-end curve
Tier thresholds
▸ How the pipeline works
- 01Scrape.Pull every non-fork repo pushed in the last 90 days, plus your contribution calendar, followers, and language byte counts — straight from GitHub's REST & GraphQL APIs.
- 02Triage.A small model reads every repo's file tree + README and picks the 20 files per repo that actually reveal how you code.
- 03Grade each repo. All repos run in parallel through a fast scoring model that reads the picked files and rates each one independently on Impact, Quality, and Depth — with evidence citations.
- 04Aggregate. A larger reasoning model combines the per-repo scores with server-computed stats (heatmap, commit cadence, language entropy, follower count) to produce the 6-dimension profile score + roasts.
- 05Correct.Deterministic server-side checks enforce anchor-scale floors (e.g. a profile with 2,000+ public commits can't score 30 Consistency) and recompute the final verdict.
~90 seconds per profile, ~$0.25 in compute. Total of ~240 files read across your top-12 repos. One rating per GitHub account per day.
▸ Data sources & caveats
- Heatmap & commit totals: GitHub GraphQL
contributionsCollection— covers the last 365 days, includes private repos when the user has opted in (default). - Language %: byte totals across the top 30 owned non-fork repos.
- Curve: a small upward nudge centered on raw score ≈ 70, capping at 100. Prevents specialists from being unfairly penalised for narrow breadth.
- Anchor corrections: when server-measured signals (e.g. privateWorkLikely, multiRepoVolume, follower count) mandate a minimum category score, the aggregation step enforces it. These are signal-conditional, not identity-based floors.