JSPM

  • Created
  • Published
  • Downloads 19068
  • Score
    100M100P100Q137684F
  • License ISC

Analyse languages used in a folder. Powered by GitHub Linguist, although it doesn't need to be installed.

Package Exports

  • linguist-js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (linguist-js) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Latest version Last updated npm downloads

Linguist

Analyses all files located in a given folder and collates the results. Powered by github-linguist, although it doesn't need to be installed.

Install

Linguist is available on npm as linguist-js.

Install locally using npm install linguist-js and import it into your code like so:

const linguist = require('linguist-js');

Or install globally using npm install -g linguist-js and run using the CLI command linguist.

linguist --help

Usage

Linguist contains one function which analyses a given folder.

As an example, take the following file structure:

.
| src
| | cli.js 1kB
| | index.ts 2kB
| readme.md 3kB

Running Linguist on this folder will return the following JSON:

{
    "count": 3,
    "results": {
        "src/index.ts": "TypeScript",
        "src/cli.js": "JavaScript",
        "readme.md": "Markdown"
    },
    "languages": {
        "programming": { "JavaScript": 1000, "TypeScript": 2000 },
        "markup": {},
        "data": {},
        "prose": { "Markdown": 3000 }
    }
}

API

Node

const linguist = require('linguist-js');
let folder = './src';
let options = { keepVendored: false, quick: false };
let { count, results, languages } = linguist(folder, options);
  • linguist(folder?, opts?) (default export): Analyse the language of all files found in a folder.
    • folder (optional; string): The folder(s) to analyse (defaults to ./). Analyse multiple folders using the syntax "{folder1,folder2,...}".
    • opts (optional; object): An object containing analyser options.
      • ignore (string array): A list of file path globs to explicitly ignore.
      • keepVendored (boolean): Whether to keep vendored files (dependencies, etc) (defaults to false).
      • quick (boolean): Whether to skip the checking of .gitattributes and .gitignore files for manual language classifications (defaults to false). Alias for checkAttributes: false, checkIgnored: false.
      • checkAttributes (boolean): Force the checking of .gitattributes files (defaults to true unless quick is set).
      • checkIgnored (boolean): Force the checking of .gitignore files (defaults to true unless quick is set).

Command-line

linguist --analyze [<folder>] [<...options>]
linguist --help
  • --analyze: Analyse the language of all files found in a folder.
    • <folder> (optional): The folder to analyse (defaults to ./). Analyse multiple folders using the syntax "{folder1,folder2,...}".
    • --ignore (optional): A list of file path globs (delimited with :, ; or |) to ignore.
    • --files (optional): Whether to print a full list of all files analysed.
    • --vendored (optional): Whether to include vendored files (dependencies, etc).
    • --quick (optional): Whether to skip the checking of .gitattributes and .gitignore files for manual language classifications. Alias for --checkAttributes=false --checkIgnored=false.
    • checkAttributes (optional): Force the checking of .gitatributes files (use alongside --quick to overwrite).
    • checkIgnored (optional): Force the checking of .gitignore files (use alongside --quick to overwrite).
  • --help: Display a help message.
  • --version: Display the current version of linguist-js.