-
Notifications
You must be signed in to change notification settings - Fork 15
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
Proposal: Semantic color aliases (both official and theme defined) #11
Comments
For builders I think the changes would be pretty simple:
|
I think the basic idea is pretty sound. I assume only base 0-15 is required. Since we want to make sure any template works for any scheme (The whole point of base16), we probably want to define a superset for all possible name aliases and all aliases should default to a base color. If what I'm saying is ok, aliases like Another lower level question is what syntax we want to use. An alternative syntax is to use yaml anchor I think it's more expressive and easier for builders to implement. It even opens the door for having more than 16 colors. |
Yes that's the idea. They'd only exist as a convenience for scheme authors. I think in many other cases one might use the |
In #10 although I did title it @joshgoebel I like this proposal. I suggest also including |
Sure. I purposely wasn't being exhaustive... obviously an official list would need to be created if we are to go this direction... and it might involve MORE than what we currently list in our styles doc, but those we list there (including |
I'd say:
We obviously will have to decide how general/specific we want to be since some scopes in some editors get crazy like: Looking at some popular editors and the most popular scopes/contexts to theme might help us insure we have a good working list. (i mean what we have now isn't terrible, but it's probably missing a few items at least) |
By the way, base9 has something similar which could use as a guide for designing a list of possible aliases: |
such en-complication of format would require to create a simple linting tool based on some of the builders, to run it on CI, which would check what all those references are resolvable and provide as a result at least minimal base16 scheme names also i think it would be better to prefix named color references with some special characters to avoid confusing situation with old-style colors which are not prefixed with '#' and not to break backward-compatibility with old schemes by disabling colors without '#' prefix |
I'm not sure why it wouldn't just be the builder... CI:
We get it for free as soon as the builder properly supports these checks for building (which it must to do it's job).
An example here might help, I'm not sure I follow what you're suggesting fully. |
|
Well it could technically be either... if there was an I could of course invent ficticous examples, with my Bace scheme:
But we could probably also disallow variables with 6 digit hex names, and then we avoid this edge case entirely. Though I don't think a lot of people were likely to run into it in the first place. Or force someone to add
I'm kind of sad we made it optional personally. If that's what you were originally suggesting that's not so bad. |
i was lazy exercising myself to come up with a 6-letter word containing only letters i think it would be better to just prefix variables with smth like
that's not worth of breaking backward-compatibility |
It wouldn't since no aliases exist yet, there are no naming conflicts yet. The
You mean on the value side, like this? # reminder, # is optional
bace00: "#bace01"
bace01: "#bace00"
bace02: "@bace00"
bace03: "@bace01" Someone suggested the |
i meant what totally disabling colors without adding resolution algorithm to determine whatever some unprefixed identifier is color or "variable" - won't break backward-compatibility but will en-complicate both spec and builder logic |
I was never suggesting that.
It's quite trivial I assure you... few lines. But even if it was slightly harder - I think the main focus should be on usability for theme and template authors, not the backend implementation details.
And could be explained in one or two sentences tops (and perhaps an example or two). It might be it's "too magical"... but I'll let others weigh in and decide... Using a prefix is "ok"... just I think not necessary in 99.9999999% of cases. |
it's ok when updating existing builder, but every of those "two lines" here and there would be a PITA if implementing builder from scratch. especially as it could be avoided without loosing the same functionality |
i think it's also would be useful to do a research which of currently available yaml parsers do support |
I've written such things from scratch before, it's simply not that complex. Truly. 💻 |
@belak Kind of waiting for your high-level thoughts before I whip up a quick proof of concept and fix Nord to see how all this might work in practice. :) |
but why to do it at all if same problem could be solved without doing it? your motivation also totally not correlating with your previous decision to remove template-index from spec because "it was too complicated" but writing same two lines for allowing ambiguous variable identifiers instead of specific ones is not, is "easy, not complex" |
It has to be done one way or the other - which requires some amount of complexity, I just think my way might be a bit more elegant... sometimes a bit of magic is nice.
Not my decision... and entirely different. Each thing must be judged on it's own merits. I think aliases are a feature that would benefit MOST syntax template authors where-as I think "build the world" benefits a very, very small number of users.
I don't allow them, they (in the very rare chance they are encounted in the wild) they throw a clear error. :) |
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
This comment was marked as off-topic.
😄 True (in absolute terms) - and perhaps I shouldn't have said "two lines of code" or whatever I said... BUT... I'm always thinking in terms of top-down design, abstraction, and well hidden complexity... and from that perspective it is literally a 1 line patch that really touches a single location in the codebase (other than a few constants) and adds only a single simple and easy to understand function. const hexDefinitions = Object.keys(data).reduce((accumulator, key) => {
+ resolveAliases(key, data); You can't get a lot better than that for the MAJOR new functionality this provides. |
A possibly relevant area to compare with is the recently standardized forced-colors spec in browsers. It tries to to standardize some basic semantic names that are under the control of the user (and/or the user's OS, e.g. dark mode may be activated at sundown). So you as a user can specify white on black, black on white, high-contrast, low-contrast (many of the examples talk about high-contrast but it's important to give the user control over this) or really anything to suit your own needs and any site that tries to follow the spec will do it's best to honor the users wishes. https://drafts.csswg.org/css-color/#valdef-system-color-canvas It hits lots of the same issues, if you don't know which colors are used (since those are under user control), how can you know the output will be readable. They suggest mostly setting the colors in foreground/background pairs, but also expect certain colors to be readable against certain other colors (e.g. Link on Canvas) rather than always setting a pair of colors. An accessabile base16 theme that picks these up as well for consistency would be neat too, but referring to it mostly as a source of similar ideas. |
That sounds a bit like perhaps phase 2... I'm more focused on the technical details of creating the aliasing system to allow semantic color names at all... at that point there are 100 different directions we COULD go that would require lots of discussion. That's why I suggested our initial pass might just start with the original semantic scopes from the spec.. I'll go ahead and write them out:
From the official list |
I'll try to take a closer look this weekend - but after a quick glance I like the general idea, though I worry a bit about the potential complexity. I think one other limitation is that it won't map cleanly to the 16 colors any more and therefore will only really work with GUI applications. |
Complexity for implementors? More choices can mean more complexity, sure. But look at the Vim template, it's already 413 lines... for many editors (Sublime, VS Code, Vim, Emacs) the amount of complexity doesn't go up - we just get higher fidelity and more diverse themes. If the spec mandates that the I think we also need to realize not all designers have the same goals...
Why would this have an impact on which applications can work with Base16? We map those semantic meanings into 16 colors now... This just allows someone to map the semantic meaning of the 16 colors differently. Or are you merely saying you're afraid that specific themes will become "less general purpose" and more targeted towards specific goals/users/applications... in which case I'd ask: Is a designer wanting to craft amazing Base16 themes focused largely on the Terminal welcome in our community? I think the answer should be yes and that:
Now I'm thinking there is a whole 3rd discussion here on the meta level about thus topic, the idea of a "general purpose" theme. That maybe the part of Base16 I take issue with.
|
I'm not sure I understand what you mean by this... which "16 colors" are we mapping to again? Surely you don't mean colors/hues? Were you merely trying to say the 16 palette slots that we attach semantic meaning to? I mean in that regard it'd be hard not to agree... the part of the spec that says Nord (and many other themes) true intents are broken in Base16 until that part of the spec starts to open up. I'm not sure that means we need to open up ALL the slots fully... that would be another discussion... I'd personally lean more towards "yes" though and find a way to guide the resulting creativity instead of restraining it. Having 0 and 5 for background and foreground (legacy) and then letting people build on top of that sounds nice. |
Maybe I was misunderstanding (like I said I just did a quick pass so far), but I thought part of this proposal was allowing additional colors to be assigned in addition to assigning semantic aliases. The additional colors would mean more than 16 which wouldn't be possible in all terminals. If you're just taking about aliases, that's probably easier. |
Nope. I'm happy with the 16 colors (it's in our brand!), though I think we should consider shaders in the future, but that's a separate discussion. This proposal is only about making it easier for people to deploy those 16 colors how they choose, without having to fight with Base16. And making it easier to write themes that have named palettes... I think my Nord theme is much more readable with just the But at the end of the day there are still only 16 colors to choose from. If someone (with the power of aliases) adds 19 colors, then the builder would throw an error and say "only 16 colors, please". |
@belak Pointed out that we also need the ability to turn semantic names into ANSI (0-16) colors for terminal sake... that a template might NOT need need the hexcolor, it might need to know "which of the 16 terminal colors is the right one"... example: Take line 248:
This wants "terminal color" (0-16)... not "hexcolor". So higher up in the template:
This would need to be replace with something like:
Which would figure out which color "comments" resolves to but then output the |
#47 is my first draft at adding "named slots" (my new name for ALL the labels) this to the spec. Still early. |
Perhaps $ for custom named slots? (to differentiate from built-in named slots) string: "constant"
constant: "base05"
base05: $red
$red: "ff0000" |
For context: I create schemes, originally only for Vim, but that then expanded on writing out every config for every program. The key takeaway of base16 for me is write once, build, have ready configs for everything. The idea with the aliases sounds great to me and reminds me of Vim's highlight links, where you can easily say with hi! link Float Number that Now, for the actual set of those aliases: I think they should first form a reasonable hierarchy ( I do want to express concern about the differentiation strategy between color and alias though. |
This has already been addressed - there are several solutions... The build tool can throw an error if a lookup is ambiguous... or we can mandate the use of
It's not extended,
That isn't something we know, that's just how the YAML is written - after it's parsed there are no quotes anywhere, only raw strings.
It's to avoid future overlap and conflicts between system slots/alises and user variables. |
That's also a big leap in complexity (with lots of edge cases) but it's technically doable. With even a single tier though we're 30x more flexible than base16. |
I've create a new repo for what I'm calling the Base17 style guide: https://github.com/base16-project/base17 I'd love feedback, the spec itself can be found under In my opinion this is how we move forward - now that Chris has reasserted his ownership of Base16.
I think getting our tooling to accept and work with the fact that there are real and divergent (the input file won't all look the same) style systems is the first step to making all of this more concrete. |
I would recommend separating semantic color aliases from color variables. Having 2 separate proposals will make it easier to talk about and tweak each of the ideas separately and see their value individually. |
TLDR: Many themes are impossible to represent in Base16 because we insist on binding multiple semantic meanings into singular colors: IE, "variables AND diff deleted MUST always be the same color". It's baked right into the spec. 🙁 You'll never find a Base16 theme where that's not true, but you'll find many themes in the larger world where that's not true.
This results in many themes ported to Base16 being broken or becoming "hollow shells" of what they intended to be. I think this is a bad outcome and we should be more flexible. Look at the Nord example at the top of #10... the Base16 Nord on the left honestly doesn't even look like Nord at all.
I think this deserves it's own topic though it's an offshoot of #10... I've quickly come to believe than many themes coming into Base16 from the "outside" can't possibly be properly represented in Base16 because of Base16's insistence on "semantic binding"... ie binding multiple semantic meanings into a single base16 color:
It's a bit larger problem than "too much red"... We don't have to look any further than the Nord examples given to see how fast this falls completely apart:
Nord is very clear about the intention of it's palette (emphasis mine):
So immediately Nord is impossible to properly represent in Base 16 because it's a violation of the "semantic binding" of
base08
.Proposal
I propose we entirely unbind the semantics with aliasing... and that all the current semantic labels become aliases. We many also need aliases for mapping colors into terminal color space... (if the desire is to TRY and match default terminal colors at all).
For backwards compatibility all the "official" alaises could map to their "semanticly bound" colors, as they do now... so if you didn't specify
error
ordiff_deleted
orvariable
they would all point tobase08
(redish in many themes).This would certainly require the aid/assistance/buy in of the template maintainers (to benefit from this improvement), but I think they'd welcome it... I'll speak for myself as the maintainer of Highlight.js template that I'd love to see this - and Nord is just one example of why.
Originally posted by @joshgoebel in #10 (comment)
The text was updated successfully, but these errors were encountered: