This repository was archived by the owner on Jun 6, 2019. It is now read-only.
forked from eslint-community/eslint-plugin-eslint-plugin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprefer-placeholders.js
60 lines (52 loc) · 1.8 KB
/
prefer-placeholders.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/**
* @fileoverview disallow template literals as report messages
* @author Teddy Katz
*/
'use strict';
const utils = require('../utils');
// ------------------------------------------------------------------------------
// Rule Definition
// ------------------------------------------------------------------------------
module.exports = {
meta: {
docs: {
description: 'disallow template literals as report messages',
category: 'Rules',
recommended: false,
url: 'https://github.com/not-an-aardvark/eslint-plugin-eslint-plugin/tree/master/docs/rules/prefer-placeholders.md',
},
fixable: null,
schema: [],
},
create (context) {
let contextIdentifiers;
// ----------------------------------------------------------------------
// Public
// ----------------------------------------------------------------------
return {
Program (node) {
contextIdentifiers = utils.getContextIdentifiers(context, node);
},
CallExpression (node) {
if (
node.callee.type === 'MemberExpression' &&
contextIdentifiers.has(node.callee.object) &&
node.callee.property.type === 'Identifier' && node.callee.property.name === 'report'
) {
const reportInfo = utils.getReportInfo(node.arguments);
if (
reportInfo && reportInfo.message && (
(reportInfo.message.type === 'TemplateLiteral' && reportInfo.message.expressions.length) ||
(reportInfo.message.type === 'BinaryExpression' && reportInfo.message.operator === '+')
)
) {
context.report({
node: reportInfo.message,
message: 'Use report message placeholders instead of string concatenation.',
});
}
}
},
};
},
};