@putout/printer 6.14.0 → 6.16.0

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/ChangeLog CHANGED
@@ -1,3 +1,13 @@
1
+ 2023.12.03, v6.16.0
2
+
3
+ feature:
4
+ - 27a2185 @putout/printer: ReturnStatement inside IfStatement: newline
5
+
6
+ 2023.12.03, v6.15.0
7
+
8
+ feature:
9
+ - f05ae8a @putout/printer: MemberExpression: chain inside ifStatement
10
+
1
11
  2023.12.03, v6.14.0
2
12
 
3
13
  feature:
@@ -1,6 +1,10 @@
1
1
  'use strict';
2
2
 
3
- const {isDecorator} = require('@putout/babel').types;
3
+ const {
4
+ isDecorator,
5
+ isMemberExpression,
6
+ } = require('@putout/babel').types;
7
+
4
8
  const {
5
9
  isLast,
6
10
  isCoupleLines,
@@ -18,7 +22,7 @@ const isTrailingIsLeading = (path) => path.node.trailingComments === path.getNex
18
22
  const isNewlineAfter = (path) => {
19
23
  const {parentPath} = path;
20
24
 
21
- if (parentPath.isMemberExpression())
25
+ if (isMemberExpression(parentPath))
22
26
  return false;
23
27
 
24
28
  return !isLast(path) && !isDecorator(path);
@@ -28,9 +28,7 @@ const classVisitor = maybeDecorators((path, printer, semantics) => {
28
28
 
29
29
  if (node.implements) {
30
30
  print(' implements ');
31
- path
32
- .get('implements')
33
- .forEach(print);
31
+ path.get('implements').forEach(print);
34
32
  }
35
33
 
36
34
  if (node.superClass) {
@@ -3,7 +3,6 @@
3
3
  const {
4
4
  isUnaryExpression,
5
5
  isArrowFunctionExpression,
6
- isLogicalExpression,
7
6
  isIfStatement,
8
7
  } = require('@putout/babel').types;
9
8
 
@@ -65,10 +64,30 @@ const isCall = (a) => a.type === 'CallExpression';
65
64
  const isExcludedFromChain = satisfy([
66
65
  isUnaryExpression,
67
66
  isArrowFunctionExpression,
68
- isLogicalExpression,
69
67
  isIfStatement,
70
68
  ]);
71
69
 
70
+ const isIfUp = (path) => {
71
+ const ifPath = path.find(isIfStatement);
72
+ let is = false;
73
+
74
+ if (!ifPath)
75
+ return is;
76
+
77
+ ifPath
78
+ .get('test')
79
+ .traverse({
80
+ MemberExpression(currentPath) {
81
+ if (path === currentPath) {
82
+ is = true;
83
+ path.stop();
84
+ }
85
+ },
86
+ });
87
+
88
+ return is;
89
+ };
90
+
72
91
  module.exports.likeChain = likeChain;
73
92
  function likeChain(path) {
74
93
  const [root, properties] = chain(path);
@@ -76,6 +95,9 @@ function likeChain(path) {
76
95
  if (isExcludedFromChain(root))
77
96
  return false;
78
97
 
98
+ if (path.find(isIfUp))
99
+ return false;
100
+
79
101
  const calls = properties.filter(isCall);
80
102
  const [firstCall] = calls;
81
103
 
@@ -4,7 +4,6 @@ const {markAfter} = require('../../mark');
4
4
  const {exists, isNext} = require('../../is');
5
5
 
6
6
  const isInside = ({parentPath}) => !parentPath.parentPath.isProgram();
7
-
8
7
  const isEmptyConsequent = (path) => path.get('consequent').isEmptyStatement();
9
8
 
10
9
  const isInsideNestedBody = ({parentPath}) => {
@@ -43,6 +43,9 @@ module.exports.ReturnStatement = {
43
43
  if (isLast(path))
44
44
  return false;
45
45
 
46
+ if (isLast(path.parentPath))
47
+ return false;
48
+
46
49
  return noTrailingComment(path);
47
50
  },
48
51
  after(path, {print}) {
@@ -18,9 +18,7 @@ module.exports.TSInterfaceDeclaration = {
18
18
 
19
19
  if (node.extends) {
20
20
  print(' extends ');
21
- path
22
- .get('extends')
23
- .map(print);
21
+ path.get('extends').map(print);
24
22
  }
25
23
 
26
24
  print('__typeParameters');
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@putout/printer",
3
- "version": "6.14.0",
3
+ "version": "6.16.0",
4
4
  "type": "commonjs",
5
5
  "author": "coderaiser <mnemonic.enemy@gmail.com> (https://github.com/coderaiser)",
6
6
  "description": "Simplest possible opinionated Babel AST printer for 🐊Putout",