@saasmakers/eslint 1.0.10 → 1.0.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -139,6 +139,21 @@ const rule$b = {
139
139
  function collapseBlankLine(text) {
140
140
  return text.replace(/\n[^\S\n]*\n[^\S\n]*/, "\n");
141
141
  }
142
+ function expressionUsesThis(expression) {
143
+ if (expression.type === index$1.distExports.AST_NODE_TYPES.AssignmentExpression) {
144
+ return isThisReceiver(expression.left);
145
+ }
146
+ if (expression.type === index$1.distExports.AST_NODE_TYPES.CallExpression) {
147
+ return isThisReceiver(expression.callee);
148
+ }
149
+ if (expression.type === index$1.distExports.AST_NODE_TYPES.OptionalCallExpression) {
150
+ return isThisReceiver(expression.callee);
151
+ }
152
+ if (expression.type === index$1.distExports.AST_NODE_TYPES.UpdateExpression) {
153
+ return isThisReceiver(expression.argument);
154
+ }
155
+ return false;
156
+ }
142
157
  function getActualLastToken(node, sourceCode) {
143
158
  const semiToken = sourceCode.getLastToken(node);
144
159
  if (!semiToken) {
@@ -185,9 +200,15 @@ function getStatementKind(node) {
185
200
  if (isSuperCall(node)) {
186
201
  return isSingleLine(node) ? "singleline-super" : "multiline-super";
187
202
  }
203
+ if (isVoidExpression(node.expression)) {
204
+ return isSingleLine(node) ? "singleline-void" : "multiline-void";
205
+ }
188
206
  if (isDirectivePrologue(node)) {
189
207
  return null;
190
208
  }
209
+ if (expressionUsesThis(node.expression)) {
210
+ return isSingleLine(node) ? "singleline-this" : "multiline-this";
211
+ }
191
212
  return isSingleLine(node) ? "singleline-expression" : "multiline-expression";
192
213
  }
193
214
  return null;
@@ -227,6 +248,21 @@ function isSingleLine(node) {
227
248
  function isSuperCall(node) {
228
249
  return node.expression.type === index$1.distExports.AST_NODE_TYPES.CallExpression && node.expression.callee.type === index$1.distExports.AST_NODE_TYPES.Super;
229
250
  }
251
+ function isThisReceiver(node) {
252
+ if (node.type === index$1.distExports.AST_NODE_TYPES.ThisExpression) {
253
+ return true;
254
+ }
255
+ if (node.type === index$1.distExports.AST_NODE_TYPES.MemberExpression || node.type === index$1.distExports.AST_NODE_TYPES.OptionalMemberExpression) {
256
+ return isThisReceiver(node.object);
257
+ }
258
+ if (node.type === index$1.distExports.AST_NODE_TYPES.ChainExpression) {
259
+ return isThisReceiver(node.expression);
260
+ }
261
+ return false;
262
+ }
263
+ function isVoidExpression(expression) {
264
+ return expression.type === index$1.distExports.AST_NODE_TYPES.UnaryExpression && expression.operator === "void";
265
+ }
230
266
  const rule$a = {
231
267
  defaultOptions: [],
232
268
  meta: {
package/dist/index.mjs CHANGED
@@ -137,6 +137,21 @@ const rule$b = {
137
137
  function collapseBlankLine(text) {
138
138
  return text.replace(/\n[^\S\n]*\n[^\S\n]*/, "\n");
139
139
  }
140
+ function expressionUsesThis(expression) {
141
+ if (expression.type === distExports.AST_NODE_TYPES.AssignmentExpression) {
142
+ return isThisReceiver(expression.left);
143
+ }
144
+ if (expression.type === distExports.AST_NODE_TYPES.CallExpression) {
145
+ return isThisReceiver(expression.callee);
146
+ }
147
+ if (expression.type === distExports.AST_NODE_TYPES.OptionalCallExpression) {
148
+ return isThisReceiver(expression.callee);
149
+ }
150
+ if (expression.type === distExports.AST_NODE_TYPES.UpdateExpression) {
151
+ return isThisReceiver(expression.argument);
152
+ }
153
+ return false;
154
+ }
140
155
  function getActualLastToken(node, sourceCode) {
141
156
  const semiToken = sourceCode.getLastToken(node);
142
157
  if (!semiToken) {
@@ -183,9 +198,15 @@ function getStatementKind(node) {
183
198
  if (isSuperCall(node)) {
184
199
  return isSingleLine(node) ? "singleline-super" : "multiline-super";
185
200
  }
201
+ if (isVoidExpression(node.expression)) {
202
+ return isSingleLine(node) ? "singleline-void" : "multiline-void";
203
+ }
186
204
  if (isDirectivePrologue(node)) {
187
205
  return null;
188
206
  }
207
+ if (expressionUsesThis(node.expression)) {
208
+ return isSingleLine(node) ? "singleline-this" : "multiline-this";
209
+ }
189
210
  return isSingleLine(node) ? "singleline-expression" : "multiline-expression";
190
211
  }
191
212
  return null;
@@ -225,6 +246,21 @@ function isSingleLine(node) {
225
246
  function isSuperCall(node) {
226
247
  return node.expression.type === distExports.AST_NODE_TYPES.CallExpression && node.expression.callee.type === distExports.AST_NODE_TYPES.Super;
227
248
  }
249
+ function isThisReceiver(node) {
250
+ if (node.type === distExports.AST_NODE_TYPES.ThisExpression) {
251
+ return true;
252
+ }
253
+ if (node.type === distExports.AST_NODE_TYPES.MemberExpression || node.type === distExports.AST_NODE_TYPES.OptionalMemberExpression) {
254
+ return isThisReceiver(node.object);
255
+ }
256
+ if (node.type === distExports.AST_NODE_TYPES.ChainExpression) {
257
+ return isThisReceiver(node.expression);
258
+ }
259
+ return false;
260
+ }
261
+ function isVoidExpression(expression) {
262
+ return expression.type === distExports.AST_NODE_TYPES.UnaryExpression && expression.operator === "void";
263
+ }
228
264
  const rule$a = {
229
265
  defaultOptions: [],
230
266
  meta: {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@saasmakers/eslint",
3
- "version": "1.0.10",
3
+ "version": "1.0.12",
4
4
  "private": false,
5
5
  "description": "Shared ESLint config and rules for SaaS Makers projects",
6
6
  "license": "MIT",