Represents a state during the highlighting (e.g., comment state, string state, etc.).
More...
#include <highlightstate.h>
|
| | HighlightState (const std::string &e="normal") |
| | HighlightState (const HighlightState ©) |
| | Copies all the elements of the highlight state, except for the id: a new id will be used.
|
| void | addRule (HighlightRulePtr rule) |
| | Adss a rule to this state.
|
| HighlightRulePtr | replaceRule (RuleList::size_type index, HighlightRulePtr rule) |
| | Substitutes the rule at the specified position.
|
|
unsigned int | getId () const |
|
const RuleList & | getRuleList () const |
|
const std::string & | getDefaultElement () const |
|
void | setDefaultElement (const std::string &e) |
| bool | findBestMatch (const std::string &s, HighlightToken &token, const MatchingParameters ¶ms) const |
| | Tries to find the rule that matches best (and first): the first rule with the smallest prefix and longest matching sequence.
|
| bool | findBestMatch (std::string::const_iterator start, std::string::const_iterator end, HighlightToken &token, const MatchingParameters ¶ms) const |
| | Tries to find the rule that matches best (and first): the first rule with the smallest prefix and longest matching sequence.
|
| void | replaceReferences (const ReplacementList &rep) |
| | Performs replacement of references in the rules of this state.
|
|
bool | getNeedsReferenceReplacement () const |
|
void | setNeedsReferenceReplacement (bool b=true) |
|
HighlightStatePtr | getOriginalState () const |
|
void | setOriginalState (HighlightStatePtr orig) |
|
| static bool | betterThan (const HighlightToken &t1, const HighlightToken &t2) |
| | Whether t1 is better than t2: t1 has a non-longer prefix and a longer matching string (this makes sense only if a string was matched, and in fact this should be used only after having matched something).
|
|
|
const unsigned int | id |
| | the identifier of the state
|
|
std::string | defaultElement |
| | the name of the element for strings when no rule matches (default: "normal") for states this should always be "normal" while for environments it should be the same element that represents the new state (e.g., "comment", "string", etc.)
|
|
RuleList | ruleList |
| | the list of rules of this state
|
|
bool | needsReferenceReplacement |
| | whether one of the contained rules has dynamic references to be replaced
|
|
HighlightStatePtr | originalState |
| | In case this state is a copy of another state, in this field we store the original state.
|
|
|
static unsigned int | global_id |
| | the global counter to assign unique state ids
|
Represents a state during the highlighting (e.g., comment state, string state, etc.).
◆ HighlightState() [1/2]
- Parameters
-
| e | the element for strings when no rule matches (default: "normal") |
◆ HighlightState() [2/2]
Copies all the elements of the highlight state, except for the id: a new id will be used.
- Parameters
-
◆ addRule()
Adss a rule to this state.
- Parameters
-
| rule | the rule to add at the end of the list |
◆ betterThan()
Whether t1 is better than t2: t1 has a non-longer prefix and a longer matching string (this makes sense only if a string was matched, and in fact this should be used only after having matched something).
- Parameters
-
- Returns
◆ findBestMatch() [1/2]
Tries to find the rule that matches best (and first): the first rule with the smallest prefix and longest matching sequence.
- Parameters
-
| s | the string for trying to match the rule |
| token | where results will be inserted, if the rule matched |
| params | additional arguments for the matching |
- Returns
- whether a matching rule was found
◆ findBestMatch() [2/2]
Tries to find the rule that matches best (and first): the first rule with the smallest prefix and longest matching sequence.
- Parameters
-
| start | the beginning of the string for trying to match the rule |
| end | the beginning of the string for trying to match the rule |
| token | where results will be inserted, if the rule matched |
| params | additional arguments for the matching |
- Returns
- whether a matching rule was found
◆ replaceReferences()
Performs replacement of references in the rules of this state.
For each rule that needs replacement, it creates a copy of the rule.
- Parameters
-
| the | list of values for the replacement; the first element is the value for replacing the first dynamic back reference, and so on. (it should contain 9 possibly empty elements) |
◆ replaceRule()
Substitutes the rule at the specified position.
The rule must exit at the specified position.
- Parameters
-
- Returns
- the old rule
The documentation for this class was generated from the following file:
- /cygdrive/d/a/scallywag/source-highlight/source-highlight-3.1.9-1.x86_64/src/source-highlight-3.1.9/lib/srchilite/highlightstate.h