Becoming friendlier to desktop users is one of the goals of the FreeBSD project at the moment, as we recently saw with the new ability to install a full KDE Plasma desktop environment during FreeBSD’s initial installation. This is just one small piece of a larger effort, though, to improve, modernise, and possibly even replace the current FreeBSD installer entirely. As such, Pierre Pronchery, a Security Engineer for the FreeBSD Foundation and member of their team as a Userland Software Developer, published a blog post today with more information around this effort.
The article goes into great detail to compare the installation procedures of other operating systems to that of FreeBSD, and the conclusion is that FreeBSD is lagging behind in quite a few areas. Among other shortcomings, the FreeBSD installer has no support for different languages, very little accessibility features, no niceties like progress bars or lists of steps, and most notably, no graphical mode. Some of these are already being addressed.
The current FreeBSD installer (a combination of bsddialog, bsdconfig, and bsdinstall) consists of a number of shell scripts with some small C programs here and there, and the downside of this is that this is really only suitable for creating very basic steps and user interfaces. As an example, Pronchery mentions values during network setup, like network mask, DNS server or gateway, can’t be prepopulated with the most likely values, which puts quite a burden on the user. This specific issue is being worked on by one of the original creators of bsddialog, and the solution they settled on is adding Lua scripting, which would give developers an avenue to fix some of these shortcomings.
As far as a possible graphical installer goes, Pronchery looked at the various options out there, both from the Linux world and the few graphical installers that exist for a few desktop-oriented FreeBSD distributions, but for a variety of reasons, none of them proved to be particularly suitable for FreeBSD. As such, Pronchery created a quick proof-of-concept for a graphical installer by implementing bsddialog as a GTK+ application which he calls gbsddialog. It’s important to note that this proof-of-concept is not suitable for FreeBSD, as GTK+ is licensed under the LGPL, but it does illustrate that by “simply” reimplenting bsddialog using a graphical toolkit, you can get quite a long way to a usable FreeBSD installer that mimics the traditional installer quite well.
The article covers a number of other topics, such as setting up a development environment to make it more straightforward and easier to work on the FreeBSD installer, as well as various steps that need to be taken to improve the accessibility of the installer. It concludes with a mention of the possibility of a complete rewrite of the installer, but such decisions are of course not made by a single person and require a lot more discussion and input.
Regardless, the amount of work being done to improve FreeBSD for generic desktop use is exciting, as we need a viable, competitive alternative to that other open source desktop operating system.


By FreeBSD standards, the number of balls they have in the air seems absolutely dizzying. It is great to see but I hope they do not lose the attributes that appeal to their users today. If they go for a GUI installer, for example, I hope they leave text mode as an option.
If they need a GUI toolkit, maybe this would work for them:
https://github.com/Immediate-Mode-UI/Nuklear
I wish they used something modern like Dioxus then.
@a_very_dumb_nickname
I had not heard of Dioxus. Thank you for that.
It is hard to understand what a Dioxus app looks like at first read through their material. At least the license looks compatible. Apache 2.0 should be ok to ship with FreeBSD. Is there any other Apache 2.0 stuff in the core FreeBSD? There is LLVM of course but it has an exception clause.
Text mode installer will always be an option. FreeBSD is one of the more conservative OSes out there, and the majority of their use case is servers and network appliances. This push for workstation and laptop QoL changes is awesome and long overdue, but it won’t be at the expense of where the OS really shines.
“It’s important to note that this proof-of-concept is not suitable for FreeBSD, as GTK+ is licensed under the LGPL”
I don’t get it. They’re running KDE Plasma, which has a GPL license, so why would GTK+ not be suitable?
@Munchkinguy
KDE is entirely optional. I think they are saying LGPL is not suitable for anything in the core system (mandatory).
I mean, GhostBSD has this perfectly solved.
I wonder why can’t they merge/absorb GhostBSD?
I understand GhostBSD exists because FreeBSD was not interested in being user friendly, but if they want it now, wouldn’t it make more sense to merge?
@kwanbis
I like me some GhostBSD. That said, there are actually quite a few little differences between the projects at this point. GhostBSD does not bundle dev tools or ports, ships with OpenRC, runs a MATE desktop, has a GUI package manager with its own repositories, ships with quite a few GPL software packages, and maybe more.
I am not that much into the details. What I can tell you is that GhostBSD is the only BSD I was able to install as easily as Linux, without having to go through university course, like with FreeBSD. That said, and I might be wrong, I doubt that at a minimum they can not base their installer of GBSD. And MATE is perfect, although I prefer XFCE.
GhostBSD no longer uses OpenRC. It switched back to FreeBSD’s init awhile back.