Skip to content
Steel Brain edited this page Oct 28, 2015 · 49 revisions

The Linter API allows you to lint files of different specified scopes.

Defining a provider

You will need to add this to your package.json file

"providedServices": {
  "linter": {
    "versions": {
      "1.0.0": "provideLinter"
    }
  }
}

and you should return an object like this from your provideLinter function

Note: You can return more than one providers at once by wrapping them in an Array. Note: You can make your provider get triggered on all scopes by using grammarScopes: ['*']. Note: You must either provide text or html, providing both is an error.

const provider = {
  name: 'Some Linter',
  grammarScopes: ['source.js', 'source.php'],
  scope: 'file', // or 'project'
  lintOnFly: false,
  lint: function(textEditor) {
    return new Promise(function(resolve, reject) {
      // do something async or
      return [{
        type: 'Error',
        text: 'Something went wrong',
        range:[[0,0], [0,1]],
        filePath: textEditor.getPath()
      }]
    })
  }
}

If you think that you don't need to be asynchronous, then you can return the direct results instead of returning a Promise.

Messages

{
  type: string,
  text?: string,
  html?: string,
  filePath?: string,
  range?: Range,
  trace?: Array<Trace>
}

Trace is an optional type that you embed inside an Error or Warning.

It can be used to provide backtraces or references to other files or ranges. This is what it looks like. Also note that you can provide any type attribute in the trace object.

Screenshot

// Trace
{
  type: "Trace",
  text?: string,
  html?: string,
  filePath: string,
  range?: Range,
  class?: string
}
Clone this wiki locally