Blame SOURCES/0006-Allow-blank-format-items-in-format-strings.patch

d0de29
From 8a5920d930429f91b269d9265323bf2507a6b8e5 Mon Sep 17 00:00:00 2001
d0de29
From: Jim MacArthur <jim.macarthur@codethink.co.uk>
d0de29
Date: Thu, 4 Feb 2016 16:59:41 +0000
d0de29
Subject: [PATCH 06/16] Allow blank format items in format strings
d0de29
d0de29
This has to be written in a slightly verbose manner because GCC 7
d0de29
defaults to building with -Werror=implicit-fallthrough which prevents
d0de29
us from just falling through to the default: case.
d0de29
d0de29
Test written by: Francisco Redondo Marchena <francisco.marchena@codethink.co.uk>
d0de29
d0de29
Use -fdec-blank-format-item to enable. Also enabled by -fdec.
d0de29
---
d0de29
 gcc/fortran/io.c                                    | 10 ++++++++++
d0de29
 gcc/fortran/lang.opt                                |  4 ++++
d0de29
 gcc/fortran/options.c                               |  1 +
d0de29
 gcc/testsuite/gfortran.dg/dec_format_empty_item_1.f | 19 +++++++++++++++++++
d0de29
 gcc/testsuite/gfortran.dg/dec_format_empty_item_2.f | 19 +++++++++++++++++++
d0de29
 gcc/testsuite/gfortran.dg/dec_format_empty_item_3.f | 19 +++++++++++++++++++
d0de29
 6 files changed, 72 insertions(+)
d0de29
 create mode 100644 gcc/testsuite/gfortran.dg/dec_format_empty_item_1.f
d0de29
 create mode 100644 gcc/testsuite/gfortran.dg/dec_format_empty_item_2.f
d0de29
 create mode 100644 gcc/testsuite/gfortran.dg/dec_format_empty_item_3.f
d0de29
d0de29
diff --git a/gcc/fortran/io.c b/gcc/fortran/io.c
d0de29
index 57117579627..5b355952840 100644
d0de29
--- a/gcc/fortran/io.c
d0de29
+++ b/gcc/fortran/io.c
d0de29
@@ -756,6 +756,16 @@ format_item_1:
d0de29
       error = unexpected_end;
d0de29
       goto syntax;
d0de29
 
d0de29
+    case FMT_RPAREN:
d0de29
+      /* Oracle allows a blank format item. */
d0de29
+      if (flag_dec_blank_format_item)
d0de29
+	goto finished;
d0de29
+      else
d0de29
+	{
d0de29
+	  error = unexpected_element;
d0de29
+	  goto syntax;
d0de29
+	}
d0de29
+
d0de29
     default:
d0de29
       error = unexpected_element;
d0de29
       goto syntax;
d0de29
diff --git a/gcc/fortran/lang.opt b/gcc/fortran/lang.opt
d0de29
index a957b90707f..3d8aaeaaf44 100644
d0de29
--- a/gcc/fortran/lang.opt
d0de29
+++ b/gcc/fortran/lang.opt
d0de29
@@ -440,6 +440,10 @@ fdec
d0de29
 Fortran Var(flag_dec)
d0de29
 Enable all DEC language extensions.
d0de29
 
d0de29
+fdec-blank-format-item
d0de29
+Fortran Var(flag_dec_blank_format_item)
d0de29
+Enable the use of blank format items in format strings.
d0de29
+
d0de29
 fdec-duplicates
d0de29
 Fortran Var(flag_dec_duplicates)
d0de29
 Allow varibles to be duplicated in the type specification matches.
d0de29
diff --git a/gcc/fortran/options.c b/gcc/fortran/options.c
d0de29
index b652be70f3d..a8c2cf71c3b 100644
d0de29
--- a/gcc/fortran/options.c
d0de29
+++ b/gcc/fortran/options.c
d0de29
@@ -78,6 +78,7 @@ set_dec_flags (int value)
d0de29
   SET_BITFLAG (flag_dec_duplicates, value, value);
d0de29
   SET_BITFLAG (flag_dec_char_conversions, value, value);
d0de29
   SET_BITFLAG (flag_dec_comparisons, value, value);
d0de29
+  SET_BITFLAG (flag_dec_blank_format_item, value, value);
d0de29
 }
d0de29
 
d0de29
 /* Finalize DEC flags.  */
d0de29
diff --git a/gcc/testsuite/gfortran.dg/dec_format_empty_item_1.f b/gcc/testsuite/gfortran.dg/dec_format_empty_item_1.f
d0de29
new file mode 100644
d0de29
index 00000000000..ed27c18944b
d0de29
--- /dev/null
d0de29
+++ b/gcc/testsuite/gfortran.dg/dec_format_empty_item_1.f
d0de29
@@ -0,0 +1,19 @@
d0de29
+! { dg-do run }
d0de29
+! { dg-options "-fdec" }
d0de29
+!
d0de29
+! Test blank/empty format items in format string
d0de29
+!
d0de29
+! Test case contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
d0de29
+! Modified by Mark Eggleston <mark.eggleston@codethink.com>
d0de29
+!
d0de29
+        PROGRAM blank_format_items
d0de29
+          INTEGER A/0/
d0de29
+
d0de29
+          OPEN(1, status="scratch")
d0de29
+          WRITE(1, 10) 100
d0de29
+          REWIND(1)
d0de29
+          READ(1, 10) A
d0de29
+          IF (a.NE.100) STOP 1
d0de29
+          PRINT 10, A
d0de29
+10        FORMAT( I5,)
d0de29
+        END
d0de29
diff --git a/gcc/testsuite/gfortran.dg/dec_format_empty_item_2.f b/gcc/testsuite/gfortran.dg/dec_format_empty_item_2.f
d0de29
new file mode 100644
d0de29
index 00000000000..2793cb16225
d0de29
--- /dev/null
d0de29
+++ b/gcc/testsuite/gfortran.dg/dec_format_empty_item_2.f
d0de29
@@ -0,0 +1,19 @@
d0de29
+! { dg-do run }
d0de29
+! { dg-options "-fdec-blank-format-item" }
d0de29
+!
d0de29
+! Test blank/empty format items in format string
d0de29
+!
d0de29
+! Test case contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
d0de29
+! Modified by Mark Eggleston <mark.eggleston@codethink.com>
d0de29
+!
d0de29
+        PROGRAM blank_format_items
d0de29
+          INTEGER A/0/
d0de29
+
d0de29
+          OPEN(1, status="scratch")
d0de29
+          WRITE(1, 10) 100
d0de29
+          REWIND(1)
d0de29
+          READ(1, 10) A
d0de29
+          IF (a.NE.100) STOP 1
d0de29
+          PRINT 10, A
d0de29
+10        FORMAT( I5,)
d0de29
+        END
d0de29
diff --git a/gcc/testsuite/gfortran.dg/dec_format_empty_item_3.f b/gcc/testsuite/gfortran.dg/dec_format_empty_item_3.f
d0de29
new file mode 100644
d0de29
index 00000000000..499db922876
d0de29
--- /dev/null
d0de29
+++ b/gcc/testsuite/gfortran.dg/dec_format_empty_item_3.f
d0de29
@@ -0,0 +1,19 @@
d0de29
+! { dg-do compile }
d0de29
+! { dg-options "-fdec -fno-dec-blank-format-item" }
d0de29
+!
d0de29
+! Test blank/empty format items in format string
d0de29
+!
d0de29
+! Test case contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
d0de29
+! Modified by Mark Eggleston <mark.eggleston@codethink.com>
d0de29
+!
d0de29
+        PROGRAM blank_format_items
d0de29
+          INTEGER A/0/
d0de29
+
d0de29
+          OPEN(1, status="scratch")
d0de29
+          WRITE(1, 10) 100 ! { dg-error "FORMAT label 10 at \\(1\\) not defined" }
d0de29
+          REWIND(1)
d0de29
+          READ(1, 10) A ! { dg-error "FORMAT label 10 at \\(1\\) not defined" }
d0de29
+          IF (a.NE.100) STOP 1
d0de29
+          PRINT 10, A ! { dg-error "FORMAT label 10 at \\(1\\) not defined" }
d0de29
+10        FORMAT( I5,) ! { dg-error "Unexpected element" }
d0de29
+        END
d0de29
-- 
d0de29
2.11.0
d0de29