New! Render PlantUML diagrams directly inside GitHub
with our official browser extension —
No server. No tokens. No tracking. Zero permissions but clipboard. —
Try it out and let us know what you think!
Extended Backus–Naur Form (EBNF)
Extended Backus–Naur Form (EBNF) is a type of formal syntax used to specify the structure of a programming language or other formal language. It is an extension of Backus-Naur Form (BNF), which was originally developed by John Backus and Peter Naur to describe the syntax of the Algol programming language. EBNF adds several additional metasymbols to the original BNF metasymbols, which allows for a more concise and readable specification of a language's syntax. It is commonly used in the specification of programming languages, and is also sometimes used to describe the syntax of other types of formal languages, such as database query languages or markup languages. Basic support for EBNF has been introduced in PlantUML. [Ref. QA-16529]
Minimal binary diagram
All EBNF Elements
EBNF elements handled by PlantUML are described below.
Special sequence management with special-sequence-symbol "?"
You can manage special sequence with special-sequence-symbol "?".
Full repetition management with repetition-symbol "*"
You can manage repetition with repetition-symbol "*".
Drawing mode
Before version V1.2025.1, you can choice the drawing mode, and having a compacted mode by using !pragma compact command.
Expanded mode (by default, and the only one from V1.2025.1)
Compacted mode (only available before V1.2025.1)
Notes on Elements
Notes may be added to elements of your diagram by using EBNF comment tags.
Using (global) style
Without style (by default)
With style
You can use style to change rendering of elements.
Example of LISP Grammar
LISP Grammar with PlantUML.
EBNF of PlantUMLs EBNF Grammar
EBNF allows for self description, so here it is!
Java Language Specification
A real world example of a detailed programming language.
Packages and Modules
Lexical Structure
Types, Values, and Variables
Names
Classes
Interfaces
Arrays
Blocks, Statements, and Patterns
Remaining defects
Could you put 'arrow head' on all rerouted lines?
Order issue
Allow accentuated or Unicode char on EBNF meta-identifier or rule name.
Allow full restriction management with except-symbol "-"