Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
/twlyPublic

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

NotificationsYou must be signed in to change notification settings

rdgd/twly

Repository files navigation

You're a towel

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 projectnpm 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 commandtwly. 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 directorytwly '*.css'.

For a list of available CLI arguments run commandtwly --help.

See thenode-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

Contributors4

  •  
  •  
  •  
  •  

Languages


[8]ページ先頭

©2009-2025 Movatter.jp