-
Notifications
You must be signed in to change notification settings - Fork 21
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Mixed syntax scanner #11
base: master
Are you sure you want to change the base?
Conversation
The mixed scanner will parse <r:tag></r:tag> {r:tag}{/r:tag} block styles and {tag} without a prefix or end-tag.
Interesting. I took a quick look through but didn't see a test like this (perhaps I missed it). What happens with this scanner if I try:
Will that raise an error or just quietly pass? |
It will allow different start/end syntax, but if this is something that should not be allowed I'm not sure if this should be checked inside the scanner or if it should be something that is passed through to the Parser which is already doing the start/end tag checks. |
It seems the MixedScanner won't allow:
How would the regex be changed to support an optional prefix? |
No it will match single tags To support
But to support |
Thanks for the fast reply. I actually don't require the html/xml style tags at all, so having to restrict matches to my own tags isn't really an issue. I changed the regex in the MixedScanner to the following, using your suggestion, but adding the
I'm trying to use the following tag combination:
The scanner is now confused and fails. The output is the un-truncated When using the original regex, and prefixes in my truncate tag, the output is perfect:
I feel your answer is close, but the lack of an end tag for the inner tag confuses the scanner. Adding a self-closing tag however doesn't fix the issue. I suck at regex. Your help is much appreciated. |
@MeetDom wouldn't your example need a self-closing tag |
@saturnflyer Yes I did try that, but it doesn't fix the issue. I'm on Mac and so downloaded Reggie and RegExhibit. Both tools match well, and RegExhibit actually shows the match details. I'm currently using this regex:
And the following text:
All variations are matching. The problem doesn't seem to be the regex, just the ruby statement when interpolating the The latest variation of the regex I'm using in the MixedScanner is:
|
Yes, sorry the regex will match but I forgot the scanner also modifies If you use the To support the mixing of closed/non-closed tags it will need a change to the parser that injects any missing end tags rather than raise an error. I'll give it a try but would this be something that could be pulled into radius without changing how existing templates work? |
I'm not sure if you want to pull this in - but it includes a new scanner that supports mixed syntax:
It will parse both
<r:tag></r:tag>
and{r:tag}{/r:tag}
block styles and also a{tag}
style without a prefix or end-tag.So you can choose the standard
<xml:tag>
syntax to hide tags from wysiwyg editors, and switch to{block:tags}
when you want to see something, also the{tag}
style looks better inside attributes<a href="{url}">{Title}</a>
It also gets close to supporting tumblr style templates
{block:Post}{Title}{/block:Post}