It’s possible and there isn’t any technical limitation for this other than the language used and its likely to be an out-of-tree implementation due to the Haiku API being only accessible via C++ whereas GTK/GDK appears to accept C-based implementations. (Parts of the Quartz implementation are in Objective-C).
It’s unlikely that it will be ever upstreamed if someone does this anyway, but then again that could change.
One of problems in porting GTK3 it that it display window border themselves, but Haiku display window border in app_server. Default GTK3 theme also use window semi-transparency that is not supported by app_server.
One thing to be aware of when doing these things is that in Haiku a window is always a separate thread running its own event loop. If GTK expects all callbacks to happen in the main thread instead, you need to somehow forward events between the two threads.
Drawing strategy can also be a concern, normally in Haiku there is no buffering, apps draw directly to the framebuffer and need to be able to redraw any part at any time on request from the app_server. If that doesn’t work for GTK, you will need to have it draw offscreen to a BBitmap and have code to copy data from that BBitmap to the display. It has been done (for example in WebKit and in the LibreOffice native backend, and I guess probably in the Qt backend as well).
So, nothing impossible, it’s just quite some work and there are these caveats to know about.
3dEyes, this is unbelievably epic! VERY nice work! I’d glanced at GTK before, myself, but the C OOP was just too much for my tastes… and it already even looks native, wow!
How long before we have GIMP? Maybe in time for beta2?
GIMP 2.10 can run against GTK3 already. I think it is slightly less stable and not “officially supported”, but it is handled out of the box so far as I know. Same for Inkscape.
It is still very early to port GIMP.
There is no mouse, keyboard, window styles and everything else)
Right now there are only windows and surface rendering.