• greasewizard@slrpnk.net
    link
    fedilink
    English
    arrow-up
    82
    ·
    6 days ago

    I don’t agree with this at all. syntax highlighting is more useful when looking at small chunks of code. I only need to know the difference between the two words next to each other, or if I properly closed a string definition.

    I should memorize my theme colors? give me a break. the only one I need to know is which one is a string, the rest are “code”

    I wouldn’t vehemently disagree with this so much if the article didn’t make so many assumptions, and was in a more conversational tone. “Getting it wrong” sounds pompous, but if you just talked about how YOU used syntax highlighting, I wouldn’t care so much

    • lad@programming.dev
      link
      fedilink
      English
      arrow-up
      18
      ·
      6 days ago

      Yeah, there are maybe a couple of reasonable ideas like using background and making comments stand out more, but that’s it. Especially weird is the idea about light theme not being used because of syntax highlight

  • Gobbel2000@programming.dev
    link
    fedilink
    arrow-up
    13
    ·
    5 days ago

    I feel like the truth lies somewhere in the middle, but this one I absolutely 100% agree with:

    Comments should be highlighted, not hidden away.

    • w3dd1e@lemmy.zip
      link
      fedilink
      arrow-up
      2
      ·
      4 days ago

      100% agree. First thing u do when setting up a new dev environment is grab an extension to highlight comments.

      I like the extensions that let me change the color by using various symbols in the comments.

  • Eager Eagle@lemmy.world
    link
    fedilink
    English
    arrow-up
    58
    ·
    6 days ago
    • Complains that it’s hard to see purple becoming red when return is misspelled
    • Creates a theme that doesn’t differentiate reserved keywords from variables at all
  • 48954246@lemmy.world
    link
    fedilink
    English
    arrow-up
    59
    ·
    6 days ago

    Very strong opinions for something entirely subjective and endlessly configurable.

    I failed the question about remembering what colour my class definitions were, but you know what? I don’t care. All I want is for it to be visually distinct when I’m trying to parse a block of code

    • Eager Eagle@lemmy.world
      link
      fedilink
      English
      arrow-up
      15
      ·
      6 days ago

      yeah, this guy got syntax highlighting backwards. It never occurred to me that I should know the element-to-color mappings of my theme. For what good would that serve?

    • Kissaki@programming.dev
      link
      fedilink
      English
      arrow-up
      7
      ·
      5 days ago

      I failed the question about remembering what colour my class definitions were, but you know what? I don’t care. All I want is for it to be visually distinct when I’m trying to parse a block of code

      Between multiple IDEs, text editors, diff viewers and editors, and hosted tools like MR/review diff, they’re not even consistently just one thing. For me, very practically and factually. Colors differ.

      As you point out, they’re entirely missing the point. What the colors are for and how they’re being used.

    • Buddahriffic@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      4 days ago

      Yeah, if I want to know what the colour is to find other instances of that thing easier, it takes 2 seconds to determine the colour. But I can’t remember ever actually doing that.

      That retunr typo will be caught by the compiler. That’s what pass 1 is pretty much for, spell and syntax check.

    • jh29a@lemmy.blahaj.zone
      link
      fedilink
      arrow-up
      1
      ·
      5 days ago

      I care about knowing what which color means ostensibly (not sure how much it actually benefits me,) but I also actually do, for the vscode default theme.

  • Jayjader@jlai.lu
    link
    fedilink
    arrow-up
    49
    ·
    6 days ago

    Per statistics, 70% of developers prefer dark themes. Being in the other 30%, that question always puzzled me. Why?

    Have you tried asking any of them?

    And I think I have an answer. Here’s a typical dark theme: […] and here’s a light one: […] On the latter one, colors are way less vibrant.

    Does the author not understand that a lot of us code in darker environments where the light background of most light themes either sears our retinas or forces us to turn the monitor brightness so far down that everything becomes a shade of grey?

    • entwine@programming.dev
      link
      fedilink
      arrow-up
      17
      ·
      6 days ago

      Most light themes I’ve encountered don’t seem to grasp the concept of ‘contrast’. I bet if you were to survey light theme users, you’d find that most of them have nonstandard/weird settings on their monitors. Chrome dev tools, Xcode, and Visual Studio’s light themes are all great though, as they have proper contrast and don’t look like rainbow vomit.

      But one other issue with light themes is that for some people (myself included), it makes ‘eye floaters’ stand out more. I’m fortunate that my case isn’t terrible, but I can see it being a serious problem for some people, especially older developers.

    • Frezik@lemmy.blahaj.zone
      link
      fedilink
      English
      arrow-up
      2
      ·
      5 days ago

      Agreed. When I switch from a browser tab with a white background to something dark, my eyes physically feel less stressed. High nit monitors might not be doing us favors on this one.

  • TeamAssimilation@infosec.pub
    link
    fedilink
    arrow-up
    41
    ·
    6 days ago

    If everyone else is is wrong, it might be that he’s the one who is wrong.

    Actually, I read his post and he’s definitely wrong. Having coded in plaint text editors without syntax highlighting, I know the candy store look really aids locating needles on this haystack. He’s proposing making more needles hay-colored so the ones he thinks are more important become the focus.

    It’s just his personal taste, if he loves visual fatigue, he should enjoy it without criticizing others.

  • Ms. ArmoredThirteen@lemmy.zip
    link
    fedilink
    English
    arrow-up
    33
    ·
    6 days ago

    Their examples where they’re trying to trick me into not finding things as quickly with a bunch of syntax highlighting worked exactly the opposite for me. Also I use dark theme because I don’t like burning a hole through my retinas from working all day it has nothing to do with highlighting options. This is a very subjective topic being presented as fact to such a degree it feels like satire

    • underscores@lemmy.zip
      link
      fedilink
      English
      arrow-up
      5
      ·
      6 days ago

      Agreed. My theme works for me and I’ve never had any issues finding anything.

      I use GitHub Dark with high contrast. I also use this theme for nvim.

      I think the key take away should be: experiment with themes and fonts and find something that works for you because if you’re like <author> some themes might be easier to work with.

  • magic_lobster_party@fedia.io
    link
    fedilink
    arrow-up
    28
    ·
    6 days ago

    There are two main use-cases you want your color theme to address:

    1. Look at something and tell what it is by its color (you can tell by reading text, yes, but why do you need syntax highlighting then?)
    2. Search for something. You want to know what to look for (which color).

    I disagree. I want syntax highlighting because I think it’s easier to read. I don’t care much about which color everything is, just that different things have different colors. I don’t remember any color mappings, and I’m never thrown off guard if the color mapping change.

    When I read var count = 0L, I want to know that var is syntactically different from count, and count is different from 0L. That’s it.

    • Kacarott@aussie.zone
      link
      fedilink
      arrow-up
      3
      ·
      4 days ago

      Exactly!! Having each different part be different colours essentially breaks the code into larger “tokens” which is much easier to read than letting your eyes get lost in a sea of uniformity.

      It’s not about knowing which colour is variables and which colour is functions. It’s about there being some contrast between them.

  • esa@discuss.tchncs.de
    link
    fedilink
    arrow-up
    28
    ·
    6 days ago

    The stance coupled with the garish background colour reminds me of how Pike also had a very dismissive view of using colours for syntax highlighting, and then later opened up about having a kind of colourblindness.

    Both of them also seem to mean colour when they write syntax highlighting. That’s just one typographic tool among many. We also use bold, italics, underline, and even whitespace to highlight programming syntax. We could write a lot of programming languages as if they were prose, but we don’t. People hate that and call it “minified code”.

    Humans also have a great capacity for colour vision, much better than most mammals. Some of us are even tetrachromats. Our colour vision is basically a free channel of information: It’s always on; we don’t have to concentrate to be able to discern most colours. When things in nature are more colourful than usual, like leaves in fall or a colourful sunset, we don’t find it tiresome; we find it refreshing and seek it out. But when our built environment becomes all shades of grey, we tend to find it depressing.

    But humans are also different in many ways here. Better or worse colour vision is one thing, but some are also prone to getting overstimulated; others require more than average stimuli. We have great selective attention as a species, but again, individuals vary. There’s no one syntax highlighting that works for everyone.

    Ultimately we should just find some syntax highlighting that we find generally pleasant, and then stick with it until we reflexively use the information carried in those colours. Use habit formation for our benefit.

    Tonsky may enjoy his garish background colour and have found a mushy colourscheme that works for him, but he’s also way off base in his assessment of colourschemes in general.

    • qqq@programming.dev
      link
      fedilink
      arrow-up
      4
      ·
      5 days ago

      garish background colour

      Honestly, thought this would be the only thing that people would talk about. I can’t bring myself to seriously read a blog post about syntax highlighting when presented with such a horrendous color scheme. I usually just dive right into firefox reader because 99% of the web is shit, and I guess I did only to look for some callout to the irony or trolling… “Yellow for comments” And I’m still not convinced it’s not trolling.

  • Jayjader@jlai.lu
    link
    fedilink
    arrow-up
    16
    ·
    6 days ago

    I find it much easier to find the function definitions when the word function is a different color than most of the surrounding text.

    if the author meant “find a specific function def according to it’s name or role” then I could at least appreciate the perspective. As it stands, I can’t help but notice that their supposed “better highlighting for finding defs” example is not using the same source code: the preceding anonymous immediately-invoked function that englobes the entire first code block/sample is now off-screen and the code blurb itself is different…

    • ignirtoq@fedia.io
      link
      fedilink
      arrow-up
      10
      ·
      6 days ago

      the preceding anonymous immediately-invoked function that englobes the entire first code block/sample is now off-screen and the code blurb itself is different…

      That bothered me a lot. Then I noticed in his second snippet, only function names were highlighted. What if I’m reviewing someone else’s code and I’m looking for magic strings/numbers that should be factored out as constants or parameters? The first block already has literal values a distinct color; does he expect me to change the syntax highlighting settings on my IDE for every task?

      • Jayjader@jlai.lu
        link
        fedilink
        arrow-up
        4
        ·
        6 days ago

        For what it’s worth, the second snippet is just to demonstrate their point about looking for function defs names. Reading the article until the end, they propose a bit more than just coloring function names where they are defined.

        I still don’t think the example proves their point, but let’s not misconstrue it either.

        • ignirtoq@fedia.io
          link
          fedilink
          arrow-up
          6
          ·
          6 days ago

          I honestly couldn’t get very far because his points were not as clear-cut as he was trying to imply and the tone was confrontational. I have a hard time being told I’m wrong on a matter of personal preference that is individually configurable , and where my choices have no impact on others’ experience.

          If he’s venting about his own experience, because the most common choices, which are defaults, don’t match his preferences, go right ahead. But don’t phrase it like anyone who disagrees with you can be demonstrated as objectively wrong with a few simple examples.

  • Kissaki@programming.dev
    link
    fedilink
    English
    arrow-up
    9
    arrow-down
    2
    ·
    edit-2
    5 days ago

    I strongly disagree.

    Coloring is categorization of code. Much like indent, spacing, line-breaking, aligning, it aids readability.

    None of the examples they provided looked better, more appropriate, or more useful. None of the “tests” lead me to question my syntax highlighting. Quite the contrary.

    By reducing the highlighting to what they seem important, they’re losing the highlighting for other cases. The examples of highlighting only one or two things make it obvious. When you highlight only method heads, you gain clarity when reading on that level, across methods, but lose everything when reading the body.

    I didn’t particularly like their dark theme choice. Their initial example is certainly noisy, but you can have better themes and defaults with more subtle and more equal strength colors. The language or framework syntax and spacing can also influence it.

    Bolding is very useful when color categorizes code to give additional structure discoverability, just like spacing does.

  • mormund@feddit.org
    link
    fedilink
    arrow-up
    16
    ·
    6 days ago

    Hm don’t agree with their choices, but interesting to read through the thought process. The more colorful theme seems more useful to me, even if I can’t remember the colors I use. I think its a VS code standard theme. I never really cared about customizing everything in general, I just keep what I found useful around.

  • Damarus@feddit.org
    link
    fedilink
    arrow-up
    8
    ·
    6 days ago

    The article is offering a strong opinion, which might be just because you get more engagement that way. I’m not offended by that, it’s just how the internet and media in general works.

    The thoughts about approaching syntax highlighting differently do intrigue me. I’m definitely playing around with my color theme in the coming days to see if something different suits me better.

    • codeinabox@programming.devOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      5 days ago

      The author does make some good points about colours as visual cues, instead of just making things look colourful. I have to admit prior to reading this post, I always picked my themes on aesthetics, but it has made me think about colour as utility.

      • esa@discuss.tchncs.de
        link
        fedilink
        arrow-up
        2
        ·
        5 days ago

        They are utility, as long as you don’t have a theme that randomly picks a new colour every time the token type changes.

        It’s a bit like having a bunch of different tools or utensils in separate colours. Even if the drawer is messy and the colour ultimately arbitrary, you can pick out utensils because you’re habituated to looking for a given colour.

        Just stick to one theme and you’ll get the same thing but for code. Theme hopping kills your habituation, and resets you to the “I can tell that these are different things because the colours are different” stage.

  • arty@feddit.org
    link
    fedilink
    English
    arrow-up
    3
    ·
    5 days ago

    I guess I’m one of the few here who uses pretty much the same approach with 4 colors as the author, with even another twist. I’m not saying I followed the same train of thought to come to this conclusion, but the names of my constants and functions are black, strings are green, and numbers are blue. The keywords and punctuation are gray to be less visible, not unlike in Python.

    The added twist is a nod in the direction of people saying the white background burns their retinas, but there are more background colors than blue and white. I chose a calm light-green one, which I also use whenever I’m reading texts. It’s not exactly the combination with the most points in the scientific readability research, but I remember that the dark background lost that competition.

    I attribute to these choices the fact that I notice many more typos in the code of my colleagues than they do in mine.

  • thingsiplay@beehaw.org
    link
    fedilink
    arrow-up
    10
    ·
    6 days ago

    The point of many colors is not that everything is important, but showing relationship and the “type” of code. I don’t think the less colored version is better (or worse) readable. It’s a preference.