Formatting Features
Typstyle follows a consistent set of formatting rules to ensure your Typst code is readable, maintainable, and follows established conventions. This page documents the core formatting styles applied by typstyle.
All examples are automatically rendered using the embedded typstyle formatter, ensuring they always reflect the latest features.
However, documentation updates may lag behind new features. If there are inconsistencies between descriptions and example output, the actual formatting behavior takes precedence.
- Default line width: 80 characters (configurable with
--line-width--line-width) - Default indentation: 2 spaces per level (configurable with
--indent-width--indent-width) - File endings: typstyle ensures files end with a newline character
Inline comments are preserved and positioned correctly:
#let conf( title: none,//commentsauthors: (), abstract: [], lang: "zh",// language doctype: "book",//commentsdoc,// my docs) = { doc}#{ let c = 0// my comment}
#let conf( title: none,//commentsauthors: (), abstract: [], lang: "zh",// language doctype: "book",//commentsdoc,// my docs) = { doc}#{ let c = 0// my comment}
#let conf( title: none, //comments authors: (), abstract: [], lang: "zh", // language doctype: "book", //comments doc, // my docs) = { doc }#{ let c = 0 // my comment}
#let conf( title: none, //comments authors: (), abstract: [], lang: "zh", // language doctype: "book", //comments doc, // my docs) = { doc }#{ let c = 0 // my comment}
Block comments are automatically aligned and formatted:
#{ let x = 1 /* Attached block comment that spans multiple lines */ /* Block comment that spans multiple lines */}Aligned: /* Block comment with leading stars * that * spans * multiple * lines */
#{ let x = 1 /* Attached block comment that spans multiple lines */ /* Block comment that spans multiple lines */}Aligned: /* Block comment with leading stars * that * spans * multiple * lines */
#{ let x = 1 /* Attached block comment that spans multiple lines */ /* Block comment that spans multiple lines */}Aligned: /* Block comment with leading stars * that * spans * multiple * lines */
#{ let x = 1 /* Attached block comment that spans multiple lines */ /* Block comment that spans multiple lines */}Aligned: /* Block comment with leading stars * that * spans * multiple * lines */
Use // @typstyle off// @typstyle off to disable formatting for specific code regions:
// @typstyle off#let intentionally_bad_format = "preserved";#let properly_formatted="cleaned up"
// @typstyle off#let intentionally_bad_format = "preserved";#let properly_formatted="cleaned up"
// @typstyle off#let intentionally_bad_format = "preserved";#let properly_formatted = "cleaned up"
// @typstyle off#let intentionally_bad_format = "preserved";#let properly_formatted = "cleaned up"
The escape hatch only applies to the next syntax node, not the rest of the code.
There is no closing // @typstyle on// @typstyle on directive.
For details, please see Escape Hatch.