]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix the MS-DOS, Haiku, USG, etc builds
authorPo Lu <luangruo@yahoo.com>
Thu, 10 Aug 2023 01:53:26 +0000 (01:53 +0000)
committerPo Lu <luangruo@yahoo.com>
Thu, 10 Aug 2023 01:53:26 +0000 (01:53 +0000)
* configure.ac (emacs_cv_boot_time_file): Only compute this on
GNU/Linux, the sole system with systemd.
* nt/inc/ms-w32.h (BOOT_TIME_FILE): Remove now redundant #undef.
* src/filelock.c (get_boot_time): Eschew BOOT_TIME_FILE if not
defined.

configure.ac
nt/inc/ms-w32.h
src/filelock.c

index 56c8cf1ae051051bee67e66078c91e6a7c2cbc87..b5f8a0d5416b6a1aeb4d0a1e49e1f3e2adfaca93 100644 (file)
@@ -2625,11 +2625,11 @@ if test "$GCC" = yes && test "$ac_enable_autodepend" = yes; then
 fi
 AC_SUBST([AUTO_DEPEND])
 
+BOOT_TIME_FILE=
 AC_CACHE_CHECK([for old but post-boot file],
   [emacs_cv_boot_time_file],
   [AS_CASE([$opsys],
-     [*bsd|darwin|dragonfly],
-       [emacs_cv_boot_time_file='not needed'],
+     [gnu-linux],
      [emacs_cv_boot_time_file=unknown
       AS_IF([test $cross_compiling = no],
        [# systemd puts it in /var/lib/systemd.
@@ -2642,19 +2642,22 @@ AC_CACHE_CHECK([for old but post-boot file],
             /var/run/random-seed
         do
           test -f $file && { emacs_cv_boot_time_file=$file; break; }
-        done])])])
+        done])],
+     [*], [emacs_cv_boot_time_file=not-needed])])
+
 AS_CASE([$emacs_cv_boot_time_file],
   [/*|*:*], [BOOT_TIME_FILE=\"$emacs_cv_boot_time_file\"],
-  [NULL|nullptr|0], [BOOT_TIME_FILE=$emacs_cv_boot_time_file],
-  ['not needed'], [BOOT_TIME_FILE=NULL],
+  ['not needed'], [BOOT_TIME_FILE=],
   [# Guess systemd if unknown.
    # If guess is wrong, Emacs falls back on something else.
    BOOT_TIME_FILE=\"/var/lib/systemd/random-seed\"])
-AC_DEFINE_UNQUOTED([BOOT_TIME_FILE], [$BOOT_TIME_FILE],
-  [Name of file that, if it exists, postdates boot and predates
-   the first Emacs invocation; or a null pointer if no such file is known.
-   This file is used only on GNU/Linux and other systems
-   that lack the FreeBSD-style sysctl with KERN_BOOTTIME.])
+
+AS_IF([test -n "$BOOT_TIME_FILE"],
+  [AC_DEFINE_UNQUOTED([BOOT_TIME_FILE], [$BOOT_TIME_FILE],
+    [Name of file that, if it exists, postdates boot and predates
+     the first Emacs invocation; or a null pointer if no such file is known.
+     This file is used only on GNU/Linux and other systems
+     that lack the FreeBSD-style sysctl with KERN_BOOTTIME.])])
 
 #### Choose a window system.
 
index b23fd5030fa5629a8b3ef36713d47685f7e402d0..58be1199345bcf9ec435d08333fec2ef45b4f085 100644 (file)
@@ -121,7 +121,6 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
    the output, but that's gross.  So this should do; if the file is
    not there, the boot time will be returned as zero, and filelock.c
    already handles that.  */
-#undef BOOT_TIME_FILE
 #define BOOT_TIME_FILE "C:/pagefile.sys"
 
 /* ============================================================ */
index 0ad130353f3718b1dc6a373d6aece77678a1dced..3b1ff8ad56680dc3080589e0dd5931955b0bb067 100644 (file)
@@ -159,7 +159,7 @@ get_boot_time (void)
   }
 #endif /* defined (CTL_KERN) && defined (KERN_BOOTTIME) */
 
-  if (BOOT_TIME_FILE)
+#ifdef BOOT_TIME_FILE
     {
       struct stat st;
       if (stat (BOOT_TIME_FILE, &st) == 0)
@@ -168,6 +168,7 @@ get_boot_time (void)
          return boot_time;
        }
     }
+#endif /* BOOT_TIME_FILE */
 
 #if defined (BOOT_TIME)
   /* The utmp routines maintain static state.  Don't touch that state