Mamushi is a fork of the popular Black formatter adapted to the Vyper programming language. Mamushi reformats your Vyper contracts in a readable and consistent way.
pip install mamushi
Search all *.vy files and overwrite them after formatting:
mamushi
Specify a list of *.vy files or directories and output to console after formatting:
mamushi [SRC]
Output the result to console instead of overwriting:
mamushi --in-place False
The default line length is 80. Line length can be adjusted by using the --line-length
option.
By default, mamushi will compare the AST of your reformatted code with that of the original to ensure that the changes applied remain strictly formal. The option can be disabled with --safe False
to speed things up.
When handling expressions split by commas, mamushi follows Black's default behavior.
Mamushi also uses Black's magic trailing comma to give user the option to collapse a comma-separated expression into one line if possible. If a trailing comma is added, mamushi will always explode the expression. This can have important consequences for the commenting of your code. Consider the following two examples:
This code snippet:
self.b(0, # amount to send
msg.sender, # sender
True, # refund ?
)
formats to the following with a trailing comma after the last argument (True
):
self.b(
0, # amount to send
msg.sender, # sender
True, # refund ?
)
The # fmt: on
, # fmt: off
, # fmt: skip
tags from black are currently not supported. You can use # nosplit
to prevent the formatter from a splitting a line but formatting will still be applied to spacing.
but if the trailing comma is removed, the line will be collapsed to:
self.b(0, msg.sender, True) # amount to send # sender # refund ?
- Multiprocessing when processing multiple files
- Configuration files
- Improve Windows compatibility
- Handle versioning of Vyper/lark grammar
- Refactoring comment handling in the parser
- Add .gitignore / exclude / include support