KXStudio : News
>
KXStudio Monthly Report (May 2022)
On 2022-05-31 by falkTX
Hello all, it has been a while since the last time I wrote one of the "monthly" reports, but now back again.
Typically I would write about stuff that was happening behind-the-scenes or to be released soon,
but last couple of months have been mostly releases of stuff that was already in progress and was reported on already, or quick enough releases that could be done in a single month.
Also, there was
quite
a
lot
of
Cardinal,
like
a lot
of it. :)
Continuing with efforts torwards VST3
VST3 support in
DPF
is not going as quickly as I hoped, with the last few details being hard to get right.
As a way to learn more about VST3 specifics, and also because
I promised to do so,
I began doing a host-side implementation for
Carla.
While Carla can already do VST3 plugins,
it relies on
JUCE
for it which I am not totally happy with.
Having JUCE built on Carla + Linux just to get VST3 support is something that has always bothered me.
Because Linux does not have the concept of a OS-level event loop, a special way of mixing Qt and JUCE is in place, and feels very dirty.
There are other technical reasons for disliking the approach, but I will skip the details here.
Do note that, alike for VST2, I will keep using VST3 through JUCE for macOS and Windows.
Mostly because I rarely use those systems, so overall it is safer to rely on JUCE for them.
Maybe at some point the Carla VST3 implementation will be good enough to consider enabling the native approach on those systems too, but that can take a while.
Carla related things
Speaking of Carla, I merged the Jean Pierre Cimalando's
JSFX plugin support pull request,
though still in the process of cleaning things up (in particular non-x64 builds are broken at the moment).
Next release will have the feature enabled, which also propagates to stuff like
Ildaeil
and its use in
Cardinal. :D
Also on Carla, I updated the in-tree JUCE to version 7.
JUCE 7 can now host LV2 plugins too, but for that I will keep Carla's native implementation which is more complete (JUCE does not support CV ports or external UIs, for example).
The update to JUCE also serves to help bring JUCE-based plugins into
DISTRHO-Ports
and KXStudio packaging, since I reuse the same JUCE version for everything.
My
usual set of patches
are complete now, and everything was ready to update DISTRHO-Ports main branch to it except it
completely breaks Vital[ium] :/
The best approach is likely to have Vitalium be separate from DISTRHO-Ports, but setting that up takes a fair bit of time, so we won't see that so soon.
Perhaps the updated Vital source (whenever that drops..) will have better compatibility with newer JUCE versions, unknown at this point.
In any case, updates to DISTRHO-Ports are blocked at the moment because of this, but there is enough to do on other projects anyway.
Still on Carla, I also updated its in-tree DPF, bringing over the UI code restructure from a while ago.
This is important for the JSFX support, for possibily having their custom GUIs.
I will probably skip them for the first Carla version with JSFX enabled, but it is good to have this in place early so there are less blockers for the implementation.
The update also means being able to refresh the
DPF-based internal plugins,
which have been ignored for a while.
Sassy Spreadsheet and Scope
A little fancy tool caught my attention recently - the
sassy spreadsheet.
It was
recently open-sourced
and with the GUI widgets being familiar (it uses
imgui)
there were very high chances of it working on Linux.
There were no official Linux builds or ways to build for Linux, but
not for long!
So while we can build and run it now, sadly any operation results in a crash :(
I did some investigation but couldn't find why, author also couldn't tell.
That said, because it is based on imgui and I have worked with it and implemented in a few places, I wondered about taking advantage of it..
Can we take the very nice and properly behaving scope and use it somewhere else?
Yes we can. Yay for open-source!
KXStudio Repositories
On Repository related updates, I finally began to update some packages.
This really goes slow compared to previous times, as the newly introduced automated plugin tests fail.
I should have expected that..
It is great that we catch things early, but that also means updates can be blocked because of it.
Sometimes errors are
falsely
reported, but sometimes
actual plugin issues
are found too.
Kind of a pain to deal with when things fail, though in the long term it is for the best.
Because it was just too old and even non-working for some users, the use of the external, non-PPA based repository has been removed.
This basically means the the removal of the ardour package from the KXStudio repositories.
My idea for it was to update it to version 7 and find a way to automate the whole split build (amd64, armhf and arm64 packages).
Easier said than done, and there is too much I am doing already, it is hard to justify maintaining an extra repository just for a few packages.
Apologies for taking so long for taking a decision on this, I always hope to be able to do everything and more, but always fall short.
Doing less things is fine too.
Another small removal is the "recommended" meta-packages, which I had setup as a way for users to easily install a few extra useful programs from outside the KXStudio repositories.
Turns out, making a meta-package that can properly depend/install things across many debian versions and variants is hard.
Packages get removed or renamed, and makes a whole mess of optional dependencies that is just best to simply not care about.
And so it is now.
Related to actual package updates, we have these for this month:
- airwindows-lv2 added (version 1.3)
- dragonfly-reverb updated to 3.2.6
- lsp-plugins updated to 1.2.1
That is all for now, see you next time!