-
Notifications
You must be signed in to change notification settings - Fork 85
Expand file tree
/
Copy pathprint-preserving-empty-lines.ts
More file actions
37 lines (33 loc) · 1.25 KB
/
print-preserving-empty-lines.ts
File metadata and controls
37 lines (33 loc) · 1.25 KB
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
import { NonterminalKind } from '@nomicfoundation/slang/cst';
import { doc, util } from 'prettier';
import { locEnd } from '../slang-utils/loc.js';
import type { AstPath, Doc, ParserOptions } from 'prettier';
import type { AstNode, LineCollection } from '../slang-nodes/types.d.ts';
import type { PrintFunction } from '../types.d.ts';
const { hardline } = doc.builders;
export function printPreservingEmptyLines(
path: AstPath<LineCollection>,
print: PrintFunction,
options: ParserOptions<AstNode>
): Doc {
return path.map((childPath) => {
const node = childPath.node;
return [
// Only attempt to prepend an empty line if `node` is not the first item
!childPath.isFirst &&
// YulLabel adds a dedented line so we don't have to prepend a hardline.
(node.kind !== NonterminalKind.YulStatement ||
node.variant.kind !== NonterminalKind.YulLabel)
? hardline
: '',
print(childPath),
// Only attempt to append an empty line if `node` is not the last item
!childPath.isLast &&
// Append an empty line if the original text already had an one after the
// current `node`
util.isNextLineEmpty(options.originalText, locEnd(node))
? hardline
: ''
];
}, 'items');
}