Lines of Code Breakdown: A Compositional Analysis
Results of analyzing 10 million lines of code across the largest Open Source projects
Last updated November 20, 2024
There are a
lot
of
tools
that provide stats on lines of code (LoC). Conventional wisdom has long held that these metrics
are fraught, but absent hard data, it has only been possible to
gesture toward the disadvantages of relying on LoC,
without statistical proof.
GitClear has previously asserted that only 5% of lines of code
meaningfully evolve the repo's code base.
Because it is an extraordinary claim that 95% of LoC is noise, it is beholden upon us to substantiate this claim with data.
That is the purpose of this page.
The funnel below aggregates real world lines of code measurement
across 567,109 commits in
107 open source repos
between August 21, 2024 and November 20, 2024.
On desktop, hover on a funnel step to get more details about it.
First step: All changed code lines
36,638,334
changed lines of code factored into analysis
All changed code lines
The total lines of code in our most recent data set. This includes all lines that changed in any commit, so it is equivalent to the "Lines of Code" metric provided by GitHub or Pluralsight Flow.
Distinct commits
19,871,314 lines remain
Distinct: Ignore duplicated fragments
This step rinses all lines of code that occurred in a branch that is discarded, or code that is committed in multiple branches or repos.
Removes 16,767,020 lines
Effecting
15,883,578 lines remain
Effecting: Remove semantic lines
Changes that modify white space, blank lines, language keywords (e.g., begin, include), or types of lines that don't contain meaningful code content relative to the file type.
Removes 3,987,736 lines
Substantive
11,976,657 lines remain
Substantive: Negate batch operations
Diff Delta approximates cognitive load per commit. Operations like move, cut/paste and find/replace change many lines but do not represent high cognitive load, so are discarded by this step.
Removes 3,906,921 lines
Purposeful
1,592,670 lines remain
Purposeful: Rinse commit artifacts
To normalize away the difference between a developer who commits 100 times vs 1 time daily, we identify churned code, and we devalue large-scale additions (like new libraries).
Removes 10,383,987 lines
💎
Result
4.3% of total
1,593k final LoC
Important code line changes
Once you've cut through all the layers of noise that cloud lines of code, you find only a fraction of code evolving its repo in a purposeful, substantive way.
1,592,670
(4.3%)
impacting lines remain
How much noise does your analysis tool let through?
Since other git stat tools (including those that profess to offer "Engineering Insights") neglect to process
some or all of the steps above, the "insights" that they offer are as likely as not to be false positives or
commit artifacts.
If you would like to extract the fractional lines of code that correspond to meaningful work by developers,
consider signing up for a free GitClear trial, or a demo.