47

I have just started using JSHint (through the Sublime-Linter package for Sublime Text 2). I would like to suppress its warnings regarding functions that are used before they are defined, as I see no problem with using function definitions like this. For example, the following code generates warnings:

(function($){ 

    $(document).ready(function()
    {
      formValidationSetup();
      refreshErrorMessages();
    });

    function formValidationSetup()
    {

    }

    function refreshErrorMessages()
    {

    }

})(jQuery);

The warnings:

  1. formValidationSetup is defined but never used
  2. refreshErrorMessages is defined but never used

I've tried setting undef to false in the JSHint options, but I'm still getting these errors. Is there another option I should be setting? Form the JSLint docs for undef:

true if variables and functions need not be declared before used. This is not available in strict mode.

Undistraction
  • 42,754
  • 56
  • 195
  • 331

6 Answers6

91

To avoid the warning

defined but never used

in jslint in your javascript add comments like:

 /*exported formValidationSetup, refreshErrorMessages */

In jshint and jslint you can set the unused option to false:

 /*jshint unused:false*/

See Options

Roland Puntaier
  • 3,250
  • 30
  • 35
9

I had this problem with should and expect in Chai tests. I ended up with this pattern:

'use strict';

var request = require('supertest');
var should = require('chai').should();  // jshint ignore:line
var expect = require('chai').expect;    // jshint ignore:line

process.env.NODE_ENV = 'test';
var appPromise = require('./index');

describe('GET /r_u_up', function() {

  it('respond with 204', function(done) {
    appPromise.then(function(app) {
      request(app)
      .get('/r_u_up')
      .expect(204, done);
    });
  });

});
Michael Cole
  • 15,473
  • 7
  • 79
  • 96
5

You can simply use

"unused": false,

in your .jshintrc

Imal Hasaranga Perera
  • 9,683
  • 3
  • 51
  • 41
3

Interestingly, adding 'use strict'; inside the IIFE suppresses the error. Not sure why though.

Undistraction
  • 42,754
  • 56
  • 195
  • 331
3

A better way not touching the Gruntfile.js in a typical Yoeman setup is to edit the .jshintrc file (a hidden file in Unix system). And update the content as the following:

{
  "curly": true,
  "eqeqeq": true,
  "immed": true,
  "latedef": true,
  "newcap": true,
  "noarg": true,
  "sub": true,
  "undef": true,
  "unused": false, // the change is here
  "boss": true,
  "eqnull": true,
  "node": true
}

set the "unused" to false.

sampathsris
  • 21,564
  • 12
  • 71
  • 98
xptest18
  • 39
  • 2
  • 2
    Welcome to Stack Overflow. Consider formatting code elements in your answer using indented code blocks or preformatted text: http://stackoverflow.com/editing-help#code – sampathsris Aug 25 '14 at 03:04
-1

You'll want to use the 'latedef' option

cyberwombat
  • 38,105
  • 35
  • 175
  • 251