prettier-plugin-solidity
Version:
A Prettier Plugin for automatically formatting your Solidity code.
76 lines (65 loc) • 2.32 kB
text/typescript
import { NonterminalKind } from '@nomicfoundation/slang/cst';
import { getNodeMetadata, updateMetadata } from '../slang-utils/metadata.js';
import { StringLiteral } from './StringLiteral.js';
import { StringLiterals } from './StringLiterals.js';
import { HexStringLiteral } from './HexStringLiteral.js';
import { HexStringLiterals } from './HexStringLiterals.js';
import { UnicodeStringLiterals } from './UnicodeStringLiterals.js';
import type * as ast from '@nomicfoundation/slang/ast';
import type { AstPath, Doc, ParserOptions } from 'prettier';
import type { AstNode } from './types.d.ts';
import type { PrintFunction, SlangNode } from '../types.d.ts';
export class StringExpression implements SlangNode {
readonly kind = NonterminalKind.StringExpression;
comments;
loc;
variant:
| StringLiteral
| StringLiterals
| HexStringLiteral
| HexStringLiterals
| UnicodeStringLiterals;
constructor(ast: ast.StringExpression, options: ParserOptions<AstNode>) {
let metadata = getNodeMetadata(ast);
switch (ast.variant.cst.kind) {
case NonterminalKind.StringLiteral:
this.variant = new StringLiteral(
ast.variant as ast.StringLiteral,
options
);
break;
case NonterminalKind.StringLiterals:
this.variant = new StringLiterals(
ast.variant as ast.StringLiterals,
options
);
break;
case NonterminalKind.HexStringLiteral:
this.variant = new HexStringLiteral(
ast.variant as ast.HexStringLiteral,
options
);
break;
case NonterminalKind.HexStringLiterals:
this.variant = new HexStringLiterals(
ast.variant as ast.HexStringLiterals,
options
);
break;
case NonterminalKind.UnicodeStringLiterals:
this.variant = new UnicodeStringLiterals(
ast.variant as ast.UnicodeStringLiterals,
options
);
break;
default:
throw new Error(`Unexpected variant: ${ast.variant.cst.kind}`);
}
metadata = updateMetadata(metadata, [this.variant]);
this.comments = metadata.comments;
this.loc = metadata.loc;
}
print(path: AstPath<StringExpression>, print: PrintFunction): Doc {
return path.call(print, 'variant');
}
}