You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
NQL works mostly on literals - strings that don't need to be quoted because they are obviously strings.
E.g. tag:photo, we don't need to do tag:'photo', it's totally redundant!
However, if a string contains a character that has another purpose in NQL, we have to use quotes (or escaping) to make it clear the whole thing is intended as a string.
E.g. in a date string published_at:<2017-09-01 12:45:12, both the space and the colons mean that we cannot use a literal, and we need to use quotes e.g. published_at:<'2017-09-01 12:45:12'.
NOTE: should colons be allowed inside of literals?! Or should they be allowed as escaped-chars!??!
This works absolutely wonderfully if the filter lives in a URL encoded URL string, or in JSON, but poses a problem in javascript code:
The single quotes end up escaped like \' inside the string, which NQL also doesn't seem to understand - or it goes wrong somewhere on the way to NQL - need to test this better to understand what's happening - it definitely should work
TODO:
At least support escaped single quotes (this is a bug)
Consider supporting double quotes (this is an enhancement)
The text was updated successfully, but these errors were encountered:
refs #18
- Added a bunch of additional tests, all passing, that show strings are lexed correctly
- I was not able to reproduce any issues with quotes not being treated correctly
- Escaped quotes are handled as expected
As far as I can tell, everything is working correctly the only thing we don't support is allowing an unescaped double quote in a single-quoted string, this is weird.
Ideally we'd support either quote style, and not require the other quote to be escaped within it.
Beyond that, it's possible to escape an apostrophe inside a single-quoted string, so we can represent 'john o'nolan'.
NQL works mostly on literals - strings that don't need to be quoted because they are obviously strings.
E.g.
tag:photo
, we don't need to dotag:'photo'
, it's totally redundant!However, if a string contains a character that has another purpose in NQL, we have to use quotes (or escaping) to make it clear the whole thing is intended as a string.
E.g. in a date string
published_at:<2017-09-01 12:45:12
, both the space and the colons mean that we cannot use a literal, and we need to use quotes e.g.published_at:<'2017-09-01 12:45:12'
.NOTE: should colons be allowed inside of literals?! Or should they be allowed as escaped-chars!??!
This works absolutely wonderfully if the filter lives in a URL encoded URL string, or in JSON, but poses a problem in javascript code:
Example from the prev/next helper in Ghost:
Normally we would use single quotes around the code, but we can't because this would clash with NQL.
In other languages, you'd switch to using double quotes, but NQL doesn't support this.
If we switch to using template literals:
The single quotes end up escaped like
\'
inside the string, which NQL also doesn't seem to understand - or it goes wrong somewhere on the way to NQL - need to test this better to understand what's happening - it definitely should workTODO:
The text was updated successfully, but these errors were encountered: