Search code examples
javascriptgulpeslintline-endings

Expected linebreaks to be 'LF' but found 'CRLF' linebreak-style


When using eslint in the gulp project i have encountered a problem with error like this
Expected linebreaks to be 'LF' but found 'CRLF' linebreak-style and I am using Windows environment for the running gulp and the entire error log is given below

 Kiran (master *) Lesson 4 $ gulp
 Using gulpfile c:\Users\Sai\Desktop\web-build-tools\4\
 gulpfile.js
 Starting 'styles'...
 Finished 'styles' after 17 ms
 Starting 'lint'...
 'lint' errored after 1.14 s
 ESLintError in plugin 'gulp-eslint'
 sage: Expected linebreaks to be 'LF' but found 'CRLF'.
 ails: fileName: c:\Users\Sai\Desktop\web-build-tools\4\js\extra.js



$>Users\Sai\Desktop\web-build-tools\4\js\extra.js
error  Expected linebreaks to be 'LF' but found 'CRLF'  linebreak-style

I have also including extra.js file as the error indicating possible mistake.

function getWindowHeight() {
    return window.innerHeight;
}

getWindowHeight();

Solution

  • Check if you have the linebreak-style rule configure as below either in your .eslintrc or in source code:

    /*eslint linebreak-style: ["error", "unix"]*/
    

    Since you're working on Windows, you may want to use this rule instead:

    /*eslint linebreak-style: ["error", "windows"]*/
    

    Refer to the documentation of linebreak-style:

    When developing with a lot of people all having different editors, VCS applications and operating systems it may occur that different line endings are written by either of the mentioned (might especially happen when using the windows and mac versions of SourceTree together).

    The linebreaks (new lines) used in windows operating system are usually carriage returns (CR) followed by a line feed (LF) making it a carriage return line feed (CRLF) whereas Linux and Unix use a simple line feed (LF). The corresponding control sequences are "\n" (for LF) and "\r\n" for (CRLF).

    This is a rule that is automatically fixable. The --fix option on the command line automatically fixes problems reported by this rule.

    But if you wish to retain CRLF line-endings in your code (as you're working on Windows) do not use the fix option.