summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAkim Demaille <akim.demaille@gmail.com>2021-10-23 06:01:44 +0200
committerAkim Demaille <akim.demaille@gmail.com>2021-11-06 09:00:58 +0100
commitc83425ef4e1c66c81d328338e6bf98f5e3c33b81 (patch)
tree74ff6c21cd05cfe4033e0cbff08a90bf002056d0
parentc9b5b46d744766396db52b97a9e3a1f61f9e742a (diff)
downloadbison-c83425ef4e1c66c81d328338e6bf98f5e3c33b81.tar.gz
tests: address portability issues about strdup
Reported by Dennis Clarke <https://lists.gnu.org/r/bug-bison/2021-10/msg00005.html>. In particular <https://lists.gnu.org/r/bug-bison/2021-10/msg00023.html>. * doc/bison.texi, examples/c/glr/c++-types.y, * examples/c/bistromathic/parse.y tests/testsuite.h: Define _XOPEN_SOURCE to 600, to get a strdup that works on Solaris. * tests/glr-regression.at: Use strdup freely.
-rw-r--r--doc/bison.texi9
-rw-r--r--examples/c/bistromathic/parse.y5
-rw-r--r--examples/c/glr/c++-types.y4
-rw-r--r--tests/glr-regression.at4
-rw-r--r--tests/testsuite.h5
5 files changed, 23 insertions, 4 deletions
diff --git a/doc/bison.texi b/doc/bison.texi
index a559649c..77357813 100644
--- a/doc/bison.texi
+++ b/doc/bison.texi
@@ -2644,6 +2644,13 @@ calculator.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>. */
+
+%code top {
+ /* Portability issues for strdup. */
+#ifndef _XOPEN_SOURCE
+# define _XOPEN_SOURCE 600
+#endif
+}
@end example
@end ignore
@@ -2875,7 +2882,7 @@ found, a pointer to that symbol is returned; otherwise zero is returned.
not make these assumptions. */
#include <assert.h>
#include <stdlib.h> /* malloc, realloc. */
-#include <string.h> /* strlen. */
+#include <string.h> /* strdup, strlen. */
@end group
@group
diff --git a/examples/c/bistromathic/parse.y b/examples/c/bistromathic/parse.y
index fbdeb7fc..5c1e6055 100644
--- a/examples/c/bistromathic/parse.y
+++ b/examples/c/bistromathic/parse.y
@@ -21,6 +21,11 @@
// Emitted on top of the implementation file.
%code top {
+ /* Portability issues for strdup. */
+ #ifndef _XOPEN_SOURCE
+ # define _XOPEN_SOURCE 600
+ #endif
+
#include <ctype.h> // isdigit
#include <locale.h> // LC_ALL
#include <math.h> // cos, sin, etc.
diff --git a/examples/c/glr/c++-types.y b/examples/c/glr/c++-types.y
index 4c978386..ff1b62fb 100644
--- a/examples/c/glr/c++-types.y
+++ b/examples/c/glr/c++-types.y
@@ -53,6 +53,10 @@
%code
{
+ /* Portability issues for strdup. */
+#ifndef _XOPEN_SOURCE
+# define _XOPEN_SOURCE 600
+#endif
#include <assert.h>
#include <ctype.h>
diff --git a/tests/glr-regression.at b/tests/glr-regression.at
index a10f69ba..3a226f65 100644
--- a/tests/glr-regression.at
+++ b/tests/glr-regression.at
@@ -295,9 +295,7 @@ FILE *input;
else
{
assert (strlen (buf) < sizeof buf - 1);
- char *s = YY_CAST (char *, malloc (strlen (buf) + 1));
- strcpy (s, buf);
- ]AT_VAL[ = s;
+ ]AT_VAL[ = strdup (buf);
return 'V';
}
break;
diff --git a/tests/testsuite.h b/tests/testsuite.h
index 46e99dfe..d2be5e62 100644
--- a/tests/testsuite.h
+++ b/tests/testsuite.h
@@ -10,3 +10,8 @@
# pragma GCC diagnostic ignored "-Wzero-as-null-pointer-constant"
# endif
#endif
+
+/* We use strdup, make it available. */
+#ifndef _XOPEN_SOURCE
+# define _XOPEN_SOURCE 600
+#endif