Replace core language HexStrings with library entity
Baz via Digitalmars-d
digitalmars-d at puremagic.com
Tue Mar 17 14:18:04 PDT 2015
On Tuesday, 17 March 2015 at 21:06:04 UTC, Artur Skawina wrote:
> On 03/17/15 20:47, deadalnix via Digitalmars-d wrote:
>>
>> Not that much. But q{ string are a pain in the ass.
>
> Why? I'm not sure if you're referring to using or parsing them.
> The only problem with the former is the lack of a
> non-brace-nesting
> variant.
> Lexing is quite trivial, as long as the lexer supports
> recursion.
> For example, this is a complete implementation:
>
> TokenString: "q{" TokenStringBody "}"
> TokenStringBody: ( ( ![{}] TokenClass )+ /
> BracedTokenSequence )*
> BracedTokenSequence: "{" ( ( ![{}] TokenClass )+ /
> BracedTokenSequence )* "}"
>
> That's PEG, but the mapping to code should be fairly obvious.
>
> For syntax highlighting purposes it can actually be even
> simpler - it's
> enough to treat a `q{` token just like a `{`; everything that
> follows
No. I don't agree. `q{` makes sense: it's a helper for a string
you want to mix. `q{` means: don't highlight me as a string even
if i'm one. It's clearly made for the people who writes text
editors and IDEs.
More information about the Digitalmars-d
mailing list