aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely@redhat.com>2022-01-25 10:11:36 +0000
committerJonathan Wakely <jwakely@redhat.com>2022-01-25 21:05:16 +0000
commite20486d508afdf22790a271e90ca76d8df5fa7a5 (patch)
treea33514c91774a948fb54a939f60b446cfd17d217
parentc8bd4dc8212e43b2f9af08b80df97f90cdb0df4f (diff)
downloadgcc-e20486d508afdf22790a271e90ca76d8df5fa7a5.zip
gcc-e20486d508afdf22790a271e90ca76d8df5fa7a5.tar.gz
gcc-e20486d508afdf22790a271e90ca76d8df5fa7a5.tar.bz2
libstdc++: Define _GNU_SOURCE for secure_getenv on Cygwin [PR104217]
For GNU/Linux G++ defines _GNU_SOURCE automatically, but not for Cygwin. This means secure_getenv is not declared by Cygwin's <stdlib.h>, even though autoconf detected it is present in the library. Define it in the source files that want to use secure_getenv. libstdc++-v3/ChangeLog: PR libstdc++/104217 * src/c++17/fs_ops.cc (_GNU_SOURCE): Define. * src/filesystem/dir.cc (_GNU_SOURCE): Define. * src/filesystem/ops.cc (_GNU_SOURCE): Define.
-rw-r--r--libstdc++-v3/src/c++17/fs_ops.cc4
-rw-r--r--libstdc++-v3/src/filesystem/dir.cc4
-rw-r--r--libstdc++-v3/src/filesystem/ops.cc4
3 files changed, 12 insertions, 0 deletions
diff --git a/libstdc++-v3/src/c++17/fs_ops.cc b/libstdc++-v3/src/c++17/fs_ops.cc
index 1d3693a..321944d 100644
--- a/libstdc++-v3/src/c++17/fs_ops.cc
+++ b/libstdc++-v3/src/c++17/fs_ops.cc
@@ -27,6 +27,10 @@
# define NEED_DO_COPY_FILE
# define NEED_DO_SPACE
#endif
+#ifndef _GNU_SOURCE
+// Cygwin needs this for secure_getenv
+# define _GNU_SOURCE 1
+#endif
#include <bits/largefile-config.h>
#include <filesystem>
diff --git a/libstdc++-v3/src/filesystem/dir.cc b/libstdc++-v3/src/filesystem/dir.cc
index f1bf96a..d5b11f2 100644
--- a/libstdc++-v3/src/filesystem/dir.cc
+++ b/libstdc++-v3/src/filesystem/dir.cc
@@ -25,6 +25,10 @@
#ifndef _GLIBCXX_USE_CXX11_ABI
# define _GLIBCXX_USE_CXX11_ABI 1
#endif
+#ifndef _GNU_SOURCE
+// Cygwin needs this for secure_getenv
+# define _GNU_SOURCE 1
+#endif
#include <bits/largefile-config.h>
#include <experimental/filesystem>
diff --git a/libstdc++-v3/src/filesystem/ops.cc b/libstdc++-v3/src/filesystem/ops.cc
index 324c6af..cd98caf 100644
--- a/libstdc++-v3/src/filesystem/ops.cc
+++ b/libstdc++-v3/src/filesystem/ops.cc
@@ -27,6 +27,10 @@
# define NEED_DO_COPY_FILE
# define NEED_DO_SPACE
#endif
+#ifndef _GNU_SOURCE
+// Cygwin needs this for secure_getenv
+# define _GNU_SOURCE 1
+#endif
#include <bits/largefile-config.h>
#include <experimental/filesystem>