<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">Return-Path: &lt;rosenp@gmail.com&gt;
Received: from localhost.localdomain (76-14-106-55.rk.wavecable.com. [76.14.106.55])
        by smtp.gmail.com with ESMTPSA id f19sm148509170pfk.180.2019.08.09.13.01.06
        for &lt;flac-dev@xiph.org&gt;
        (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256);
        Fri, 09 Aug 2019 13:01:06 -0700 (PDT)
From: Rosen Penev &lt;rosenp@gmail.com&gt;
To: flac-dev@xiph.org
Subject: [PATCH] Switch to utimensat for newer POSIX versions
Date: Fri,  9 Aug 2019 13:01:05 -0700
Message-Id: &lt;20190809200105.1443-1-rosenp@gmail.com&gt;
X-Mailer: git-send-email 2.17.1

Some libcs like uClibc-ng can optionally disable deprecated functions.
utime is one of them. When done so, both the header and the function go
missing.

This fixes flac_utime to work in such a situation.
---
 include/share/compat.h           | 10 +++++++++-
 src/libFLAC/metadata_iterators.c |  9 +++++++--
 src/share/grabbag/file.c         |  9 +++++++--
 3 files changed, 23 insertions(+), 5 deletions(-)

--- a/include/share/compat.h
+++ b/include/share/compat.h
@@ -112,9 +112,13 @@
 #include &lt;sys/utime.h&gt; /* for utime() */
 #endif
 #else
+#if _POSIX_C_SOURCE &gt;= 200809L
+#include &lt;fcntl.h&gt;
+#else
 #include &lt;sys/types.h&gt; /* some flavors of BSD (like OS X) require this to get time_t */
 #include &lt;utime.h&gt; /* for utime() */
 #endif
+#endif
 
 #if defined _MSC_VER
 #  if _MSC_VER &gt;= 1800
@@ -160,11 +164,15 @@
 
 #define flac_fopen fopen
 #define flac_chmod chmod
-#define flac_utime utime
 #define flac_unlink unlink
 #define flac_rename rename
 #define flac_stat stat
 
+#if _POSIX_C_SOURCE &gt;= 200809L
+#define flac_utime(a, b) utimensat (AT_FDCWD, a, *b, 0)
+#else
+#define flac_utime utime
+#endif
 #endif
 
 #ifdef _WIN32
--- a/src/libFLAC/metadata_iterators.c
+++ b/src/libFLAC/metadata_iterators.c
@@ -3422,13 +3422,18 @@ FLAC__bool get_file_stats_(const char *f
 
 void set_file_stats_(const char *filename, struct flac_stat_s *stats)
 {
-	struct utimbuf srctime;
-
 	FLAC__ASSERT(0 != filename);
 	FLAC__ASSERT(0 != stats);
 
+#if _POSIX_C_SOURCE &gt;= 200809L
+	struct timespec srctime[2] = {};
+	srctime[0].tv_sec = stats-&gt;st_atime;
+	srctime[1].tv_sec = stats-&gt;st_mtime;
+#else
+	struct utimbuf srctime;
 	srctime.actime = stats-&gt;st_atime;
 	srctime.modtime = stats-&gt;st_mtime;
+#endif
 	(void)flac_chmod(filename, stats-&gt;st_mode);
 	(void)flac_utime(filename, &amp;srctime);
 #if !defined _MSC_VER &amp;&amp; !defined __BORLANDC__ &amp;&amp; !defined __MINGW32__
--- a/src/share/grabbag/file.c
+++ b/src/share/grabbag/file.c
@@ -27,7 +27,6 @@
 #include &lt;fcntl.h&gt; /* for _O_BINARY */
 #else
 #include &lt;sys/types.h&gt; /* some flavors of BSD (like OS X) require this to get time_t */
-#include &lt;utime.h&gt; /* for utime() */
 #endif
 #if defined __EMX__
 #include &lt;io.h&gt; /* for setmode(), O_BINARY */
@@ -53,11 +52,17 @@
 void grabbag__file_copy_metadata(const char *srcpath, const char *destpath)
 {
 	struct flac_stat_s srcstat;
-	struct utimbuf srctime;
 
 	if(0 == flac_stat(srcpath, &amp;srcstat)) {
+#if _POSIX_C_SOURCE &gt;= 200809L
+		struct timespec srctime[2] = {};
+		srctime[0].tv_sec = srcstat.st_atime;
+		srctime[1].tv_sec = srcstat.st_mtime;
+#else
+		struct utimbuf srctime;
 		srctime.actime = srcstat.st_atime;
 		srctime.modtime = srcstat.st_mtime;
+#endif
 		(void)flac_chmod(destpath, srcstat.st_mode);
 		(void)flac_utime(destpath, &amp;srctime);
 	}
</pre></body></html>