Skip to content

Welcome to Planet KDE

This is a feed aggregator that collects what the contributors to the KDE community are writing on their respective blogs, in different languages

Saturday, 31 January 2026

Welcome to a new issue of This Week in Plasma!

This week we reached that part of every Plasma release cycle where the bug fixes and polish for the upcoming release are still coming in hot and heavy, but people have also started to land their changes for the next release. So there’s a bit of both here!

Everyone’s working really hard to make Plasma 6.6 a high-quality release. It’s a great time to help out in one way or another, be it testing the 6.6 beta release and reporting bugs, or triaging those bugs as they come in, or fixing them!

Notable New Features

Plasma 6.7.0

The Emoji Selector window now lets you choose mixed skin tone groupings of emojis using a nice little user-friendly pop-up dialog. (Tobias Ozór, plasma-desktop MR #3426)

You’re now able to set a global keyboard shortcut to clear the notification history. (Taras Oleksyn, KDE Bugzilla #408995)

Notable UI Improvements

Plasma 6.6.0

In the Application Dashboard widget, keyboard focus no longer gets stolen by selectable items that happen to be right under the pointer at the moment the widget is opened. (Christoph Wolk, KDE Bugzilla #510777)

Breeze-themed checkboxes now always have an opaque background, which resolves an issue where their unchecked versions could be hard to see when overlaid on top of images. (David Redondo, KDE Bugzilla #511751)

Plasma 6.7.0

System Settings’ subcategory back button is now more of a traditional back button, eliminating a source of redundant page titles. There are still too many, but this reduces the count by one! (Nate Graham, systemsettings MR #390)

On System Settings’ Notifications page, you can now always preview a notification sound even if sound is currently disabled for that notification. (Thomas Moerschell, plasma-workspace MR #6214)

Plasma’s network settings now expose additional L2TP VPN options that were previously unavailable. (Mickaël Thomas, plasma-nm MR #480)

The old Air Plasma style (a lighter take on the original Oxygen style) is back, with fixes and improvements, too! (Filip Fila, oxygen MR #77)

The Oxygen cursor theme received a small visual fix to improve the appearance of the busy cursor. (Filip Fila, oxygen MR #89)

The cursor theme settings now show more accurate previews, which fixes issues like wobbling cursors, and makes the preview grid feel more stable. (Kai Uwe Broulik, plasma-workspace MR #6240)

System Settings’ various theme chooser pages are now consistent about whether you can delete the active theme (no), and also let you know why certain themes can’t be deleted: because they were installed by the OS, not the “get new stuff” system. (Sam Crawford, plasma-workspace MR #6222)

The Weather Report widget now shows a progress indicator while its popup is open but still loading the weather forecast from the server. (Bogdan Onofriichuk, kdeplasma-addons MR #993)

Frameworks 6.23

Combobox pop-ups through QtQuick-based apps and System Settings pages now use the standard menu styling, rather than a custom style. (Nate Graham, qqc2-desktop-style MR #497)

Added styling for the new upstream SearchField component that was recently added to QtQuick itself. Now it looks like the KDE version that we created years ago before the Qt version existed. (Manuel Alcaraz Zambrano, qqc2-desktop-style MR #500)

Notable Bug Fixes

Plasma 6.5.6

Fixed an issue on operating systems with asserts turned on (like KDE neon) that could sometimes crash Plasma when you launched apps. (David Edmundson, KDE Bugzilla #513312)

Plasma 6.6.0

Fixed a rare issue that could leave KWin without control of the mouse and keyboard at login. (Vlad Zahorodnii, KDE Bugzilla #511611)

Fixed a case where Plasma could crash when moving around a Weather Report widget on the desktop. (Bogdan Onofriichuk, KDE Bugzilla #514200)

Fixed an issue in Discover when launched with Snap support that could prevent it being launched again after previously being closed. (Aleix Pol Gonzalez, KDE Bugzilla #507217)

Fixed a case where the Plasma Bluetooth pairing wizard would fail to pair devices. (David Edmundson, KDE Bugzilla #495615)

The logout screen no longer fails to take focus if you raised the focus stealing level to “Medium” or higher, and manually de-focusing it no longer breaks your ability to re-focus it. (Vlad Zahorodnii, KDE Bugzilla #514204 and Aleksey Rochev, KDE Bugzilla #511258)

The custom size ruler for Plasma panels no longer sometimes appears on the wrong screen of a multi-screen setup. (Vlad Zahorodnii, plasma-workspace MR #6215)

The “X notifications were received while Do Not Disturb was active” notification is no longer inappropriately saved to the notification history. (Kai Uwe Broulik, plasma-workspace MR #6223)

Fixed two semi-related issues with widgets that made them not let you pick the same color after deleting it, or configure the same mouse action after deleting it. (Christoph Wolk, KDE Bugzilla #514983 and KDE Bugzilla #449389)

The global menu on a newly-cloned panel on a different screen now realizes immediately that it’s on a new screen. (David Redondo, KDE Bugzilla #514907)

Discover’s notification about ongoing updates no longer displays a nonsensically large number of updates under certain circumstances. (Harald Sitter, KDE Bugzilla #513676)

Plasma Browser Integration no longer exports Microsoft Teams calls as controllable media sources; it always omitted them in the past, but Microsoft changed the URL again, so we had to adapt to that once more. (Kai Uwe Broulik, KDE Bugzilla #514870)

You can now move focus from the Application Dashboard widget’s search field using arrow keys, and also type accented characters using dead keys or the compose key as the first character in a search while the search field isn’t explicitly focused. (Christoph Wolk, KDE Bugzilla #511146 and KDE Bugzilla #510871)

Animated wallpapers explicitly set for the lock screen now play their animation as expected. (Taras Oleksyn, KDE Bugzilla #460910)

Undoing the deletion of a panel widget no longer sometimes positions it far from where it was before. (Marco Martin, KDE Bugzilla #515107)

Ending the renaming of an item on the desktop by clicking on another item no longer starts a drag-selection for no good reason. (Akseli Lahtinen, KDE Bugzilla #514954)

The “Defaults” button on System Settings’ Accessibility page now works properly to reset non-default colorblindness modes. (Andrew Gigena, KDE Bugzilla #513489)

Plasma 6.7.0

Fixed a very nasty KWin bug that could, under certain rare circumstances relating to intensive Alt+Tab usage, cause the screen to go black. This change may be backported to Plasma 6.6 if it’s deemed safe enough. (Xaver Hugl, KDE Bugzilla #514828)

Frameworks 6.23

Fixed being unable to paste clipboard entries as text that were copied from a LibreOffice Calc spreadsheet cell and then re-arranged in the clipboard history list. (Alexey Rochev, KDE Bugzilla #513701)

Notable in Performance & Technical

Plasma 6.6.0

KRDP (the KDE library for remote desktop support) no longer requires systemd. (David Edmundson, krdp MR #141)

Plasma 6.7.0

KWin now supports the ext-background-effect-v1 Wayland protocol. This adds support for standardized background effects like blur, opening the door for visual consistency across apps using these effects. (Xaver Hugl, KWin MR #4890)

How You Can Help

KDE has become important in the world, and your time and contributions have helped us get there. As we grow, we need your support to keep KDE sustainable.

Would you like to help put together this weekly report? Introduce yourself in the Matrix room and join the team!

Beyond that, you can help KDE by directly getting involved in any other projects. Donating time is actually more impactful than donating money. Each contributor makes a huge difference in KDE — you are not a number or a cog in a machine! You don’t have to be a programmer, either; many other opportunities exist.

You can also help out by making a donation! This helps cover operational costs, salaries, travel expenses for contributors, and in general just keep KDE bringing Free Software to the world.

To get a new Plasma feature or a bugfix mentioned here

Push a commit to the relevant merge request on invent.kde.org.

Friday, 30 January 2026

Continuing previous efforts to update the “secure passwords” story of the Plasma desktop, I’ve done some integration work between Plasma and oo7.

Oo7 is a relatively recent SecretService provider written in Rust; it’s very nice, lightweight and cross-desktop. Very interesting for us supporting it as a first class citizen.

We want in the end to replace completely the old KWallet system with something based on SecretService, have all our applications migrated transparently with user data as well, if possible with a cross-desktop backend implementation.

We also want it to be as transparent as possible for the end user, not having any complicated first time setup, or dialogs that ask for a manual unlock when not needed. For the user, the whole system should be just invisible, except when looking up their passwords or when client applications add passwords to it themselves.

As a first thing several months ago we did a transparent translation layer for the KWallet DBus interface, so now the “KWallet” service became just a translation layer between the kwallet api and the secretservice one.

The old kwalletd service instead became “ksecretd” now providing only the SecretService interface, and that’s what we use by default now. however, it can be configured to use a different provider, so it can already be used with gnome-keyring or KeepassXC if the user wishes. In that case the user data will be migrated the first time.

Also I’ve written a new application called KeepSecret. It is centered around SecretService, with a much more modern UI compared to KWalletManager and works also much better on mobile, so we can have also a modern password manager on Plasma Mobile.

KeepSecret running with the oo7 backend, with a native password dialog

The last thing that we did so far is integration with a new SecretService provider on the block: oo7.

If oo7 is Just another SecretSerive provider, Won’t it “just work” in Plasma? Not quite, but that’s actually a good thing. Oo7 wants to properly integrate with the environment it runs in, so we need to build that integration.

When you use KWallet, KeepassXC, or gnome-keyring directly, they create their own password dialogs using their own toolkits and styles, therefore potentially looking a bit alien when run in a different environment than the one it it was designed for.

This is not ideal for evaluating options for a possible future replacement of KWallet (which piece by piece we are working towards), as we want the UI part completely integrated with the Plasma desktop.

Instead, oo7 is built on the assumption that the environment it runs on will provide its own dialogs, a bit like the portal system for services like screen sharing and file picking.
This requires active integration both on the Plasma part and the oo7 part, but on the other hand it will look native on Plasma, Gnome, and any other platform that implements the integration hooks. And that’s with the added benefit of sharing the password storage if someone every now and then goes desktop environment hopping.

On the Plasma side we decided to employ a very small daemon which is launched only on demand with dbus activation. It will create the needed system dialogs, pass the user input back to oo7 and then quit when not needed anymore, so it won’t constantly use up system resources.

This is already available in Plasma 6.6: the code for it is here. It’s designed first for oo7, but it can be used by any daemon which wishes to provide native password dialogs, so we might start to use it also from other components in the future, either other SecretService providers or completely different things which have similar needs like Polkit.

On the oo7 part, Harald implemented the integration with its dbus interface, so with oo7 from main branch (or its next release) it can be used in place of KWallet (with all old applications still using the KWallet API using its backend as well), with all data migrated to it, and it will show native UI for its password dialogs… all the pieces of the puzzle slowly falling together 🙂

Needless to say this is still at an experimental stage, but it’s an important milestone in getting more independent from the aging KWallet infrastructure.

Let’s go for my web review for the week 2026-05.


Neocities Is Blocked by Bing

Tags: tech, web, search, microsoft, vendor-lockin

Huh? What’s going on there? I don’t see why they would exclude this domain completely, it makes no sense.

https://blog.neocities.org/blog/2026/01/27/bing-block


The Enclosure feedback loop

Tags: tech, ai, machine-learning, gpt, copilot, enclosure, vendor-lockin

Interesting point. As we see the collapse of public forums due to the usage of AI chatbots, we’re in fact witnessing a large enclosure movement. And it’ll reinforce itself as the vendors are training on the chat sessions. What used to be in public will be hidden.

https://michiel.buddingh.eu/enclosure-feedback-loop


No, Cloudflare’s Matrix server isn’t an earnest project

Tags: tech, ai, machine-learning, copilot, matrix, cloudflare, security, failure

Very in depth review of the mess of a Matrix home server vide coded at Cloudflare… all the way to the blog announcing it. Unsurprisingly this didn’t go well and they had to cover their tracks several times. The response from the Matrix foundation is a bit underwhelming, it’s one thing to be welcoming, it’s another to turn a blind eye to such obvious failures. This doesn’t reflect well on both Cloudflare and the Matrix Foundation I’m afraid.

https://nexy.blog/2026/01/28/cf-matrix-workers/


I Was Right About ATProto Key Management

Tags: tech, social-media, bluesky, decentralized

Indeed, it just can’t be called decentralized…

https://notes.nora.codes/atproto-again/


Microsoft Gave FBI BitLocker Encryption Keys, Exposing Privacy Flaw

Tags: tech, microsoft, security, privacy

Are we surprised? Of course not… As soon as you backup the keys on someone else’s server BitLocker can’t do anything to ensure privacy.

https://www.forbes.com/sites/thomasbrewster/2026/01/22/microsoft-gave-fbi-keys-to-unlock-bitlocker-encrypted-data/


ICE takes aim at data held by advertising and tech firms

Tags: tech, advertisement, surveillance, politics, privacy

What a surprise… No really who would have expected this could happen? I heard so many times “I have nothing to hide” over the years. When something like this happens you suddenly wish you were a bit more careful with your privacy and the privacy of the people around you.

https://www.theregister.com/2026/01/27/ice_data_advertising_tech_firms/


The Rise of Sanityware

Tags: tech, privacy, surveillance, attention-economy

Those are indeed getting more popular. In a way that’s unfortunate, we shouldn’t need them so much.

https://thatshubham.com/blog/2026


Blogs Are Back

Tags: tech, rss, blog, tools

Looks like a nice tool to help people to get into RSS.

https://www.blogsareback.com/


Places to Telnet

Tags: tech, networking, funny

Telnet is not dead! We still have fun places to turn telnet clients to.

https://telnet.org/htm/places.htm


10 Years of Wasm: A Retrospective

Tags: tech, web, standard, webassembly, history

Nice retelling of the story behind WebAssembly.

https://bytecodealliance.org/articles/ten-years-of-webassembly-a-retrospective


cppstat - C and C++ Compiler Support Status

Tags: tech, c++, standard, tools

Looks like an interesting tool to follow availability of C++ features in compilers.

https://cppstat.dev/


Why I still teach OpenGL ES 3.0

Tags: tech, graphics, teaching, learning

Good point, it is old but portable and carries the important concepts. This is a good teaching vehicle. Even though it’s unlikely you’d use it in the wild much longer.

https://eliasfarhan.ch/jekyll/update/2026/01/27/why-i-teach-opengles.html


SPAs Are a Performance Dead End

Tags: tech, web, frontend, performance

It’s a solution for a problem long gone. SPAs should be the exception for highly interactive applications not the norm. Most web applications don’t need to be a SPA and would be better off without being one.

https://www.yegor256.com/2026/01/25/spa-vs-performance.html


Functional Core, Imperative Shell

Tags: tech, functional, architecture, tests, tdd

Clearly not a style which works for any and every applications. Still, it’s definitely a good thing to aim towards such an architecture. It brings really nice properties in terms of testability and safety.

https://www.destroyallsoftware.com/screencasts/catalog/functional-core-imperative-shell


How I estimate work as a staff software engineer

Tags: tech, estimates, decision-making

The approach is interesting. I wouldn’t assume it’s doable in every contexts though. What’s sure is that you need to embrace the uncertainty and accept to go with the exercise. Estimates are needed to make decisions and help teams to sync.

https://www.seangoedecke.com/how-i-estimate-work/


Is It Worth It?

Tags: tech, failure, organisation, estimates

Solving paper cuts pay off faster than you’d think.

https://griffin.com/blog/is-it-worth-it


Things I’ve learned in my 10 years as an engineering manager

Tags: tech, engineering, management, leadership

Nice advice, there’s a lot of variation on the role. And yet, some things seem to always be there.

https://www.jampa.dev/p/lessons-learned-after-10-years-as


Because coordination is expensive

Tags: tech, team, organisation, communication, complexity

The complexity and cost in organisations is indeed mostly about coordination. This is a difficult problem and largely unsolved in fact.

https://surfingcomplexity.blog/2026/01/24/because-coordination-is-expensive/


Douglas Adams on the English–American cultural divide over “heroes”

Tags: culture

The contrast is indeed very stark. I got my own bias and fondness for heroic failures.

https://shreevatsa.net/post/douglas-adams-cultural-divide/



Bye for now!

 

It's that time of year again; another Qt World Summit is approaching! We are looking for speakers, collaborators, and industry thought leaders to share their expertise and insights at the upcoming Qt World Summit 2026 on October 27-28, in Berlin, Germany. 

*Please note we are looking for live talks only

 

In the past two months since the previous report KDE Itinerary got new vector-based map views and manual control over reservation cancellations, and there has been more work on reverse engineering proprietary train tickets, among many other things.

New Features

Vector maps

The map views can now use a MapLibre-based vector map instead of the previous raster image map. This gives us smoother and continuous zoom, and should also allow localized labels eventually, something particularly important in regions you can’t even read the local script.

Screenshot of Itinerary showing a full-screen MapLibre map with two event locations marked on it.
Vector-based map view in Itinerary.

This is enabled in our nightly APK and Flatpak builds, other distribution channels might not have this enabled yet.

Reservation cancellation

It’s now possible to manually mark reservations as canceled, rather than just importing that information from documents. This is useful for keeping unused reservations around but not have them considered for transfers, in the maps or for statistics, e.g. because you still need them for refund claims or travel cost reimbursement.

Screenshot of part of Itinerary's reservation editing page, showing a checkbox to toggle the cancellation state.
Manually changeable cancellation status.

Canceled reservations are now also clearly marked as such in the timeline view again, something that had gotten lost in the last timeline restyling.

Infrastructure Work

Ticket barcode reverse engineering

Ticket barcodes can contain machine-readable information about the trip and can therefore be very useful for importing tickets into Itinerary. While ticket barcodes on international trips commonly use openly standardized formats for interoperability between different providers, this is unfortunately often not the case for domestic tickets. For those we have to resort to reverse engineering.

Fortunately though, there’s more people interested in what’s in those barcodes, e.g. from a privacy or security perspective, and there’s increasing collaboration.

Specifically, the understanding of the Hungarian domestic ticket format has significantly increased recently, as the result of three different parties exchanging their observations and evaluating their respective findings against each other’s ticket sample pools. A few few magic numbers for product/tariff/discount codes are yet to be figured out, but there’s now a pretty complete Kaitai spec able to decode versions 2 to 6 of the current format, e.g. using the Kaitai Web IDE.

Many of the discoveries made there have a resulted in improvements and fixes for MÁV and Volánbusz tickets in Itinerary.

Documentation on ticket barcodes formats is also slowly being consolidated in the Train Ticket Wiki, where available also in appropriate machine-readable formats (Kaitai, Protobuf, ASN.1, etc).

Reverse geocoding for location codes

The work on automatic geocoding for train and bus reservations covered in the last report has been further expanded:

  • Hotel and restaurant reservations are now also automatically geocoded. This makes automatic transfers work in more cases.
  • Reverse geocoding on imported tickets only containing train station or airport codes is now also supported. This for example results in proper station names when scanning a train ticket barcode that only contains station codes.

Events

There’s two recent events that covered upcoming changes to Transitous, the public transport routing service used by Itinerary:

And more opportunities to meet the Itinerary and Transitous teams are coming up:

Fixes & Improvements

Travel document extractor

  • Added or improved travel document extractors for Booking.com, České dráhy, Cytric, Deutsche Bahn, gomus, KLM, MÁV and Volánbusz.
  • Fixed a crash on referenced but non-existent PDF image masks (bug 513945).
  • Handle RSP6 decoding failures properly, fixing a few fields containing “null” in that case.
  • Added support for resolving Hungarian railway station codes.
  • Added support for local SNCF pass barcodes in some regions of France.

All of this has been made possible thanks to your travel document donations!

Public transport data

  • Added (partial) coverage in Japan and Thailand thanks to Transitous.
  • Fixed access parameters to the VVS API for the Stuttgart area in Germany.

All of this also directly benefits KTrip.

Itinerary app

  • Mark cancelled intermediate stops on the journey section map.
  • Don’t allow to open an empty place context menu.
  • Show yearly sections for past trip groups in the trip group list.
  • Fix showing entrance date picker for events without valid start date.
  • Fix a timer overflow when monitoring for delays for trips in the slightly more distant future.
  • Fixed several issues following from inconsistent ordering of timeline entries, such as two elements starting at exactly the same time and having no defined end time. This could reesult in duplicate or lost timeline entries under some circumstances.
  • Correctly reset the trip group name field after closing the rename dialog.
  • Fix overly aggressive input validation on manually entered flight numbers.
  • Continous Flatpak builds for testing the latest development version are now also available for ARM64.

How you can help

Feedback and travel document samples are very much welcome, as are all other forms of contributions. Feel free to join us in the KDE Itinerary Matrix channel.

After some more nights spent with our beloved Bouncy Ball, I'm happy to announce that a new version is out on the KDE Store. Last week in Bouncy Ball | KDE Store page Prior to getting down and dirty with it, I again had at a look at how the ball was implemented in KDE4...... Continue Reading →

Thursday, 29 January 2026

Screenshot of Kaidan in widescreen Screenshot of Kaidan

Welcome Kaidan 0.15.0! This release adds experimental support for calls. In addition, it contains some very useful improvements and lots of fixes.

Most of the work has been funded by NLnet via NGI Zero Entrust and NGI Zero Commons Fund with public money provided by the European Commission.

Audio/Video Calls

Kaidan has supported voice and video messages for a long time. Starting with this release, you can even have an audio or video call with a contact! An incoming call is indicated via a notification and you can either accept or reject it.

Please note that there are still some features missing and some setups may not work properly. Especially, calls are only supposed to work on Linux at the moment. But wee wanted to share the current achievements with you to get some feedback! Our goal is to extend the A/V calls functionality and make it available on other operating systems in the future.

Audio/Video calls

Notifications for Group Chat Replies

Formerly, you got a notification if someone mentioned you in a group chat while the corresponding setting was enabled. But you could miss replies to your messages. Kaidan notifies you now on receiving replies as well.

Message Input Field Focusing

In contrast to the soft keyboard on a mobile device, which needs to be opened each time you want to enter something, your keyboard is always reachable on a desktop device. Why not make use of that circumstance? Kaidan ensures that the most relevant message input field stays focused to allow entering text without an additional click into the corresponding field. That way, you can interact smoothly with the user interface and be more productive.

Advanced Message Highlighting

Kaidan 0.14 introduced highlighted messages if you opened their context menu. Messages are now also highlighted while they are being corrected or while you are choosing emojis to react to them. If another message was already highlighted before, that message is highlighted again once you sent the correction/reaction.

Advanced message highlighting

Integrated Search Field

With Kaidan, you can quickly search for chats and messages. But while searching for messages, the opened search bar reduced the space for messages. On mobile devices, the search bar even consumed unnecessary space within the chat list. Both problems are solved now! The search field is integrated into the main toolbar above the messages resp. the chat list. You can even focus each search field via an own keyboard shortcut to directly search without moving the cursor.

Integrated search field

Password Manager Fallback

Since Kaidan’s last version, passwords are stored in a password manager if the system provides one. But there was no fallback yet. It is now possible to use Kaidan even if no password manager is available. In that case, the passwords are stored in an unencrypted file. Once Kaidan detects a password manager on start, the unencrypted passwords are automatically migrated to the password manager.

Changelog

There are several other improvements. Have a look at the following changelog for more details.

Features:

  • Add support for audio/video calls (XEP-0166: Jingle, XEP-0167: Jingle RTP Sessions, XEP-0176: Jingle ICE-UDP Transport Method, XEP-0215: External Service Discovery, XEP-0320: Use of DTLS-SRTP in Jingle Sessions, XEP-0353: Jingle Message Initiation) (@melvo)
  • Show busy indicator while saving captured image/video data (@melvo)
  • Notify on receiving reply to own group chat message if ‘On mention’ notification setting is enabled (@melvo)
  • Select file after opening in folder on Linux if supported (@melvo)
  • Improve media capturing look/behavior (including preview after capturing image until image is saved) (@melvo)
  • Restore focusing of last focused user interface elements (especially message input field) for various use cases (@melvo)
  • Keep message bubble highlighted on reacting/correcting (@melvo)
  • Allow to select message for correction via Ctrl+Up/Ctrl+Down (@melvo)
  • Integrate search field into main toolbar increasing space for messages and, on mobile devices, even for chats in chat list (@melvo)
  • Show message search field via Ctrl+Shift+F (@melvo)
  • Display toolbar buttons on mobile devices exactly as on desktop devices (@melvo)
  • Hide horizontal separator above top-most chat unless chat list is scrolled (@melvo)
  • Store passwords in unencrypted file if no password manager is available or corresponding command-line option provided (@fazevedo)
  • Migrate unencrypted passwords to password manager if available on start (@fazevedo)

Bugfixes:

  • Fix overlapping message bubble tail (@melvo)
  • Fix medium preview hovering if hidden drop area info is hovered (@melvo)
  • Fix updating OMEMO 2 keys for all use cases (@melvo)
  • Fix deadlock on logout during upload of multiple files (@melvo)
  • Fix creating additional database connection on wrong thread (@melvo)
  • Fix sending/resetting whether message is being composed for various corner cases (switching chat, logging out, disabling corresponding setting) (@melvo)
  • Fix updating last message on receiving initial message after setting up existing account in Kaidan for first time (@melvo)
  • Fix resetting draft message after canceling message correction (@melvo)
  • Fix resending failed message reaction (@melvo)
  • Fix selecting previously selected message after changing reactions (@melvo)
  • Fix restoring message highlighting and cancel ongoing correction/reply on removing corresponding message (@melvo)
  • Fix displaying last message sender in chat list after draft message removal (@melvo)

Notes:

  • Kaidan requires Kirigami Addons 1.8 now
  • Kaidan requires QXmpp 1.14 now

Download

Or install Kaidan for your distribution:

Packaging status

We are happy to announce the release of Qt Creator 19 Beta!

You find a selection of improvements and fixes below. Please have a look at our change log for more detailed information.

Wednesday, 28 January 2026

I have a pile of hard drives. 3.5” Spinning rust. There’s like a dozen of them, some labeled cryptically (EBN D2), some infuriatingly (1) and some not-at-all. Probably most of them work. But how to effectively figure out what is on them? FreeBSD to the rescue.

Hotplug Just Works

All the drives are SATA. I do have an IDE drive, I use it for opening beer bottles. And an ST-225 for old-time’s sake. But SATA it is, and there’s spare SATA data- and power-cables dangling out the side of my PC. This particular machine runs FreeBSD 14.3, and connecting a drive (data first, then power) yields some messages in the system log. Old-school, the command to read these is still dmesg, which prints:

ada3 at ahcich0 bus 0 scbus0 target 0 lun 0
ada3: <WDC WD3200AAKS-00SBA0 12.01B01> ATA-7 SATA 2.x device
ada3: Serial Number WD-WMAPZ0561055
ada3: 300.000MB/s transfers (SATA 2.x, UDMA6, PIO 8192bytes)
ada3: Command Queueing enabled
ada3: 305245MB (625142448 512 byte sectors)

That matches information printed on the label of the disk (this drive is from 2007, has a 1 written on it in black marker – it may have been a drive in the English Breakfast Network server back then). It also tells me that the disk is registered with the system as ada3.

FreeBSD’s disk subsystem is a stack of “GEOM classes”. The geom(4) manpage tells me that it is a modular disk I/O request transformation framework, but the important bit is geom(8), the command to query the disk subsystem. Running geom disk list ada3 tells me what is known about disks involved with ada3. This actually doesn’t tell me much I don’t already know:

Geom name: ada3
Providers:
1. Name: ada3
   Mediasize: 320072933376 (298G)
   Sectorsize: 512
   Mode: r0w0e0
   descr: WDC WD3200AAKS-00SBA0
   lunid: 50014ee0aabd8fe3
   ident: WD-WMAPZ0561055
   rotationrate: unknown
   fwsectors: 63
   fwheads: 16

Well, actually this tells me that the dmesg and geom output are in mibi- and gibi-bytes, and that they’re consistent. How about partitions on this disk, though? geom part list ada3 tells me (here I’ve removed several partitions, along with many other lines that are not very useful right now; the output is extensive):

Geom name: ada3
scheme: GPT
Providers:
1. Name: ada3p1
   Mediasize: 819200 (800K)
   efimedia: HD(1,GPT,a43a2da3-bb5f-11e5-8d81-f5e4d894ddb1,0x22,0x640)
   label: (null)
   type: efi
   index: 1
2. Name: ada3p2
   Mediasize: 315679277056 (294G)
   efimedia: HD(2,GPT,a43c9069-bb5f-11e5-8d81-f5e4d894ddb1,0x662,0x24bff9c0)
   label: (null)
   type: freebsd-ufs
   index: 2

So it is a GPT-partitioned disk, and at least one of the partitions is an “old-fashioned” UFS partition. That’s FreeBSD before ZFS became the de-facto standard filesystem (maybe just for me). This disk is simple to deal with (further notes below)!

After I’m done with the disk, I power it down first with camcontrol standby ada3. I can hear the disk stop spinning and then pull out the connectors (power first, then data). And move on to the next disk. After disconnecting, dmesg confirms that I unplugged the correct drive:

ada3 at ahcich0 bus 0 scbus0 target 0 lun 0
ada3: <WDC WD3200AAKS-00SBA0 12.01B01> s/n WD-WMAPZ0561055 detached
(ada3:ahcich0:0:0:0): Periph destroyed

This way I can step through all of the drives in my pile and then jot down what disk does what (or, in rare cases, decide they can be zeroed out and re-used for something else).

Dealing with non-GPT disks

The scheme reported by geom part list is GPT if you’re sensible, but of course it is possible to bump into MBR and BSD disklabels as well. The geom subsystem abstracts all that away, and the only realy difference is the names of devices.

Scheme BSD, also known as BSD disklabel, gives you ada3a and ada3d, rather than numbered partitions. It is possible to apply this to a whole disk. It is also possible to have a BSD disklabel inside an MBR partition, but that’s a late-90s kind of setup.

Scheme MBR gives you numbered partitions, but FreeBSD calls these slices instead of partitions and so you end up with ada3s1 instead of ada3p1.

Dealing with UFS

UFS partitions are pretty simple: mount them somewhere and things will be OK. I go for read-only, and I have a /mnt/tmp for all my arbitrary-disk-mounting activity. So mount -o ro /dev/ada3p2 /mnt/tmp it is (ada3p2 is the partition name found earlier).

This particular disk turned out to be my main workstation drive around 2017, with a handful of still-interesting files on it. Ones I would not have missed if I hadn’t looked, but it was nice to find a presentation PDF I gave to SIDN once-upon-a-time.

After looking, umount /mnt/tmp to unmount and release the disk. After that, power-down and disconnect as described above.

Dealing with ZFS

Slightly newer disks might be ZFS. Here’s the partition information for one:

Providers:
1. Name: ada3p1
   Mediasize: 250059309056 (233G)
   label: backup0
   type: freebsd-zfs
   index: 1

It’s a GPT partition with a label, and ZFS on it. That means it’s part of a ZFS pool, and is probably referred to within the pool by its label. Possibly by its ID. In any case, ZFS needs to be imported, not mounted, because the filesystems are contained as part of the storage pool. The command to discover what is available is zpool import , which doesn’t actually import anything.

   pool: zbackup
 config:
        zbackup        ONLINE
          gpt/backup0  ONLINE

That’s encouraging: the pool consists of a single drive and everything is online. To make the filesystems in this pool available, I need to import it. I’ll force it (-f, because it was probably untimely ripp’d from whatever machine it was in previously), without mounting any of the filesystems in it (-N), readonly (-o readonly=on) with a temporary name (-t zwhat), like so: zpool import -f -N -o readonly=on -t zbackup zwhat

After importing the pool, zfs list tells me what filesystems are available:

zwhat                       36.2G   189G    25K  /zwhat
zwhat/home                  36.2G   189G  36.0G  /tmp/foo/

I can mount a single ZFS filesystem just like a UFS filesystem. The ZFS filesystem knows where it would want to be mounted (/tmp/foo, I have no idea what I was doing back then), but we can treat it like a legacy filesystem: mount -t zfs zwhat/home /mnt/tmp

After looking, umount /mnt/tmp to unmount and release the disk. After that, power-down and disconnect as described above.

Dealing with Linux ext4

If the disk comes from a Linux machine, then it may have an ext4 filesystem on it. I still usually pick that when installing Linuxes. Here’s the partition information for one:

scheme: MBR
Providers:
2. Name: ada3s2
   Mediasize: 64428703744 (60G)
   rawtype: 131
   type: linux-data

There is ext4 support in the FreeBSD kernel, although it is named ext2 (and some ext4 filesystems use unsupported features, and then it won’t mount). But for simple cases: mount -o ro -t ext2fs /dev/ada3s2 /mnt/tmp does the job.

Dealing with linux-raid

I found two disks, both WD Caviar Blue, labeled EBN D1 and EBN D2 with similar layouts. Those are linux-raid disks, and this is something I can’t deal with in FreeBSD. Heck, I’m not confident I can deal with them under Linux anymore, either.

Providers:
1. Name: ada3s1
   Mediasize: 493928031744 (460G)
   efimedia: HD(1,MBR,0xa8a8a8a8,0x3f,0x398033d3)
   rawtype: 253
   type: linux-raid

Re-purposing Disks

KDE has a lovely partitioning tool, but I wouldn’t be me if I didn’t go for the command-line approach. Make sure the disk isn’t mounted anywhere, but is powered up.

Zero out the first gigabyte or so of the disk: dd if=/dev/zero of=/dev/ada3 bs=1M count=1024 I guess this isn’t strictly necessary, and geom warns during this operation that the GPT is corrupt and the backup GPT (at the other end of the disk) should probably be used. Ignore that.

Destroy the partition table some more: geom part destroy -F ada3 , now it is really dead.

Make a new GPT partition table on the disk: geom part create -s gpt ada3

Start adding partitions to the partition table. I (now) use labels with the last digits of the drive’s serial-number. This drive gets a gigabyte of swap (just in case) and the rest is a ZFS partition which I can add to a pool later.

  • geom part add -t freebsd-swap -s 1G -l swap-159666 ada3
  • geom part add -t freebsd-zfs -l zfs-159666 ada3

Why the labels-with-serial-numbers? Well, that’s so that I can subsequently create a ZFS pool from labeled partitions, and it remains obvious where the parts of the pool come from and also prevents name-collisions from naming everything backup0 and so.

I've been administering KDE's participation in the Google Summer of Code program for the last few years (and mentoring on some). This post is just some personal thoughts on the differences between what the KDE organization expects and what usually the applicants want (I'm not in everybody heads, it's assumptions from my experience). I don't provide any solution (because I don't have any) and there is no judgment (both point of views are valid), just a personal point of view.

Applicants point of view

GSoC is a individual competitive program which can be a huge boost to start a career. There are usually two major reasons for the applicants to participate in GSoC:

  • the money.
  • the experience and the line in the CV for real life work.

There is, for a lot of applicants, no genuine interest in the projects (at least at the beginning, the first interaction is often "I want to start contributing to KDE and prepare for GSoC"), and they mostly want a GSoC slot. Small digression, on one of my projects, two people already asked to contribute and if we were doing GSoC, but after telling them that contributions are welcomed and we will only propose a topic if we feel enough confidence that the contributor would stay after, they told us they preferred to choose another project.

Contributors consider GSoC as an end of their studies, not a project they want to contribute after: there is also a change of life to consider between university life and work life and a balance to achieve when starting the latter (which could be in a different town/country) which may be a reason for the drop of interest.

Organization point of view

GSoC is an opportunity to welcome new contributors to our community. The organization usually expects from GSoC:

  • contributors willing to contribute regularly to their projects.
  • implementation (partial or total) of the proposed ideas.
  • having a positive return on investment (is the time spent mentoring worth the result?)

GSoC is mostly a step to have contributors learning about the projects, and contribute in the long-term. Long-term is purposely vague; what we expected for the GCompris project was the contributor would contribute at least one year and mentor for the next GSoC (so a loop was present, and applicants would also gain an experience on mentoring, while giving some relief to the other experienced mentors) but it can vary depending on the project.

For the return on investment, mentors do not consider it good having spent more than three months mentoring for projects they could have done in less time they spent to mentor the contributor. Helping someone grow is always personally rewarding but we still hope this person will also show us the results of the teaching by improving our projects in the future.

Impacts of the differences

There is a huge difference on the expectations. What can we do to reach a common ground where everyone is happy?

  • Organizations cannot force anyone to contribute after the GSoC end.
  • If money is the main motivation to stay, most organizations will not have money to hire applicants to work after (and do we want to hire someone only motivated by money? No, it's not OSS values, we love passion).
  • Find ways to create a real interest for the organization. In KDE, we have the chance to have tons of projects with different topics (astronomy, education, digital painting, video editing, scientific plotting, games, desktop environment, system administration, internationalization, ...) where it is easy to participate to other projects from time to time and learn new things if we are curious enough.
  • Be stricter on the entry point for organizations: explicitly say in the beginning that we expect a long-term relationship not just the equivalent of an internship. It should reduce the number of applicants and only keep the ones with a genuine interest (if applicants are honest of course).
  • Organizations/Mentors could reduce their objectives of GSoC and consider that contributors are here to produce and spend less time on training/mentoring, expecting contributors already know the basics, but this would totally spoil the nature of the program.

Another track is to find the projects where contributors stay / don't stay and understand the difference. Most of the big KDE applications don't manage to keep their contributors, while smaller ones do. Maybe as a contributor, it's because it's more difficult to take decisions, feel included/listened on large projects because they have a high maturity level/long-term contributors and a well-defined vision? Whereas on smaller projects, there are fewer constraints from the existing environment and it feels more rewarding and motivating to contribute there?

To conclude, here are the statistics for KDE retention the last years:

YearStartedCompletedActive after 1 yearActive after 2 yearsActive after 3 years
20182017554
20192422988
20202119221
20211615863
202276510
202397332
2024101042-
202515126--

That is, an average of 15 people sign up each year, of which

  • an average of 90% finish
  • 44% continued contributing 1 year later
  • 28% continued contributing 2 years later
  • 22% continued contributing 3 years later

We would of course love having more contributors staying at least one year but it's almost half and a quarter that stay active for a few years!