Class EnumeratedReferenceLinkRefProcessor
- java.lang.Object
-
- com.vladsch.flexmark.ext.enumerated.reference.internal.EnumeratedReferenceLinkRefProcessor
-
- All Implemented Interfaces:
LinkRefProcessor
public class EnumeratedReferenceLinkRefProcessor extends java.lang.Object implements LinkRefProcessor
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
EnumeratedReferenceLinkRefProcessor.Factory
-
Field Summary
Fields Modifier and Type Field Description (package private) static int
BRACKET_NESTING_LEVEL
private EnumeratedReferenceRepository
enumeratedReferenceRepository
(package private) static boolean
WANT_EXCLAMATION_PREFIX
-
Constructor Summary
Constructors Constructor Description EnumeratedReferenceLinkRefProcessor(Document document)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description @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
getBracketNestingLevel()
Whether the element consists of nested [] inside the link ref.boolean
getWantExclamationPrefix()
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 Detail
-
WANT_EXCLAMATION_PREFIX
static final boolean WANT_EXCLAMATION_PREFIX
- See Also:
- Constant Field Values
-
BRACKET_NESTING_LEVEL
static final int BRACKET_NESTING_LEVEL
- See Also:
- Constant Field Values
-
enumeratedReferenceRepository
private final EnumeratedReferenceRepository enumeratedReferenceRepository
-
-
Constructor Detail
-
EnumeratedReferenceLinkRefProcessor
public EnumeratedReferenceLinkRefProcessor(Document document)
-
-
Method Detail
-
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
public boolean isMatch(@NotNull @NotNull BasedSequence nodeChars)
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
@NotNull public @NotNull Node createNode(@NotNull @NotNull BasedSequence nodeChars)
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
public void updateNodeElements(@NotNull @NotNull Document document, @NotNull @NotNull Node node)
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
-
-