Skip to content

Commit ceee56b

Browse files
Trottrvagg
authored andcommitted
tools: disallow deprecated define getter/setter
PR-URL: #6774 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Johan Bergström <bugs@bergstroem.nu> Refs: #6768
1 parent c81b6f8 commit ceee56b

File tree

2 files changed

+33
-0
lines changed

2 files changed

+33
-0
lines changed

.eslintrc

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -94,6 +94,7 @@ rules:
9494
assert-fail-single-argument: 2
9595
new-with-error: [2, "Error", "RangeError", "TypeError", "SyntaxError", "ReferenceError"]
9696
no-deepEqual: 2
97+
no-definegetter-definesetter: 2
9798

9899
# Global scoped method and vars
99100
globals:
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
/**
2+
* @fileoverview Rule to flag usage of __defineGetter__ and __defineSetter__
3+
* @author Rich Trott
4+
*/
5+
6+
'use strict';
7+
8+
//------------------------------------------------------------------------------
9+
// Rule Definition
10+
//------------------------------------------------------------------------------
11+
12+
module.exports = {
13+
create: function(context) {
14+
const disallowed = ['__defineGetter__', '__defineSetter__'];
15+
16+
return {
17+
MemberExpression: function(node) {
18+
var prop;
19+
if (node.property) {
20+
if (node.property.type === 'Identifier' && !node.computed) {
21+
prop = node.property.name;
22+
} else if (node.property.type === 'Literal') {
23+
prop = node.property.value;
24+
}
25+
if (disallowed.includes(prop)) {
26+
context.report(node, `The ${prop} property is deprecated.`);
27+
}
28+
}
29+
}
30+
};
31+
}
32+
};

0 commit comments

Comments
 (0)