01 · Roasts
The Graveyard Curator
363 public repos and a staleRepoRatio of 0.76 — 76% of your repos haven't been touched in 2+ years. That's not a portfolio, that's a digital fossil record.
Test-Averse Embedded Architect
easy-build has 169 stars and Dockerfiles for AOSP/Yocto/OpenWrt but zero tests and zero CI. You're trusting Docker pulls from strangers without a single automated check. Bold choice.
The Language Mirage
C (42%) + C++ (41%) = 83% of your codebase. Having C# and Java sprinkled in doesn't make you multilingual — it makes you a C developer with occasional tourism.
509 Commits, 363 Repos
That's an average of 1.4 commits per repo per year. You're spreading commits thinner than butter on a baguette at a Parisian diet clinic.
16-Year Blog, Still No Tests
gmacario.github.io was created in 2009 and last pushed in 2026 — a 16-year project — and HAS_TESTS is still 'no'. At some point 'I'll add tests later' becomes a lifestyle.
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% weight60C
- Consistency20% weight60C
- Quality20% weight58D
- Depth15% weight55D
- Breadth10% weight65C
- Community10% weight65C
03 · Stats
365-day commit heatmap
267 active days
Language distribution
- C42%
- C++41%
- C#6%
- Java5%
- Jupyter Notebook2%
- Shell1%
- Other3%
04 · Numbers
Owned repos
non-fork
17
Commits
last 12 months
509
Followers
199
Joined GitHub
Apr 2009
05 · Top repos
gmacario /
easy-build
Actively maintained Docker collection (169 stars, 9yr history) for embedded build environments (AOSP, Yocto, OpenWrt). Well-documented with README and CONTRIBUTING.md, multiple Dockerfiles with structured layout, but no tests/CI limits quality ceiling despite strong foundation.
gmacario /
gmacario.github.io
Personal blog built with Next.js, TypeScript-free, featuring CI/CD pipelines and Docker support. Well-documented and structured, but minimal adoption (4 stars) and thin audience reach limits impact.
gmacario /
learning-python
Learning collection of Python scripts and Jupyter notebooks demonstrating tutorials and experiments. Minimal README, untyped code with mixed maturity, no tests/CI. 6 years of sporadic commits on personal education project.
06 · Timeline
- Apr 18, 2009Joined GitHub
- Apr 25, 2009Created gmacario.github.io — Gianpaolo Macario public website on GitHub.com
- Mar 29, 2014Created easy-build — Collection of Dockerfiles for building embedded software distributions
- Oct 20, 2017Created learning-python
- Feb 7, 2026Most recent push to gmacario.github.io
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.