From ad19eae9f52eea54caaab1bc1faa3af2e859e88f Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Mon, 28 Oct 2024 12:19:36 +1000 Subject: [PATCH 1/9] meson: add `HOST_MACOS` Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- libs/meson.build | 133 +++++++++++++++++++++++++---------------------- meson.build | 4 ++ 2 files changed, 76 insertions(+), 61 deletions(-) diff --git a/libs/meson.build b/libs/meson.build index 3184ec230..13d8a4dde 100644 --- a/libs/meson.build +++ b/libs/meson.build @@ -1,66 +1,77 @@ +libfvwm3_sources = files( + 'BidiJoin.c', + 'Bindings.c', + 'ClientMsg.c', + 'ColorUtils.c', + 'Colorset.c', + 'CombineChars.c', + 'Cursor.c', + 'Event.c', + 'FBidi.c', + 'FEvent.c', + 'FGettext.c', + 'FImage.c', + 'FRender.c', + 'FRenderInit.c', + 'FScreen.c', + 'FShape.c', + 'FTips.c', + 'Fft.c', + 'Ficonv.c', + 'Flocale.c', + 'FlocaleCharset.c', + 'Grab.c', + 'Graphics.c', + 'Module.c', + 'Parse.c', + 'Picture.c', + 'PictureBase.c', + 'PictureGraphics.c', + 'PictureImageLoader.c', + 'PictureUtils.c', + 'Rectangles.c', + 'Strings.c', + 'System.c', + 'Target.c', + 'WinMagic.c', + 'XError.c', + 'XResource.c', + 'cJSON.c', + 'charmap.c', + 'envvar.c', + 'fio.c', + 'flist.c', + 'fqueue.c', + 'fsm.c', + 'fvwmlib3.c', + 'fvwmrect.c', + 'fvwmsignal.c', + 'getpwuid.c', + 'gravity.c', + 'log.c', + 'modifiers.c', + 'safemalloc.c', + 'setpgrp.c', + 'strtonum.c', + 'timeout.c', + 'wcontext.c', + 'wild.c', +) + +string_sources = files( + 'strlcat.c', + 'strlcpy.c', +) + +# We don't build the string sources on macOS +# We probably could check for target_system, but nobody is cross-compiling _to_ macOS +if not (host_machine.system() == 'darwin') + libfvwm3_sources += string_sources +endif + libfvwm3 = static_library( 'fvwm3', - sources: [ - 'BidiJoin.c', - 'Bindings.c', - 'ClientMsg.c', - 'ColorUtils.c', - 'Colorset.c', - 'CombineChars.c', - 'Cursor.c', - 'Event.c', - 'FBidi.c', - 'FEvent.c', - 'FGettext.c', - 'FImage.c', - 'FRender.c', - 'FRenderInit.c', - 'FScreen.c', - 'FShape.c', - 'FTips.c', - 'Fft.c', - 'Ficonv.c', - 'Flocale.c', - 'FlocaleCharset.c', - 'Grab.c', - 'Graphics.c', - 'Module.c', - 'Parse.c', - 'Picture.c', - 'PictureBase.c', - 'PictureGraphics.c', - 'PictureImageLoader.c', - 'PictureUtils.c', - 'Rectangles.c', - 'Strings.c', - 'System.c', - 'Target.c', - 'WinMagic.c', - 'XError.c', - 'XResource.c', - 'cJSON.c', - 'charmap.c', - 'envvar.c', - 'fio.c', - 'flist.c', - 'fqueue.c', - 'fsm.c', - 'fvwmlib3.c', - 'fvwmrect.c', - 'fvwmsignal.c', - 'getpwuid.c', - 'gravity.c', - 'log.c', - 'modifiers.c', - 'safemalloc.c', - 'setpgrp.c', - 'strlcat.c', - 'strlcpy.c', - 'strtonum.c', - 'timeout.c', - 'wcontext.c', - 'wild.c', - ], + sources: libfvwm3_sources, include_directories: includedirs, dependencies: all_found_deps, install: false, diff --git a/meson.build b/meson.build index 984eaad31..cab6f6cfb 100644 --- a/meson.build +++ b/meson.build @@ -65,6 +65,10 @@ if host_machine.endian() == 'big' conf.set('WORDS_BIGENDIAN', true) endif +if host_machine.system() == 'darwin' + conf.set10('HOST_MACOS', true) +endif + # Set static configuration. conf.set_quoted('VERSION', meson.project_version()) conf.set_quoted('VERSIONINFO', fvwm_vcs_versioninfo) From 82a56f05f45998801eac7f04844d5c5eb728e69e Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 12:26:24 +1000 Subject: [PATCH 2/9] meson: implement `HAVE_GNU_READLINE` Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- meson.build | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/meson.build b/meson.build index cab6f6cfb..8b019e8ab 100644 --- a/meson.build +++ b/meson.build @@ -223,6 +223,10 @@ else if readline.found() all_found_deps += readline conf.set10('HAVE_READLINE', true) + # Check for append_history to determine if we have GNU readline + if cc.has_function('append_history', dependencies: readline) + conf.set10('HAVE_GNU_READLINE', true) + endif endif endif From bc82b3de95219dc0af2b54cd7705a61402b1c354 Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 12:48:46 +1000 Subject: [PATCH 3/9] meson: implement `HAVE_SAFETY_MKSTEMP` This has been safe since 2008 so we don't need to check for it. Tidyup: Add `true` values to `non_configurable_ops` Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- meson.build | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/meson.build b/meson.build index 8b019e8ab..65906d1b4 100644 --- a/meson.build +++ b/meson.build @@ -91,8 +91,6 @@ conf.set('SIGNAL_RETURN', 'return') conf.set('ICONV_ARG_CONST', '') conf.set('fd_set_size_t', 'int') conf.set('EXECUTABLE_EXTENSION', 'NULL') -conf.set10('HAVE_XOUTPUT_METHOD', true) -conf.set10('FORK_CREATES_CHILD', true) # Enable FTMs if host_machine.system() == 'linux' @@ -364,6 +362,10 @@ endif # Hard-coded non_configurable_ops = [ 'FMiniIconsSupported', + 'FORK_CREATES_CHILD', + 'HAVE_SAFETY_MKSTEMP', # safer since 2008; no real need to check for this on a modern system. + 'HAVE_X11_FD', + 'HAVE_XOUTPUT_METHOD', 'HAVE_XSHM', ] From 3b5909a274c8a736e3dcd80873533a4204534251 Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 12:55:05 +1000 Subject: [PATCH 4/9] meson: remove `HAVE_SYS_TYPES_H` We don't actually guard this anywhere in the codebase. Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- config_defines.h | 4 ---- 1 file changed, 4 deletions(-) diff --git a/config_defines.h b/config_defines.h index 1dfc31cad..9a2d37718 100644 --- a/config_defines.h +++ b/config_defines.h @@ -31,10 +31,6 @@ # define memmove(_d,_s,_l) bcopy((_s),(_d),(_l)) #endif -#if HAVE_SYS_TYPES_H -# include -#endif - #if HAVE_UNISTD_H # include #endif From 22ef9cccfa8cf617e62b36f058dd646a84c6d06f Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 13:09:23 +1000 Subject: [PATCH 5/9] meson: make `Xext` a mandatory dep As XSHM is mandatory we can no longer build without Xext, so tidy up the build code. Signed-off-by: Matt Jolly --- meson.build | 10 ++++------ meson.options | 6 ------ 2 files changed, 4 insertions(+), 12 deletions(-) diff --git a/meson.build b/meson.build index 65906d1b4..c3a6f3beb 100644 --- a/meson.build +++ b/meson.build @@ -188,6 +188,10 @@ foreach rd : all_req_deps all_found_deps += this_dep endforeach +xext = dependency('xext', required: true) +all_found_deps += xext +conf.set10('SHAPE', true) + # Python is a required dependency, we generate shebangs at buildtime # This will error by default if there is no python interpreter found py_mod = import('python') @@ -335,12 +339,6 @@ if xcursor.found() conf.set10('HAVE_XCURSOR', true) endif -xext = dependency('xext', required: get_option('xext')) -if xext.found() - all_found_deps += xext - conf.set10('SHAPE', true) -endif - xkbcommon = dependency('xkbcommon', required: get_option('xkbcommon')) if xkbcommon.found() all_found_deps += xkbcommon diff --git a/meson.options b/meson.options index 3d37cef62..ed9b82852 100644 --- a/meson.options +++ b/meson.options @@ -88,12 +88,6 @@ option( value: 'auto', description: 'Enable Xcursor support', ) -option( - 'xext', - type: 'feature', - value: 'auto', - description: 'Enable shaped window support via Xext', -) option( 'xkbcommon', type: 'feature', From 4884ae391072873c577540c71d9177c4bcabfda4 Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 13:13:06 +1000 Subject: [PATCH 6/9] un-gate `Xtrans.h` The X Network Transport layer has been shipped with X11 for some time now. We no longer need to support configurations without this feature. Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- dev-docs/INSTALL.md | 1 + libs/fsm.c | 5 +---- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/dev-docs/INSTALL.md b/dev-docs/INSTALL.md index a11ed1956..165f19203 100644 --- a/dev-docs/INSTALL.md +++ b/dev-docs/INSTALL.md @@ -32,6 +32,7 @@ system in use. * libxrandr-dev (>= 1.5) * libxrender-dev * libxt-dev +* xtrans-dev ## Optional dependencies diff --git a/libs/fsm.c b/libs/fsm.c index cfac128bd..20186af76 100644 --- a/libs/fsm.c +++ b/libs/fsm.c @@ -33,11 +33,8 @@ #include #include #include -#if defined(HAVE_X11_XTRANS_XTRANS_H) && defined(HAVE__ICETRANSNOLISTEN) #include -#elif defined(HAVE__ICETRANSNOLISTEN) -extern void _IceTransNoListen(char *protocol); -#endif + #include "fvwmlib.h" #include "log.h" From 28bf7542f6dab8d4e292d3140ee5e920a89b4585 Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 13:22:33 +1000 Subject: [PATCH 7/9] Include `time.h` and `sys/time.h` All remotely modern and supported platforms allow this. Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- libs/ftime.h | 8 -------- 1 file changed, 8 deletions(-) diff --git a/libs/ftime.h b/libs/ftime.h index f53469c26..0731cbac4 100644 --- a/libs/ftime.h +++ b/libs/ftime.h @@ -5,15 +5,7 @@ #include "config.h" -#ifdef TIME_WITH_SYS_TIME # include # include -#else -# ifdef HAVE_SYS_TIME_H -# include -# else -# include -# endif -#endif #endif /* FVWMLIB_FTIME_H */ From 82cea1e75e863e2d766399717ee183846cb7bdda Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Sun, 27 Oct 2024 13:59:54 +1000 Subject: [PATCH 8/9] meson: add `HAVE_WAIT3` Reported-by: Jaimos Skriletz Signed-off-by: Matt Jolly --- meson.build | 1 + 1 file changed, 1 insertion(+) diff --git a/meson.build b/meson.build index c3a6f3beb..50f1404ae 100644 --- a/meson.build +++ b/meson.build @@ -160,6 +160,7 @@ functions = { 'sysconf': {}, 'intl': {}, 'uname': {}, + 'wait3': {}, 'waitpid': {}, } From 7f96630ddf58fa99e93a76a423c106ced70fbc7a Mon Sep 17 00:00:00 2001 From: Matt Jolly Date: Tue, 29 Oct 2024 12:00:34 +1000 Subject: [PATCH 9/9] meson: define `SETPGRP_VOID` All current systems have a setpgrp whose signature conforms to Posix. We need to set this to use the correct implementation internally but we don't need to check for it. Signed-off-by: Matt Jolly --- meson.build | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/meson.build b/meson.build index 50f1404ae..68e0e22f4 100644 --- a/meson.build +++ b/meson.build @@ -176,6 +176,14 @@ foreach f, v : functions endif endforeach +# SETPGRP_VOID is obsolete +# All current systems have a setpgrp whose signature conforms to Posix. +# We need to set this to use the correct implementation internally +# but we don't need to check for it. +if conf.has('HAVE_SETPGRP') + conf.set10('SETPGRP_VOID', true) +endif + # Dependencies. all_found_deps = []