Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/michalspano/clocrt
clocrt - transform cloc output into a Markdown table
https://github.com/michalspano/clocrt
cli cloc go unix
Last synced: about 2 months ago
JSON representation
clocrt - transform cloc output into a Markdown table
- Host: GitHub
- URL: https://github.com/michalspano/clocrt
- Owner: michalspano
- License: mit
- Created: 2022-07-30T21:42:14.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-08-09T21:37:03.000Z (over 2 years ago)
- Last Synced: 2024-06-21T03:22:38.411Z (7 months ago)
- Topics: cli, cloc, go, unix
- Language: Go
- Homepage:
- Size: 5.43 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# `clocrt` - Count Lines of Code _Redefined Tables_
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
[![Contributors][contributors-shield]][contributors-url]
[![Release][release-shield]][release-url]
[![MIT License][license-shield]][license-url]## Table of Contents
* [Introduction](#introduction)
* [Requirements](#requirements)
* [Additional](#additional)
* [Installation](#installation)
* [Build from the source](#build-from-the-source)
* [Example](#example)
* [Usage](#usage)
* [`cloc` docs](#cloc-docs)
* [Contributing](#contributing)## Introduction
A simple, lightweight __CLI__ tool to transform a `cloc` output into a `Markdown` table written in `Go`.
## Requirements
1. A `unix`-like operating system (with either `bash` or `sh`, etc.);
2. The [`cloc`](https://github.com/AlDanial/cloc) command-line utility;
3. The [`wget`](https://savannah.gnu.org/git/?group=wget) command-line utility.\*The `wget` command-line utility is used to download the `clocrt` binary. Indeed, `clocrt` is not a fork of `cloc`, and therefore, `cloc` is a direct dependency of `clocrt`.
### Additional
A copy of the `Go` binary is needed to install the `clocrt` binary from the source. The `Go` binary is available [here](https://golang.org/dl/).
## Installation
The __automated installation__ is carried with a single command:
```sh
$ curl -s https://raw.githubusercontent.com/michalspano/clocrt/main/install | sh
```#### Build from the source
```sh
$ git clone https://github.com/michalspano/clocrt.git && cd clocrt
$ go build -o clocrt src/main.go
$ ./clocrt --version # validates the installation
```## Example
Suppose the following __working tree__ with some _dummy_ files:
```text
$ tree ./testtest
├── docs
│ └── foo.md
├── foo.go
└── foo.py
```Running `cloc` would yield the following output:
```text
$ cloc ./test3 text files.
3 unique files.
0 files ignored.github.com/AlDanial/cloc v 1.94 T=0.00 s (626.3 files/s, 1878.9 lines/s)
-------------------------------------------------------------------------------
Language files blank comment code
-------------------------------------------------------------------------------
Go 1 2 0 5
Markdown 1 0 0 1
Python 1 0 0 1
-------------------------------------------------------------------------------
SUM: 3 2 0 7
-------------------------------------------------------------------------------
```Which we transform into a `Markdown` table with `clocrt`:
```sh
$ clocrt "`cloc ./test`"
```### github.com/AlDanial/cloc v 1.94 T=0.00 s (626.3 files/s, 1878.9 lines/s)
| Language | files | blank | comment | code |
| :------: | :---: | :---: | :-----: | :--: |
| Go | 1 | 2 | 0 | 5 |
| Markdown | 1 | 0 | 0 | 1 |
| Python | 1 | 0 | 0 | 1 |
| SUM: | 3 | 2 | 0 | 7 |\*`Markdown` table syntax: [link](https://github.com/adam-p/markdown-here/wiki/Markdown-Cheatsheet#tables)
_Voila!_ :confetti_ball:
## Usage
```text
$ clocrt -h
$ clocrt --helpNAME
clocrt - count lines of code redefined tablesDESCRIPTION
A simple, lightweight CLI tool to transform a cloc output into a Markdown table.USAGE
clocrt "`[CLOC-PATTERN]`" [OPTIONS]OPTIONS
--help, -h show the usage
--version, -v fetch and display the current version--print, -pr print the result to stdout
--cell-align|-ca= center|c (default), left|l, right|r
--output-path|-op= output file path (default: out.md)
BUGS
Don't forget to quote the pattern per the example: "`[CLOC-PATTERN]`"```
#### `cloc` docs
Documentation of the `cloc` command-line utility can be found [here](https://github.com/AlDanial/cloc#options-).
## Contributing
I'm open to any contribution to the repository. If you have any suggestions or feedback, please open an issue or pull request. :+1:
With the respect to the `MIT` License provided within the project: [link](https://github.com/michalspano/clocrt/blob/main/LICENSE).[contributors-shield]: https://img.shields.io/github/contributors/michalspano/clocrt.svg?style=for-the-badge
[contributors-url]: https://github.com/michalspano/clocrt/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/michalspano/clocrt.svg?style=for-the-badge
[forks-url]: https://github.com/michalspano/clocrt/network/members
[stars-shield]: https://img.shields.io/github/stars/michalspano/clocrt.svg?style=for-the-badge
[stars-url]: https://github.com/michalspano/clocrt/stargazers
[issues-shield]: https://img.shields.io/github/issues/michalspano/clocrt.svg?style=for-the-badge
[issues-url]: https://github.com/michalspano/clocrt/issues
[license-shield]: https://img.shields.io/github/license/michalspano/clocrt.svg?style=for-the-badge
[license-url]: https://github.com/michalspano/clocrt/blob/main/LICENSE
[release-shield]: https://img.shields.io/github/tag/michalspano/clocrt.svg?style=for-the-badge
[release-url]: https://github.com/michalspano/clocrt/tags/latest