This project is under development.
Please feel free to PullRequest and Issue.
Visualize source code complexity with Sabik. This tool is to find the bad smell code. I think your helpful refactoring.
If you want to see what it looks like, click here.
Please use Node.js >= 14.
If you use Node.js 14 or less, please use version 0.2.0.
$ npx sabik /target/path
If you felt sabik is slow, using local installation.
$ npm i -g sabik
$ sabik /target/path
USAGE
$ sabik [TARGET]
OPTIONS
-h, --help show CLI help
-o, --outputReportPath=outputReportPath output report path.
For HTML, specify the directory, and for JSON, specify the file.
-t, --outputFormat=(HTML|JSON) [default: HTML] output report format. HTML or JSON. default: HTML
-v, --version show CLI version
--excludes=excludes [default: $^] exclude patterns. example: .test.ts$ .spec.ts$
--matches=matches [default: .*] match patterns. example: .ts$
- TypeScript
- JavaScript
- PHP
For now.
Sabik analyzable metrics are following.
- Cyclomatic Complexity
- Cognitive Complexity
- Halstead complexity measures
- Line of Code(Logical, Physical)
- Maintainability
For now.
Cyclomatic Complexity is metrics for linearly independent paths count. Made Thomas McCabe. High is bad, low is good metrics. Higher when your code has a deep nest. It’s very tiresome add test when over 8 scores. (In my experience)
If you want to know more about the detail, please see the following.
Cognitive Complexity is metrics for human readability. Made SonarSource inc. High is bad, low is good metrics. Higher when your code has a deep nest. It’s read very hard when over 8 scores. (In my experience)
If you want to know more about the detail, please see the following.
Halstead complexity measures are metrics for a difficulty to understand. Made Maurice Howard Halstead. High is bad, low is good metrics. Higher when your code has many responsibilities. These metrics are judge difficulty from vocabulary size, for example, the newspaper is difficult but, children's book is easy to understand.
If you want to know more about the detail, please see the following.
Physical Line of Code is metrics for line count include comments. Logical Line of Code is metrics for line count ignored comments. High is bad, low is good metrics.
Maintainability is metric for software maintainability. Made Microsoft inc. Low is bad, High is good metrics. This metric ranges from 0 ~ 100. It’s maintenance hard when under 60 scores. (In my experience)
If you want to know more about the detail, please see the following.
Copyright (c) 2020 Tetsuro Yoshikawa Licensed under the MIT license.