• Juanjo Salvador@programming.dev
    link
    fedilink
    arrow-up
    6
    ·
    15 hours ago

    I understand the concept, but the autistic engineer I have inside is a bit uncomfy with the design of this pile, implying that AWS depends on Azure.

    • calcopiritus@lemmy.world
      link
      fedilink
      arrow-up
      12
      ·
      16 hours ago

      I cannot comprehend what the fuck harfbuzz does.

      I tried to implement my own because “I don’t need all the features, I’m gonna render self-to-right western text with very few font features”. But holly fuck, the font format documentation is barely non-existent. And when I tried my naive solution it was like 10000x (or more) slower than harfbuzz.

      • chellomere@lemmy.world
        link
        fedilink
        arrow-up
        6
        ·
        5 hours ago

        HarfBuzz does opentype shaping, that is, transforming strings of unicode characters to lists of glyphs with positioning. The significance of this can be hard to understand for someone used to the latin script, as that needs very little shaping - kerning is often the only thing that’s absolutely necessary.

        But in complex scripts, most notably the Indic, there’s a lot going on. Unicode characters can merge into one glyph under circumstances, or one character can split into several, and relative positioning in both the x and y axis is imperative.

        A reason that OpenType shaping is complex is that part of the rules for what to do will be found in the font, and part will need to be hard-coded in the code implementing it.

        If you’re going to roll your own text renderer, you’ll have to care about the following areas:

        • Rasterization/rendering to bitmaps, including hinting (notoriously difficult, old-style TrueType hinting instructions are bytecode, so you’ll be writing a tiny VM for this)
        • Shaping (Kerning at a minimum, full OpenType shaping for international support)
        • BiDi (for full international support, primarily Hebrew and Perso-Arabic)
        • A caching system for rendered text glyphs and shaped text runa, as it will be too slow to perform this each time you want to render some text

        Let’s just say that I do not recommend going this route unless you’re prepared to spend a lot of time on it.

        • calcopiritus@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          3 hours ago

          I’ve got all that. I just needed to convert a string of characters into a list of glyph IDs.

          For context, I’m doing a code editor.

          I don’t use harfbuzz for shaping or whatever, since I planned on rendering single lines of mono spaced text. I can do everything except string->glyphs conversion.

          Just trying to implement basic features such as ligatures is incredibly hard, since there’s almost no documentation. Therefore you can’t make assumptions that are necessary to take shortcuts and make optimizations. I don’t know if harfbuzz uses a source of documentation that I haven’t been able to find, or maybe they are just way smarter than me, or if fonts are made in a way that they work with harfbuzz instead of the other way around.

          As someone trying to have as little dependencies as possible, it is a struggle. But at the same time, harfbuzz saved me soo much time.

          EDIT: I don’t do my own glyph rasterization, but that’s because I haven’t gotten to it yet, so I do use a library. I don’t know if it’s going to be harder than string->glyphs, but I doubt so.

  • silver@das-eck.haus
    link
    fedilink
    English
    arrow-up
    14
    ·
    21 hours ago

    Definitely us-east-1 instead of 2, nobody (any fortune 500) has time for all that resiliency. Or even the patience for changing the region in the console. Ask me how I know

  • Justas🇱🇹@sh.itjust.works
    link
    fedilink
    arrow-up
    34
    ·
    1 day ago

    Cloudflare would be more like a leaf covering the image because you don’t need it to operate the stack, you need it to work in order to be able to see what it’s doing.