DEV Community

Cover image for Format parser for Prettier and ESLint
Matt Kenefick
Matt Kenefick

Posted on

2 1

Format parser for Prettier and ESLint

What is it?

A web-based tool that attempts to infer your preferred settings for Prettier + ESLint and generate your config files for you.

⚠️ It is very much a work in progress

Example: https://mattkenefick.github.io/format-parser/

Github: https://github.com/mattkenefick/format-parser

Work in progress

How does it work?

Assumptions are made using a series of regular expressions. Each rule per library (e.g. Prettier/QuoteProps) has its own class associated with it. When we change our input, it runs all of our filters to retrieve an output.

Example

import CoreRule from '../../core/rule.js';

/**
 * Semicolons
 *
 * Print semicolons at the ends of statements
 *
 * @see https://prettier.io/docs/en/options.html#semicolons
 */
export default class RuleSemiColons extends CoreRule
{
    /**
     * @var boolean
     */
    get default() {
        return true;
    }

    /**
     * @var string
     */
    get property() {
        return 'semicolons';
    }

    /**
     * Mandatory entry function to create a decision
     *
     * @return boolean
     */
    identify() {
        let output = this.default;

        // Find all of our semi colon line endings
        const semicolons = [...this.input.matchAll(/;\s*$/gm)];

        // Determine if they make up a valuable percentage of the file (5%)
        output = semicolons.length / this.lines.length > 0.05;

        return output;
    }
}
Enter fullscreen mode Exit fullscreen mode

The above class is for Pretter's SemiColon rule. It has a default value of true. The property represented in Prettier's config is semicolons. The identify function is where we attempt to make a determination about the output.

In the case above, we attempt to find all instances where a semi-colon precedes a line ending. If we at least 5% of the file uses semi-colons at the end of the line, we assume that's the preferred way to go.

The mentioned percentage is an arbitrary value and could be changed (remember "assumptions are made" from above). The assumption here is that wants to write without semi-colons will likely have next to none in their code.

More complex determinations

Some determinations are too difficult to solve with a singular regular expression. So far, I've found that a decent assumption can be made by evaluating one of three things:

  • A singular regular expression for the entire file (as seen above)

  • Iterating through individual lines of code

  • Iterating through braces/blocks of code

Finding the difference between function blocks vs object blocks vs array blocks can be valuable for an overall determination, like determining use of trailing commas.

Some assumptions are made by comparing two or more values, like with quotations: are there more double quotes or single quotes?

Wrapping up

I've only put about one Saturday's afternoon into this so far, but it's coming along pretty well. Some assumptions may need tweaking and there are a fair amount of ESLint rules to finish.

If you have feedback or want to contribute, checkout the Github.

Do your career a big favor. Join DEV. (The website you're on right now)

It takes one minute, it's free, and is worth it for your career.

Get started

Community matters

Top comments (0)

Image of AssemblyAI

Automatic Speech Recognition with AssemblyAI

Experience near-human accuracy, low-latency performance, and advanced Speech AI capabilities with AssemblyAI's Speech-to-Text API. Sign up today and get $50 in API credit. No credit card required.

Try the API

👋 Kindness is contagious

Dive into an ocean of knowledge with this thought-provoking post, revered deeply within the supportive DEV Community. Developers of all levels are welcome to join and enhance our collective intelligence.

Saying a simple "thank you" can brighten someone's day. Share your gratitude in the comments below!

On DEV, sharing ideas eases our path and fortifies our community connections. Found this helpful? Sending a quick thanks to the author can be profoundly valued.

Okay