vmsp 2 days ago

There's an accompanying blog post at https://zserge.com/posts/fenster/

This author has some pretty cool stuff, like a tiny alternative to Firebase https://zserge.com/posts/pennybase/

  • unwind 2 days ago

    There is at least two bugs in the blog post, here:

    Next simple task would be to fill the complete framebuffer with a solid colour:

        memset(f->buf, rgb, f->width*f->height*sizeoof(uint32_t));
    
    The first is the obvious typo around `sizeof`, which I didn't even see at first (edit: this).

    The second is that code will only work for 8-bit colors, i.e. only the 8 (technically CHAR_BIT, "a byte") least-significant bits of `rgb` will be used. This is a quirk of the `memset()` standard C function, which has the prototype:

        void *memset(void s[.n], int c, size_t n);
    
    but then the man page [1] says:

    The memset() function fills the first n bytes of the memory area pointed to by s with the constant byte c.

    [1]: https://man7.org/linux/man-pages/man3/memset.3.html

    • naruhodo 2 days ago

      It will fill the screen with any of 256 shades of grey, for which r == g == b.

int_19h 2 days ago

That's not a GUI. It's something a GUI might be implemented in.

  • dragonwriter 2 days ago

    > That's not a GUI. It's something a GUI might be implemented in.

    A GUI library is indeed not a GUI, but a library with which one might implement a GUI.

    Usually, a GUI library does have things like actual controls implemented, but then most GUI libraries tend to present themselves as something closer to complete than most minimal.

    It is unusual but not unreasonable to describe the combination of cross-platform canvas + keyboard/mouse events + audio playback as the “most-minimal GUI library”.

    • benterix 2 days ago

      > A GUI library is indeed not a GUI, but a library with which one might implement a GUI.

      This definition basically blurs the distinction between a "GUI library" and "graphics library". A GUI library is GTK, QT and others. A graphics library is usually divided into 3D like *GL variants and 2D like SDL or Skia or thousands of others (including this one).

      • dragonwriter a day ago

        > A graphics library is usually divided into 3D like *GL variants and 2D like SDL

        OpenGL (what I assume you are referring to by *GL) is both 2D and 3D; it also, as one might expect of purely a graphics library, doesn't provide control events or audio and considers that something else's problem.

        SDL ("Simple DirectMedia Layer") does do things like control events and audio, but does not describe itself as a graphics library, but as "a cross-platform library designed to make it easy to write multi-media software, such as games and emulators."

      • layer8 a day ago

        It’s not just a graphics library because they provide cross-platform access to input events, timers, as well as audio playback.

        • int_19h a day ago

          So does SDL, but that's still not a GUI lib. I'm honestly not sure what the best term for that is.

          • benterix 16 hours ago

            In the past we used the term "multimedia library".

  • aa-jv 2 days ago

    Its a graphics primitive library, which can be used to implement a user interface.

vrighter 2 days ago

Where's the GUI part? This seems like a more limited SDL. There is literally zero GUI code in there, unless you count manually drawing individual pixels a GUI. The shape drawing example (NOT part of the library) shows code using the library to draw basic shapes pixel-by-pixel. That is the very thing a GUI library is supposed to do for you.

naruhodo 2 days ago

40 years ago, I cut my teeth on graphics programming in x86 assembly language and Turbo Pascal. Little graphical plots are just a really fun way to learn a language and programming concepts.

This is exactly what I want to practice some Zig programming.

CyberDildonics 2 days ago

Could be cool, but if it is supposed to be a single header file it should say that instead of 'minimal'.

Also if it's just about getting a single window up with a pixel buffer it should say that.

Top priority should be getting screenshots on the github landing page.

  • phtrivier 2 days ago

    The problem is that the title says "cross-platform GUI", so some people would expect, you know, a GUI - windows, menus, text, buttons, sliders, scrollbars, input fields, etc...

    This is more like a cross platform canvas on which you can draw.

    Raylib was my goto for that, but an alternative can't hurt, I guess ?

    • CyberDildonics a day ago

      I don't think this is an alternative to raylib. The whole single header file is 13KB. It is basically a window, rgb buffer, and keyboard+mouse input.

rmonvfer 2 days ago

Looks neat! I’m using C in a little side project and it would benefit from a simple GUI, let’s see what I can do with this. Also, just a recommendation but there isn’t even a single screenshot and I’d say that’s pretty important in a GUI library.

  • lstodd 2 days ago

    there are always tons of imgui-like libs.

kookamamie 2 days ago

A windowing library, not a GUI library.

  • aa-jv 2 days ago

    A graphics primitive library, not a windowing library.

socalgal2 2 days ago

> API is designed to be a polling loop

IMO this is a mistake. The most popular platform in the world does not allow using a polling loop. You can hack things to simulate it but eventually you'll run into where this will break for you. Better to start with something more forward compatible.

  • CyberDildonics 2 days ago

    The most popular platform in the world does not allow using a polling loop

    I don't know what that means, but just because something else doesn't use a polling loop doesn't mean it's a mistake or the wrong fit.

    Something like this so simple there is likely to be a lot that gets done inside the main loop, not the least of which is drawing into the buffer which is most of the point.

  • IcyWindows 2 days ago

    Which one are you referring to?

    • gt0 2 days ago

      I'm assuming they mean the web.

  • animuchan 2 days ago

    Does it really not support this though? I imagine this could be made to work in a WebWorker for example, where you can run the busy loop, and actively let it ingest new messages each iteration.

  • adastra22 2 days ago

    I assume you mean the web? I’m not sure why that’d be relevant to a C library.

    • socalgal2 2 days ago

      The Web runs C via WebAssembly, but if you're porting a polling loop app you're going to have a bad time. Conversely, if you start with an event driven app then you lose nothing but gain portability.

      • hyperhello 2 days ago

        Okay -- this code is pathologically minimal. If you modify it to use events on the web, will your work extend to all the other platforms?

        • socalgal2 a day ago

          Yes, because it's trivial to make an event based loop from a polling loop but not visa-versa. The difference is that an event based loop needs to give up control to the OS. A polling loop does not. So if you have a polling OS you just write few lines to emit your own loop event.

  • vrighter 2 days ago

    Good thing this isn't a library designed for the web then! What's your point here? SDL (this project seems to be a subset of it, in terms of functionality) also uses a polling loop, and it's one of the most popular libraries of this sort around.

  • Zardoz84 2 days ago

    why hell would you use a c library to make a gui on the web when you have HTML ?

    • animuchan 2 days ago

      This can be a forward compatibility concern: imagine we run a company, and our product is a GUI app written in C or C++.

      If we also believe that the desktop GUI apps are a thing of the past, and in the future everyone wants only web apps, we'd want to pick a C library for the UI which allows building for the web, for the future scenario where we have to port the app to stay relevant.

      The scenario might not materialize, but having a contingency plan sure feels nice.

    • dardeaup 2 days ago

      Maybe it was a personal goal?

Surac 2 days ago

not connected to this, but i wish i would find a c code example on how to draw a line with a width, without antialias while only setting each pixel once. this seems to be a real hard problem.

lelanthran 2 days ago

> Fenster /ˈfɛnstɐ/ -- a German word for "window".

Same in Afrikaans as well - "venster"[1] means window.

  • porphyra 2 days ago

    That's not surprising as Afrikaans is highly related to Dutch which is in turn highly related to German. In this case it all comes from the Latin fenestra.

    • kristianp 2 days ago

      > Latin fenestra.

      Hence defenestrate, to throw out the window.

  • jraph 2 days ago

    Fenêtre in French.

    Funny, English words often come from either German or French. Here where German and French agree, English is different.

    https://en.wiktionary.org/wiki/window#Etymology (missing sources as of right now)

    • memsom 2 days ago

      Ah - you are conflating Germanic for German. Germanic is not equivalent to German. German (deutsch) is a national language, Germanic is a language family. German belongs to this family, but it is not the root of all Germanic languages. English and German sit in the West Germanic branch, the East Germanic was mostly Gothic (dead) and the North Germanic languages are Swedish/Danish/Norwegian/Icelandic/Faroese and various other non national languages. English is a West Germanic language, but it was massively influenced by Old Norse (North Germanic) and various Frenches (and Latin/Greek in technical terms) as well as probably the native British languages somewhat in grammar (the present continuous tense in English also happens in Welsh, and is not very Germanic.)

      So - Window is Germanic. It comes from Old Norse 'vindauga', and the modern Norwegian Bokmal version is 'vindu'[1].

      The German word for Window comes from Latin [2].

      [1] https://en.wiktionary.org/wiki/vindu

      [2] https://en.wiktionary.org/wiki/fenster

      • jraph 2 days ago

        yeah, ok, my picture of these things was a bit simplistic, thanks for the correction and the details!

  • darccio 2 days ago

    Finestra in Catalan, and Langas in Lithuanian.

  • brabel 2 days ago

    Fönster in Swedish.

  • dvh 2 days ago

    Okno in Slovak

thisislife2 2 days ago

I chuckled at, "And, yes, it can run Doom!"

  • Forgret 2 days ago

    Hahaha, so it makes sense that DOOM can be run anywhere.

armitron 2 days ago

This can be more accurately described as a hack: there are subtle bugs (e.g. CLOCK_REALTIME is not monotonic) and corner cases that are not taken into account that I can't find any strong reasons to recommend this. One would be better served by something like SDL or raylib or if minimalism is a strict requirement, RGFW [1].

[1] https://github.com/ColleagueRiley/RGFW/blob/main/RGFW.h

fitsumbelay 2 days ago

no single facet of this that I don't love

ijidak 2 days ago

This is exciting. This is great for data visualization and financial applications!