Comments (8)
Just to confirm: this is applying to Hamlet, not Lucius or Cassius, correct?
from shakespeare.
Yes. I actually didn't tried replicating this in Lucius/Cassius, so it's just Hamlet.
from shakespeare.
The fact is that the spaces are not intended to be optional between the class and ident tokens, as we start to run into syntax ambiguities (the hash is overloaded for "insert a variable" and "start an identifier"). So I'd actually be tempted to say that both of those are invalid Hamlet and should raise a warning. But I'm not sure how others would feel about such a change.
from shakespeare.
h1.foo#bar and h1#bar.foo looks pretty unambiguous to me and converting that into invalid hamlet sounds like a bad idea.
from shakespeare.
I don't see where there would be ambiguity. I think both should be supported. An id is more important than a class and I think should go first as a best practice, but I don't think Hamlet should enforce that.
from shakespeare.
The ambiguity comes from:
h1.foo#{bar}
We could do more checking: if a hash is followed by a left brace, then it's not an ID. But that's the reason I'm in favor of just making all of the spaces a requirement.
from shakespeare.
I constantly use h1#id.class
I never use .class#id
, and am ok with saying that it isn't supported.
It is bad to currently pass #
through as an invalid class name character though.
from shakespeare.
Agreed on that last point, I've added an error explaining the problem.
from shakespeare.
Related Issues (20)
- Lucius and Cassius `&` not documented
- Lucius Cassius Comment syntax not documented HOT 5
- CSS Math HOT 1
- Hamlet puts <title> to <body> HOT 5
- Julius: async function cannot be parsed HOT 6
- shakespeare escape bug in #\" HOT 2
- [lucius] @supports mixing problem? HOT 4
- Test failure with GHC 9 HOT 6
- Build error with aeson-2 HOT 1
- `$maybe` and `$forall` unsupported in `Text.Shakespeare.Text` HOT 2
- fails to build with aeson-2.0 HOT 5
- Mixins should respect rule order HOT 1
- I18N, allow multiline messages in translation files
- Support lens operators in templates
- Julius arrow function with curly brace body is compiled to expression even if it's not an expression HOT 2
- Surprising behaviour of Scientific arithmetic inside a template HOT 1
- Cannot have two messages with the same parameter name of different types HOT 3
- Inconsistency between `textfile` and `stextfile` HOT 2
- Upgrading to the `LTS-20.26` implies ~100x performance regression for functions using dynamic templates.
- Add "$foreach" statement.
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from shakespeare.