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

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

About

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

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages