forked from nodejs/node
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathonly-ascii-characters.js
65 lines (53 loc) · 1.53 KB
/
only-ascii-characters.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
61
62
63
64
65
/**
* @fileoverview Prohibit the use of non-ascii characters
* @author Kalon Hinds
*/
/* eslint no-control-regex:0 */
'use strict';
//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------
const nonAsciiPattern = new RegExp('([^\x00-\x7F])', 'g');
const suggestions = {
'’': '\'',
'—': '-'
};
const reportError = ({line, column, character}, node, context) => {
const suggestion = suggestions[character];
let message = `Non-ASCII character ${character} detected.`;
message = suggestion ?
`${message} Consider replacing with: ${suggestion}` : message;
context.report({
node,
message,
loc: {
line,
column
}
});
};
module.exports = {
create: (context) => {
return {
Program: (node) => {
const source = context.getSourceCode();
const sourceTokens = source.getTokens(node);
const commentTokens = source.getAllComments();
const tokens = sourceTokens.concat(commentTokens);
tokens.forEach((token) => {
const { value } = token;
const matches = value.match(nonAsciiPattern);
if (!matches) return;
const { loc } = token;
const character = matches[0];
const column = loc.start.column + value.indexOf(character);
reportError({
line: loc.start.line,
column,
character
}, node, context);
});
}
};
}
};