Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/asottile/git-code-debt
A dashboard for monitoring code debt in a git repository.
https://github.com/asottile/git-code-debt
git technical-debt
Last synced: 6 days ago
JSON representation
A dashboard for monitoring code debt in a git repository.
- Host: GitHub
- URL: https://github.com/asottile/git-code-debt
- Owner: asottile
- License: mit
- Created: 2013-11-14T16:05:41.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2025-01-08T01:20:46.000Z (15 days ago)
- Last Synced: 2025-01-10T05:06:46.951Z (13 days ago)
- Topics: git, technical-debt
- Language: Python
- Size: 839 KB
- Stars: 586
- Watchers: 21
- Forks: 35
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![build status](https://github.com/asottile/git-code-debt/actions/workflows/main.yml/badge.svg)](https://github.com/asottile/git-code-debt/actions/workflows/main.yml)
[![pre-commit.ci status](https://results.pre-commit.ci/badge/github/asottile/git-code-debt/main.svg)](https://results.pre-commit.ci/latest/github/asottile/git-code-debt/main)git-code-debt
=============A dashboard for monitoring code debt in a git repository.
## Installation
```bash
pip install git-code-debt
```## Usage
### Basic / tl;dr Usage
#### make a `generate_config.yaml`
```yaml
# required: repository to clone (can be anything `git clone` understands) even
# a repository already on disk
repo: [email protected]:asottile/git-code-debt# required: database generation path
database: database.db# optional: default False
skip_default_metrics: false# optional: default []
metric_package_names: []# optional: default ^$ (python regex) to exclude paths such as '^vendor/'
exclude: ^$
```#### invoke the cli
```
# Generate code metric data (substitute your own repo path)
$ git-code-debt-generate
# Start the server
$ git-code-debt-server database.db
```### Updating data on an existing database
Adding data to the database is as simple as running generate again.
`git-code-debt` will pick up in the git history from where data was generated
previously.```
$ git-code-debt-generate
```### Creating your own metrics
1. Create a python project which adds `git-code-debt` as a dependency.
2. Create a package where you'll write your metrics
3. Add your package to `metric_package_names` in your `generate_config.yaml`The simplest way to write your own custom metrics is to extend
`git_code_debt.metrics.base.SimpleLineCounterBase`.Here's what the base class looks like
```python
class SimpleLineCounterBase(DiffParserBase):
# ...def should_include_file(self, file_diff_stat: FileDiffStat) -> bool:
"""Implement me to return whether a filename should be included.
By default, this returns True.:param FileDiffStat file_diff_stat:
"""
return Truedef line_matches_metric(self, line: bytes, file_diff_stat: FileDiffStat) -> bool:
"""Implement me to return whether a line matches the metric.:param bytes line: Line in the file
:param FileDiffStat file_diff_stat:
"""
raise NotImplementedError
```Here's an example metric
```python
from git_code_debt.metrics.base import SimpleLineCounterBaseclass Python__init__LineCount(SimpleLineCounterBase):
"""Counts the number of lines in __init__.py"""def should_include_file(self, file_diff_stat: FileDiffStat) -> bool:
return file_diff_stat.filename == b'__init__.py'def line_matches_metric(self, line: bytes, file_diff_stat -> FileDiffStat) -> bool:
# All lines in __init__.py match
return True
```An additional class is provided which feeds lines as text
(`SimpleLineCounterBase` presents them as `bytes`): `TextLineCounterBase`.
Here is an example metric using that base class:```python
from git_code_debt.metrics.base import TextLineCounterBaseclass XXXLineCount(TextLineCounterBase):
"""Counts the number of lines which are XXX comments"""def text_line_matches_metric(self, line: str, file_diff_stat: FileDiffStat) -> bool:
return '# XXX' in line
```More complex metrics can extend `DiffParserBase`
```python
class DiffParserBase(object):
# Specify __metric__ = False to not be included (useful for base classes)
__metric__ = Falsedef get_metrics_from_stat(self, commit: Commit, file_diff_stats: Tuple[FileDiffStat, ...]) -> bool:
"""Implement me to yield Metric objects from the input list of
FileStat objects.Args:
commit - Commit object
file_diff_stats - list of FileDiffStat objectsReturns:
generator of Metric objects
"""
raise NotImplementedErrordef get_metrics_info(self) -> List[MetricInfo]:
"""Implement me to yield `MetricInfo` objects."""
raise NotImplementedError
```## Some screenshots
### Index
![Example screen index](https://raw.githubusercontent.com/asottile/git-code-debt/main/img/debt_screen_1.png)### Graph
![Example screen graph](https://raw.githubusercontent.com/asottile/git-code-debt/main/img/debt_screen_2.png)