Skip to content
/ twly Public

Wanna get DRY? Static analysis tool for detecting repeat code.

Notifications You must be signed in to change notification settings

rdgd/twly

Folders and files

NameName
Last commit message
Last commit date

Latest commit

3ff7250 · Jun 15, 2021
May 15, 2017
Sep 6, 2016
May 25, 2017
May 25, 2017
May 25, 2017
Sep 2, 2016
May 25, 2017
Oct 23, 2018
Jun 15, 2021
Jun 15, 2021
May 25, 2017
May 25, 2017
May 25, 2017
Oct 23, 2018
May 25, 2017
Jun 15, 2021
May 25, 2017
May 16, 2017

Repository files navigation

You're a towel

twly?

twly (pronounced "towel-E") is a static analysis tool which can help you keep your code DRY (Don't Repeat Yourself) by letting you know where you have copy and pasted entire files or portions of them. Run twly on a directory, and twly will magically generate a report for you indicating what has been repeated and in which files. twly is language agnostic and can be used on any text document.

Installation

npm install -g twly or to include in some project npm install twly --save-dev

Configuration

twly has some default configuration, which translates into following configuration JSON object

  {
    "threshold": 95,
    "ignore": ["node_modules/**/*.*", "bower_components/**/*.*", ".git/**/*.*"],
    "minLines": 4,
    "minChars": 100
  }

twly reads the config file .trc. This file should contain a JSON object. For example, below is an example .trc file if you wanted to do the following:

  • Ignore the specific files foo.txt and bar.txt as well as all of the content in your node_modules directory
  • Exit with a status code of 1 (failure) if under 89.5 percent of files are unique
  • Only match blocks of code that have are at least 7 lines large with a minimum of 200 characters
  {
    "threshold": 89.5,
    "ignore": ["foo.txt", "bar.txt", "node_modules/**"],
    "minLines": 7,
    "minChars": 200
  }

Usage

You can use twly by simply running the command twly. This will analyze all the files and recurse into subdirectories in your current working directory by default. You can also pass twly a glob pattern... If for example you wanted all javascript files in your current directory and all subdirectories: twly '**/*.js'. This will analyze all CSS files in your current working directory twly '*.css'.

For a list of available CLI arguments run command twly --help.

See the node-glob project for options on how to specify files.

Docker Image

A Dockerfile is provided. It can be be used like so:

twly> docker build -t twly .
app> docker run --rm -t -v "$(pwd):/code" -w /code twly