[Dolphin] Label name for Overlayfs

I use Overlayfs to create temporary build environments. When I create Overlayfs, Dolphin automatically recognizes and creates entries in Devices. This is great and I really like this feature.
However, Dolphin uses the full path as the entry name for the Overlayfs and cannot specify a label name, which makes it more difficult for me to view and select.
If it’s an actual existing device, I can use the KDE partition manager to change the label name, for Overlayfs, how can I automatically assign or change its label name?

1 Like

You must be using a mount command.
You can pass to mount -o x-gvfs-name=my-name to set a name for the fs.

1 Like

Thanks, I tried to add this option but it didn’t work.

Commands executed:

overlay_name=ol_build-xx
sudo mount -t overlay ${overlay_name} -o lowerdir=../../source/build-xx,upperdir=upper,workdir=work,x-gvfs-name=${overlay_name} build

The parameters after mounting are shown below:

ol_build-xx on /home/xx/xx/builds/build-xx/build type overlay (rw,relatime,lowerdir=../../source/build-xx,upperdir=upper,workdir=work,uuid=null,nouserxattr,x-gvfs-name=ol_build-xx)

Dolphin still uses /home/xx/xx/builds/build-xx/build

Did you restart dolphin ?

I added a new mount and the new entry was immediately and automatically added to Dolphin’s list, but the label name was still the path.
Restarting Dolphin didn’t change it either.

What does solid-hardware6 list for those filesystems ?
They should start either with /org/freedesktop/UDisks2/ or /org/freedesktop/fstab

What does solid-hardware6 details <UDI> returns ?

$ mount | grep build-xx
ol_build-xx on /home/xx/xx/builds/build-xx/build type overlay (rw,relatime,lowerdir=../../source/build-xx,upperdir=upper,workdir=work,uuid=null,nouserxattr,x-gvfs-name=ol_build-xx)

$ solid-hardware6 list | grep build-xx
udi = '/org/kde/fstab/overlay/home/xx/xx/builds/build-xx/build'

$ solid-hardware6 details '/org/kde/fstab/overlay/home/xx/xx/builds/build-xx/build'
udi = '/org/kde/fstab/overlay/home/xx/xx/builds/build-xx/build'
  parent = '/org/kde/fstab' (string)
  vendor = 'overlay' (string)
  product = '~/xx/builds/build-xx/build' (string)
  description = '~/xx/builds/build-xx/build (overlay)' (string)
  icon = 'folder' (string)
qt.core.qobject.connect: QObject::connect: No such signal Solid::Backends::Fstab::FstabStorageAccess::repairRequested(QString) in ./src/solid/devices/frontend/storageaccess.cpp:23
qt.core.qobject.connect: QObject::connect: No such signal Solid::Backends::Fstab::FstabStorageAccess::repairDone(Solid::ErrorType, QVariant, QString) in ./src/solid/devices/frontend/storageaccess.cpp:24
  StorageAccess.accessible = true (bool)
  StorageAccess.filePath = '/home/xx/xx/builds/build-xx/build' (string)
  StorageAccess.ignored = false (bool)
  StorageAccess.encrypted = false (bool)

And what is your distro/version ?

I am not familiar with overlayfs.
Could create a very simple script that would setup one filesystem completely, so I can reproduce it myself easily.

Something like:

mkdir test
cd test
mkdir upper
mkdir lower
mount -o ...,x-gvfs-name=my-test

Operating System: KDE neon 6.0
KDE Plasma Version: 6.1.4
KDE Frameworks Version: 6.5.0
Qt Version: 6.7.2
Kernel Version: 6.8.0-40-generic (64-bit)

script:

mkdir -p test
cd test
mkdir -p lower upper work build
sudo mount -t overlay ol_name -o lowerdir=lower,upperdir=upper,workdir=work,x-gvfs-name=ol_label build
sudo umount build
1 Like

I have a MR fstabhandling: use libmount when available (!173) · Merge requests · Frameworks / Solid · GitLab

I tested it with success and it works.

1 Like

Thank you so much, I am amazed at how quickly it is done.
Waiting for it to merge into the trunk.

Well that’s mostly thanks to you to answer the question fast and precisely.
And I happen to be one of the right person for this kind of issue.
This days our trunk is master.

Btw, I am curious about your dev workflow with overlay fs, do you have a blog post/doc somewhere about it to recommend ?

Creating a build environment with overlayfs is a personal requirement, and I haven’t seen an doc on it, and I certainly haven’t written about it myself.
I use overlayfs at my work to create my local build environment. I had to use some unsuitable tools provided by my work to compile (e.g. binary toolchain managed by Git, and the same code for different development tasks at the same time). So I use overlayfs to combine the source code and compile tools/scripts directly together for fast compilation. And immediately rebuild a clean environment if the unsuitable tools screw everything up.
In general, it’s like a poor man’s version of Docker.