Class FootnoteLinkRefProcessor
java.lang.Object
com.vladsch.flexmark.ext.footnotes.internal.FootnoteLinkRefProcessor
- All Implemented Interfaces:
LinkRefProcessor
-
Nested Class Summary
Nested Classes -
Field Summary
FieldsModifier and TypeFieldDescription(package private) static final int
private final FootnoteRepository
(package private) static final boolean
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescription@NotNull BasedSequence
adjustInlineText
(@NotNull Document document, @NotNull Node node) Adjust child nodes' text as needed when some of the link ref text was used in the opening or closing sequence of the node or if the children are not desired then removeIndex them.boolean
allowDelimiters
(@NotNull BasedSequence chars, @NotNull Document document, @NotNull Node node) Allows the delimiter processor to allow/disallow other delimiters in its inline text@NotNull Node
createNode
(@NotNull BasedSequence nodeChars) Create the desired element that was previously matched with isMatchint
Whether the element consists of nested [] inside the link ref.boolean
Whether the image ref is desired, if not then ! will be stripped off the prefix and treated as plain textboolean
isMatch
(@NotNull BasedSequence nodeChars) Test whether the element matches desired one.void
updateNodeElements
(@NotNull Document document, @NotNull Node node) Allows the processor to adjust nodes' elements after all delimiters have been processed inside the inlined text
-
Field Details
-
WANT_EXCLAMATION_PREFIX
static final boolean WANT_EXCLAMATION_PREFIX- See Also:
-
BRACKET_NESTING_LEVEL
static final int BRACKET_NESTING_LEVEL- See Also:
-
footnoteRepository
-
-
Constructor Details
-
FootnoteLinkRefProcessor
-
-
Method Details
-
getWantExclamationPrefix
public boolean getWantExclamationPrefix()Description copied from interface:LinkRefProcessor
Whether the image ref is desired, if not then ! will be stripped off the prefix and treated as plain text- Specified by:
getWantExclamationPrefix
in interfaceLinkRefProcessor
- Returns:
- true if ! is part of the desired element, false otherwise
-
getBracketNestingLevel
public int getBracketNestingLevel()Description copied from interface:LinkRefProcessor
Whether the element consists of nested [] inside the link ref. For example Wiki link [[]] processor would return 1 Only immediately nested [] are considered. [[ ]] is nesting 1, [ [ ]] is not consideredWhen
>0
then preview of next characters is used and if they will match then inner reference will not be created to allow outer one to match the desired element- Specified by:
getBracketNestingLevel
in interfaceLinkRefProcessor
- Returns:
- desired nesting level for references,
>0
for nested, 0 for not nested
-
isMatch
Description copied from interface:LinkRefProcessor
Test whether the element matches desired one. For processors that allow nesting this will be called one additional. time for each nesting level. Last call for the actual match, all others to pre-match to prevent a non-nested element from being created.- Specified by:
isMatch
in interfaceLinkRefProcessor
- Parameters:
nodeChars
- text to match, including [] or ![]- Returns:
- true if it is a match
-
createNode
Description copied from interface:LinkRefProcessor
Create the desired element that was previously matched with isMatch- Specified by:
createNode
in interfaceLinkRefProcessor
- Parameters:
nodeChars
- char sequence from which to create the node- Returns:
- Node element to be inserted into the tree
-
adjustInlineText
@NotNull public @NotNull BasedSequence adjustInlineText(@NotNull @NotNull Document document, @NotNull @NotNull Node node) Description copied from interface:LinkRefProcessor
Adjust child nodes' text as needed when some of the link ref text was used in the opening or closing sequence of the node or if the children are not desired then removeIndex them.- Specified by:
adjustInlineText
in interfaceLinkRefProcessor
- Parameters:
document
- document, can be used to get parsing optionsnode
- node whose inline text is to be adjusted to reflect some of the text having been used as part of the opener and/or closer sequence.- Returns:
- adjusted sequence to use for this node's child text
-
allowDelimiters
public boolean allowDelimiters(@NotNull @NotNull BasedSequence chars, @NotNull @NotNull Document document, @NotNull @NotNull Node node) Description copied from interface:LinkRefProcessor
Allows the delimiter processor to allow/disallow other delimiters in its inline text- Specified by:
allowDelimiters
in interfaceLinkRefProcessor
- Parameters:
chars
- character sub-sequence to testdocument
- document, can be used to get optionsnode
- delimited node created by this processor @return true if delimiters are allowed in this part of the node's text
-
updateNodeElements
Description copied from interface:LinkRefProcessor
Allows the processor to adjust nodes' elements after all delimiters have been processed inside the inlined text- Specified by:
updateNodeElements
in interfaceLinkRefProcessor
- Parameters:
document
- document, can be used to get parsing optionsnode
- node whose elements can be adjusted
-