On 13. 5. 26 22:53, Noel Butler wrote:

On 13/05/2026 07:25, Branko Čibej wrote:

On 12. 5. 26 22:43, Noel Butler wrote:

On 13/05/2026 02:08, Timofei Zhakov wrote:

    I will be happy to try and extend cmake to work on Unix, if this
    feature is wanted of course.

-1

cmake is a PITA on *nix   for server admins


While I agree in principle that CMake is fundamentally broken and wrong-headed, that case can be made for pretty much any generic build system. So I would be grateful if you would expand on why server admins in particular would be more affected than anyone else.

-- Brane


Its convoluted. Its messy.

Lets take sql as a horrid example (but its similar with the only other  forced cmake requirement that we use being clamav), what used to configured and built with autotools could be done as such, clear simple EASY for even the most junior and senior administrator alike to config from memory -

./configure --prefix=/usr --localstatedir=/usr/mysql/data --datadir=/var/lib/mysql


done...


BUT cmake to do same thing requires this crap (supplied my mariadb team member to mimic our build requirements)


cmake -DCMAKE_C_FLAGS="-O2 -fPIC" -DCMAKE_CXX_FLAGS="-O2 -fPIC" -DFEATURE_SET="community" -DCMAKE_INSTALL_PREFIX=/usr -D INSTALL_LIBDIR="lib64" -DINSTALL_SBINDIR=libexec -DINSTALL_INCLUDEDIR=include/mysql -DINSTALL_MYSQLSHAREDIR=share/mysql -DINSTALL_SQLBENCHDIR="" -DINSTALL_MYSQLTESTDIR=mysql-test -DINSTALL_MANDIR=man -DINSTALL_PLUGINDIR="lib64/mysql/plugin"  -DINSTALL_SCRIPTDIR=bin -DINSTALL_SUPPORTFILESDIR=share/mysql -DINSTALL_MYSQLDATADIR="/var/lib/mysql" -DMYSQL_DATADIR=" /var/lib/mysql" -DMYSQL_UNIX_ADDR="/var/run/mysql/mysql.sock" -DWITH_EXTRA_CHARSETS=complex -DWITH_INNOBASE_STORAGE_ENGI NE=1 -DENABLED_LOCAL_INFILE=ON -DWITH_LIBARCHIVE=ON -DWITH_READLINE=ON -DWITH_JEMALLOC=system -DWITH_ZLIB=system -DWITH_ EXTERNAL_ZLIB=ON -DWITH_SSL=system -DCONC_WITH_SSL=ON -DUSE_ARIA_FOR_TMP_TABLES=ON -DAWS_SDK_EXTERNAL_PROJECT=OFF

Then  running    make...

*THEN* to upgrade each version you have to screw around with garbage like

rm $(</root/install_manifest-MARIADB.txt)
make install
cp install_manifest.txt /root/install_manifest-MARIADB.txt

(Sure you don't need to cp and use /root/install_manifest but if someone clears out the source code you will be left with pieces of older versions, so you copy it, and lets not forget  that file is not created until the program is built and installed, its not something you can pluck out of a tarball

all because there is no make uninstall....



And clamav as mentioned earlier, before it was just

./configure --prefix=


NOW it too requires all the manual rm BS as maria/mysql above, but at least its CMAKE line is much shorter..


cmake .. -D CMAKE_INSTALL_PREFIX=/usr/local -D CMAKE_INSTALL_LIBDIR=lib64 -D APP_CONFIG_DIRECTORY=/etc/clamav -D DATABASE_DIRECTORY=/var/lib/clamav


you try remembering all that crap when you need to off the top of your head, and using a cheatsheet (like we obviously are doing) is not an excuse.

I reckon the same morons who are involved in systemd are involved in cmake,  12 lines to do with what cron does in 1


/that completes this years rant



You just described two horribly broken CMake build systems. In the two cases you mentioned, the fault lies with the authors, not with CMake. :)

Well, except in the sense that CMake has zero, nil, zilch, none whatsoever sane defaults on ANY platform.

I'm "happy" to say that it's extremely easy to write autotools builds that are just as broken as the CMake examples you just described.

-- Brane

Reply via email to