2fd531e253
* Add: implement new linter system * Refactor: pull out editor worker * Switch to new linter and worker * Enable eslint cache * Fix: undefined error * Windows compatibility * Fix: refresh linter if the editor.linter changes * Add: stylelint * Add: getStylelintRules, getCsslintRules * Fix: logic to get correct linter * WIP: linter-report * Fix: toggle hidden state * Add: matain the order of lint report for section editor * Add: unhook event * Add: gotoLintIssue * Fix: shouldn't delete rule.init * Add: linter-help-dialog * Drop linterConfig * Add: linter-config-dialog, cacheFn * Add: use cacheFn * Drop lint.js * Add: refresh. Fix report order * Fix: hide empty table * Add: updateCount. Fix table caption * Switch to new linter/worker * Fix: remove unneeded comment * Fix: cacheFn -> cacheFirstCall * Fix: use cacheFirstCall * Fix: cache metaIndex * Fix: i < trs.length * Fix: drop isEmpty * Fix: expose some simple states to global * Fix: return object code style * Fix: use proxy to reflect API * Fix: eslint-disable-line -> eslint-disable-next-line * Fix: requestId -> id * Fix: one-liner * Fix: one-liner * Fix: move dom event block to top * Fix: pending -> pendingResponse * Fix: onSuccess -> onUpdated * Fix: optimize row removing when i === 0 * Fix: hook/unhook -> enableForEditor/disableForEditor * Fix: linter.refresh -> linter.run * Fix: some shadowing * Fix: simplify getAnnotations * Fix: cacheFirstCall -> memoize * Fix: table.update -> table.updateCaption * Fix: unneeded reassign * Fix: callbacks -> listeners * Fix: don't compose but extend * Refactor: replace linter modules with linter-defaults and linter-engines * Fix: implement linter fallbacks * Fix: linter.onChange -> linter.onLintingUpdated * Fix: cms -> tables * Fix: parseMozFormat is not called correctly * Move csslint-loader to background * Fix: watch config changes * Fix: switch to LINTER_DEFAULTS * Fix: csslint-loader -> parserlib-loader
66 lines
1.2 KiB
JavaScript
66 lines
1.2 KiB
JavaScript
'use strict';
|
|
|
|
// eslint-disable-next-line no-var
|
|
var linter = (() => {
|
|
const lintingUpdatedListeners = [];
|
|
const unhookListeners = [];
|
|
const linters = [];
|
|
const cms = new Set();
|
|
|
|
return {
|
|
register,
|
|
run,
|
|
enableForEditor,
|
|
disableForEditor,
|
|
onLintingUpdated,
|
|
onUnhook
|
|
};
|
|
|
|
function onUnhook(cb) {
|
|
unhookListeners.push(cb);
|
|
}
|
|
|
|
function onLintingUpdated(cb) {
|
|
lintingUpdatedListeners.push(cb);
|
|
}
|
|
|
|
function onUpdateLinting(...args) {
|
|
for (const cb of lintingUpdatedListeners) {
|
|
cb(...args);
|
|
}
|
|
}
|
|
|
|
function enableForEditor(cm) {
|
|
cm.setOption('lint', {onUpdateLinting, getAnnotations});
|
|
cms.add(cm);
|
|
}
|
|
|
|
function disableForEditor(cm) {
|
|
cm.setOption('lint', false);
|
|
cms.delete(cm);
|
|
for (const cb of unhookListeners) {
|
|
cb(cm);
|
|
}
|
|
}
|
|
|
|
function register(linterFn) {
|
|
linters.push(linterFn);
|
|
}
|
|
|
|
function run() {
|
|
for (const cm of cms) {
|
|
cm.performLint();
|
|
}
|
|
}
|
|
|
|
function getAnnotations(...args) {
|
|
return Promise.all(linters.map(fn => fn(...args)))
|
|
.then(results => [].concat(...results.filter(Boolean)));
|
|
}
|
|
})();
|
|
|
|
// FIXME: this should be put inside edit.js
|
|
prefs.subscribe(['editor.linter'], () => {
|
|
linter.run();
|
|
});
|