8.1 KiB
Event System
Introduction
The Event Object
Events
Events are raised when a subparser is run (or about to be run). Within a subparser, the events always follow a certain order (sequence). For instance, .before events always run before .captureStart. Each subparser raises several events sequentially:
-
.start: always runs except it subparser is disabled
Raised when the subparser has started, but no capturing or any modification to the text was done.
Always runs (except if the subparser is deactivated through options).
Properties:
property type access description input string read The full text that was passed to the subparser output string write The full text with modification that will be passed along the chain regex null matches null Usually you would want to use this event if you wish to change the input to the subparser
-
.captureStart: might not be run;
Raised when a regex match is found and a capture was successful. Some normalization and modification of the regex captured groups might be performed.
Might not be run if no regex match is found.
Properties:
property type access description input string read The captured text output string write The text that will be passed to the subparser/other listeners regex RegExp readonly Regular Expression used to capture groups matches object read/write Matches groups. Changes to this object are reflected in the output Usually you would want to use this event if you wish to modify a certain subparser behavior. Exs: remove all title attributes from links; change indentation of code blocks; etc...
-
.captureEnd: might not be run;
Raised after the modifications to the captured text are done but before the replacement is introduced in the document.
Might not be run if no regex match is found.
Properties:
property type access description input string read The captured text output string write The text that will be passed to the subparser/other listeners regex RegExp readonly Regular Expression used to capture groups matches object read/write Keypairs of matches groups. Changes to this object are reflected in the output attributes object read/write Attributes to add to the HTML output -
.beforeHash: might not be run;
Raised before the output is hashed.
Always run (except if the subparser was deactivated through options), even if no hashing is performed.
Properties:
property type access description input string read The captured text output string write The text that will be passed to the subparser/other listeners regex null matches null Usually you would want to use this event if you wish change the subparser output before it is hashed
-
.end: always runs;
Raised when the subparser has finished its work and is about to exit.
Always runs (except if the subparser is deactivated through options).
Properties:
property type access description input string read The partial/full text with the subparser modifications output string write The text that will be passed to other subparsers regex null matches null Usually you would want to use this event if you wish change the subparser hashed output
Special Events
There are some special events that are useful for "positioning" a listener extension in the main chain of events. Usually these extensions introduce new syntax that, due to precedence These events are always guaranteed to be called, regardless of options or circumstances.
-
.before_{subparserName}: always runs
Raised just before the {subparserName} is about to be entered.
Properties:
property type access description input string read The full text that was passed to the subparser output string write The full text with modification that will be passed along the chain regex null matches null -
.after.{subparserName}: always runs;
Raised when the {subparserName} has exited and before the next one is called.
Properties:
property type access description input string read The partial/full text with the subparser modifications output string write The text that will be passed to other subparsers regex null matches null
Notes
-
There are 2 main differences between before.{subparserName} and {subparserName}.start.
-
before.{subparserName} is always guaranteed to be called, even if the subparser is disabled, while {subparserName}.start doesn't.
ex:
makehtml.before.strikethrough
is always called even if the optionstrikethrough
is false -
before.{subparserName} is only raised once in a span context while {subparserName}.start is raised everytime {subparserName} is called.
As a rule of thumb,
-