Blame SOURCES/0005-dec-comparisons.patch

9805c9
From 6946d3e3e6a1d839772f4c59a5ab08901111800c Mon Sep 17 00:00:00 2001
9805c9
From: Mark Eggleston <markeggleston@codethink.com>
9805c9
Date: Thu, 23 May 2019 09:42:26 +0100
9805c9
Subject: [PATCH 05/16] dec comparisons
9805c9
9805c9
Allow comparison of Hollerith constants with numeric and character
9805c9
expressions. Also allow comparison of character literalsa with numeric
9805c9
expressions.
9805c9
9805c9
Enable using -fdec-comparisons or -fdec
9805c9
---
9805c9
 gcc/fortran/intrinsic.c                            |  5 +-
9805c9
 gcc/fortran/invoke.texi                            | 32 +++++++++++--
9805c9
 gcc/fortran/lang.opt                               |  5 ++
9805c9
 gcc/fortran/options.c                              |  1 +
9805c9
 gcc/fortran/resolve.c                              | 53 +++++++++++++++++++++-
9805c9
 .../gfortran.dg/dec-comparison-character_1.f90     | 18 ++++++++
9805c9
 .../gfortran.dg/dec-comparison-character_2.f90     | 18 ++++++++
9805c9
 .../gfortran.dg/dec-comparison-character_3.f90     | 17 +++++++
9805c9
 .../gfortran.dg/dec-comparison-complex_1.f90       | 22 +++++++++
9805c9
 .../gfortran.dg/dec-comparison-complex_2.f90       | 22 +++++++++
9805c9
 .../gfortran.dg/dec-comparison-complex_3.f90       | 22 +++++++++
9805c9
 gcc/testsuite/gfortran.dg/dec-comparison-int_1.f90 | 31 +++++++++++++
9805c9
 gcc/testsuite/gfortran.dg/dec-comparison-int_2.f90 | 31 +++++++++++++
9805c9
 gcc/testsuite/gfortran.dg/dec-comparison-int_3.f90 | 21 +++++++++
9805c9
 .../gfortran.dg/dec-comparison-real_1.f90          | 31 +++++++++++++
9805c9
 .../gfortran.dg/dec-comparison-real_2.f90          | 31 +++++++++++++
9805c9
 .../gfortran.dg/dec-comparison-real_3.f90          | 31 +++++++++++++
9805c9
 gcc/testsuite/gfortran.dg/dec-comparison.f90       | 41 +++++++++++++++++
9805c9
 18 files changed, 424 insertions(+), 8 deletions(-)
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-character_1.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-character_2.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-character_3.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-complex_1.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-complex_2.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-complex_3.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-int_1.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-int_2.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-int_3.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-real_1.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-real_2.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison-real_3.f90
9805c9
 create mode 100644 gcc/testsuite/gfortran.dg/dec-comparison.f90
9805c9
9805c9
diff --git a/gcc/fortran/intrinsic.c b/gcc/fortran/intrinsic.c
9805c9
index e94d5d3225f..6d47ae3105f 100644
9805c9
--- a/gcc/fortran/intrinsic.c
9805c9
+++ b/gcc/fortran/intrinsic.c
9805c9
@@ -4020,7 +4020,7 @@ add_conversions (void)
9805c9
 
9805c9
   /* Flang allows character conversions similar to Hollerith conversions
9805c9
      - the first characters will be turned into ascii values. */
9805c9
-  if (flag_dec_char_conversions)
9805c9
+  if (flag_dec_char_conversions || flag_dec_comparisons)
9805c9
     {
9805c9
       /* Character-Integer conversions.  */
9805c9
       for (i = 0; gfc_integer_kinds[i].kind != 0; i++)
9805c9
@@ -5150,7 +5150,8 @@ gfc_convert_type_warn (gfc_expr *expr, gfc_typespec *ts, int eflag, int wflag)
9805c9
 			     gfc_typename (&from_ts), gfc_typename (ts),
9805c9
 			     &expr->where);
9805c9
 	}
9805c9
-      else if (flag_dec_char_conversions && from_ts.type == BT_CHARACTER
9805c9
+      else if ((flag_dec_char_conversions || flag_dec_comparisons)
9805c9
+	       && from_ts.type == BT_CHARACTER
9805c9
 	       && (gfc_numeric_ts (ts) || ts->type == BT_LOGICAL))
9805c9
 	{
9805c9
 	  if (warn_conversion)
9805c9
diff --git a/gcc/fortran/invoke.texi b/gcc/fortran/invoke.texi
9805c9
index 8364c67b2df..d101b01e301 100644
9805c9
--- a/gcc/fortran/invoke.texi
9805c9
+++ b/gcc/fortran/invoke.texi
9805c9
@@ -117,15 +117,16 @@ by type.  Explanations are in the following sections.
9805c9
 @item Fortran Language Options
9805c9
 @xref{Fortran Dialect Options,,Options controlling Fortran dialect}.
9805c9
 @gccoptlist{-fall-intrinsics -fbackslash -fcray-pointer -fd-lines-as-code @gol
9805c9
--fd-lines-as-comments @gol
9805c9
--fdec -fdec-structure -fdec-intrinsic-ints -fdec-static -fdec-math @gol
9805c9
--fdec-include -fdefault-double-8 -fdefault-integer-8 -fdefault-real-8 @gol
9805c9
--fdefault-real-10 -fdefault-real-16 -fdollar-ok -ffixed-line-length-@var{n} @gol
9805c9
+-fd-lines-as-comments -fdec -fdec-structure -fdec-intrinsic-ints @gol
9805c9
+-fdec-static -fdec-math -fdec-include -fdec-format-defaults @gol
9805c9
+-fdec-add-missing-indexes -fdec-blank-format-item -fdec-comparisons @gol
9805c9
+-fdefault-double-8 -fdefault-integer-8 -fdefault-real-8 -fdefault-real-10 @gol
9805c9
+-fdefault-real-16 -fdollar-ok -ffixed-line-length-@var{n} @gol
9805c9
 -ffixed-line-length-none -fpad-source -ffree-form -ffree-line-length-@var{n} @gol
9805c9
 -ffree-line-length-none -fimplicit-none -finteger-4-integer-8 @gol
9805c9
 -fmax-identifier-length -fmodule-private -ffixed-form -fno-range-check @gol
9805c9
 -fopenacc -fopenmp -freal-4-real-10 -freal-4-real-16 -freal-4-real-8 @gol
9805c9
--freal-8-real-10 -freal-8-real-16 -freal-8-real-4 -std=@var{std}
9805c9
+-freal-8-real-10 -freal-8-real-16 -freal-8-real-4 -std=@var{std} @gol
9805c9
 -ftest-forall-temp
9805c9
 }
9805c9
 
9805c9
@@ -283,6 +284,27 @@ Enable parsing of INCLUDE as a statement in addition to parsing it as
9805c9
 INCLUDE line.  When parsed as INCLUDE statement, INCLUDE does not have to
9805c9
 be on a single line and can use line continuations.
9805c9
 
9805c9
+@item -fdec-add-missing-indexes
9805c9
+@opindex @code{fdec-add-missing-indexes}
9805c9
+Enable the insertion of missing dimensions using the lower bounds of those
9805c9
+dimensions.
9805c9
+
9805c9
+@item -fdec-format-defaults
9805c9
+@opindex @code{fdec-format-defaults}
9805c9
+Enable format specifiers F, G and I to be used without width specifiers,
9805c9
+default widths will be used instead.
9805c9
+
9805c9
+@item -fdec-blank-format-item
9805c9
+@opindex @code{fdec-blank-format-item}
9805c9
+Enable a blank format item at the end of a format specification i.e. nothing
9805c9
+following the final comma.
9805c9
+
9805c9
+@item -fdec-comparisons
9805c9
+@opindex @code{fdec-comparisons}
9805c9
+Enable comparison of Hollerith constants and character literals with numeric and
9805c9
+character expressions. Also enable comparison of Hollerith constants with numeric
9805c9
+expressions.
9805c9
+
9805c9
 @item -fdollar-ok
9805c9
 @opindex @code{fdollar-ok}
9805c9
 @cindex @code{$}
9805c9
diff --git a/gcc/fortran/lang.opt b/gcc/fortran/lang.opt
9805c9
index 5746b99b1d4..a957b90707f 100644
9805c9
--- a/gcc/fortran/lang.opt
9805c9
+++ b/gcc/fortran/lang.opt
9805c9
@@ -449,6 +449,11 @@ Fortran Var(flag_dec_char_conversions)
9805c9
 Enable the use of character literals in assignments and data statements
9805c9
 for non-character variables.
9805c9
 
9805c9
+fdec-comparisons
9805c9
+Fortran Var(flag_dec_comparisons)
9805c9
+Enable the use of hollerith constants in comparisons. Also enables comparison
9805c9
+of character literals and numeric vaiables.
9805c9
+
9805c9
 fdec-include
9805c9
 Fortran Var(flag_dec_include)
9805c9
 Enable legacy parsing of INCLUDE as statement.
9805c9
diff --git a/gcc/fortran/options.c b/gcc/fortran/options.c
9805c9
index e97b1568810..b652be70f3d 100644
9805c9
--- a/gcc/fortran/options.c
9805c9
+++ b/gcc/fortran/options.c
9805c9
@@ -77,6 +77,7 @@ set_dec_flags (int value)
9805c9
   SET_BITFLAG (flag_dec_format_defaults, value, value);
9805c9
   SET_BITFLAG (flag_dec_duplicates, value, value);
9805c9
   SET_BITFLAG (flag_dec_char_conversions, value, value);
9805c9
+  SET_BITFLAG (flag_dec_comparisons, value, value);
9805c9
 }
9805c9
 
9805c9
 /* Finalize DEC flags.  */
9805c9
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
9805c9
index 43559185481..c8b6333874b 100644
9805c9
--- a/gcc/fortran/resolve.c
9805c9
+++ b/gcc/fortran/resolve.c
9805c9
@@ -3888,6 +3888,30 @@ convert_integer_to_logical (gfc_expr *e)
9805c9
     }
9805c9
 }
9805c9
 
9805c9
+/* Return true if TYPE is character based, false otherwise.  */
9805c9
+
9805c9
+static int
9805c9
+is_character_based (bt type)
9805c9
+{
9805c9
+  return type == BT_CHARACTER || type == BT_HOLLERITH;
9805c9
+}
9805c9
+
9805c9
+
9805c9
+/* If E is a hollerith, convert it to character and issue a warning
9805c9
+   for the conversion.  */
9805c9
+
9805c9
+static void
9805c9
+convert_hollerith_to_character (gfc_expr *e)
9805c9
+{
9805c9
+  if (e->ts.type == BT_HOLLERITH)
9805c9
+    {
9805c9
+      gfc_typespec t;
9805c9
+      t.type = BT_CHARACTER;
9805c9
+      t.kind = e->ts.kind;
9805c9
+      gfc_convert_type_warn (e, &t, 2, 1);
9805c9
+    }
9805c9
+}
9805c9
+
9805c9
 /* If E is a logical, convert it to an integer and issue a warning
9805c9
    for the conversion.  */
9805c9
 
9805c9
@@ -3904,6 +3928,17 @@ convert_logical_to_integer (gfc_expr *e)
9805c9
     }
9805c9
 }
9805c9
 
9805c9
+/* Convert to numeric and issue a warning for the conversion.  */
9805c9
+
9805c9
+static void
9805c9
+convert_to_numeric (gfc_expr *a, gfc_expr *b)
9805c9
+{
9805c9
+  gfc_typespec t;
9805c9
+  t.type = b->ts.type;
9805c9
+  t.kind = b->ts.kind;
9805c9
+  gfc_convert_type_warn (a, &t, 2, 1);
9805c9
+}
9805c9
+
9805c9
 /* Resolve an operator expression node.  This can involve replacing the
9805c9
    operation with a user defined function call.  */
9805c9
 
9805c9
@@ -4108,6 +4143,13 @@ resolve_operator (gfc_expr *e)
9805c9
 	  convert_logical_to_integer (op2);
9805c9
 	}
9805c9
 
9805c9
+      if (flag_dec_comparisons && is_character_based (op1->ts.type)
9805c9
+          && is_character_based (op2->ts.type))
9805c9
+	{
9805c9
+	  convert_hollerith_to_character (op1);
9805c9
+	  convert_hollerith_to_character (op2);
9805c9
+	}
9805c9
+
9805c9
       if (op1->ts.type == BT_CHARACTER && op2->ts.type == BT_CHARACTER
9805c9
 	  && op1->ts.kind == op2->ts.kind)
9805c9
 	{
9805c9
@@ -4116,6 +4158,15 @@ resolve_operator (gfc_expr *e)
9805c9
 	  break;
9805c9
 	}
9805c9
 
9805c9
+      if (flag_dec_comparisons && is_character_based (op1->ts.type)
9805c9
+          && op1->expr_type == EXPR_CONSTANT && gfc_numeric_ts (&op2->ts))
9805c9
+	convert_to_numeric (op1, op2);
9805c9
+
9805c9
+      if (flag_dec_comparisons && gfc_numeric_ts (&op1->ts)
9805c9
+	  && is_character_based (op2->ts.type)
9805c9
+	  && op2->expr_type == EXPR_CONSTANT)
9805c9
+	convert_to_numeric (op2, op1);
9805c9
+
9805c9
       if (gfc_numeric_ts (&op1->ts) && gfc_numeric_ts (&op2->ts))
9805c9
 	{
9805c9
 	  gfc_type_convert_binary (e, 1);
9805c9
@@ -10499,7 +10550,7 @@ resolve_ordinary_assign (gfc_code *code, gfc_namespace *ns)
9805c9
 
9805c9
   if ((gfc_numeric_ts (&lhs->ts) || lhs->ts.type == BT_LOGICAL)
9805c9
       && rhs->ts.type == BT_CHARACTER
9805c9
-      && rhs->expr_type != EXPR_CONSTANT)
9805c9
+      && (rhs->expr_type != EXPR_CONSTANT || !flag_dec_char_conversions))
9805c9
     {
9805c9
       gfc_error ("Cannot convert CHARACTER into %s at %L",
9805c9
                  gfc_typename (&lhs->ts),     
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-character_1.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-character_1.f90
9805c9
new file mode 100644
9805c9
index 00000000000..d8209163a0e
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-character_1.f90
9805c9
@@ -0,0 +1,18 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-fdec -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  character(4) :: c = 4HJMAC ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne.4HJMAC) stop 1 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne."JMAC") stop 2 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.eq."JMAN") stop 3 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("JMAC".eq.4HJMAN) stop 4 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("AAAA".eq.5HAAAAA) stop 5 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("BBBBB".eq.5HBBBB ) stop 6 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne.c) stop 7 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (c.ne.4HJMAC) stop 8 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-character_2.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-character_2.f90
9805c9
new file mode 100644
9805c9
index 00000000000..7332acbaf5c
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-character_2.f90
9805c9
@@ -0,0 +1,18 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-fdec-comparisons -std=legacy -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  character(4) :: c = 4HJMAC ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne.4HJMAC) stop 1 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne."JMAC") stop 2 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.eq."JMAN") stop 3 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("JMAC".eq.4HJMAN) stop 4 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("AAAA".eq.5HAAAAA) stop 5 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if ("BBBBB".eq.5HBBBB ) stop 6 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (4HJMAC.ne.c) stop 7 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+  if (c.ne.4HJMAC) stop 8 ! { dg-warning "HOLLERITH to CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-character_3.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-character_3.f90
9805c9
new file mode 100644
9805c9
index 00000000000..c20c012478a
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-character_3.f90
9805c9
@@ -0,0 +1,17 @@
9805c9
+! { dg-do compile }
9805c9
+! { dg-options "-fdec -fno-dec-comparisons" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  character(4) :: c = 4HJMAC
9805c9
+  if (4HJMAC.ne.4HJMAC) stop 1 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HJMAC.ne."JMAC") stop 2 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HJMAC.eq."JMAN") stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if ("JMAC".eq.4HJMAN) stop 4 !  { dg-error "Operands of comparison" }
9805c9
+  if ("AAAA".eq.5HAAAAA) stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if ("BBBBB".eq.5HBBBB ) stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HJMAC.ne.c) stop 7 ! { dg-error "Operands of comparison" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-complex_1.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-complex_1.f90
9805c9
new file mode 100644
9805c9
index 00000000000..3495f2ae414
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-complex_1.f90
9805c9
@@ -0,0 +1,22 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  complex(4) :: a
9805c9
+  complex(4) :: b
9805c9
+  a = 8HABCDABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCDABCD", b);
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.8HABCDABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.8HABCEABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (8HABCDABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (8HABCEABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCDABCD") stop 5 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCEABCE") stop 6 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCDABCD".ne.b) stop 7 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCEABCE".eq.b) stop 8 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-complex_2.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-complex_2.f90
9805c9
new file mode 100644
9805c9
index 00000000000..c38042cc600
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-complex_2.f90
9805c9
@@ -0,0 +1,22 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  complex(4) :: a
9805c9
+  complex(4) :: b
9805c9
+  a = 8HABCDABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCDABCD", b);
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.8HABCDABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.8HABCEABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (8HABCDABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (8HABCEABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCDABCD") stop 5 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCEABCE") stop 6 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCDABCD".ne.b) stop 7 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCEABCE".eq.b) stop 8 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-complex_3.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-complex_3.f90
9805c9
new file mode 100644
9805c9
index 00000000000..9b27fc4d502
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-complex_3.f90
9805c9
@@ -0,0 +1,22 @@
9805c9
+! { dg-do compile }
9805c9
+! { dg-options "-std=legacy -fdec -fno-dec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  complex(4) :: a
9805c9
+  complex(4) :: b
9805c9
+  a = 8HABCDABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCDABCD", b);
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.8HABCDABCD) stop 1 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.eq.8HABCEABCE) stop 2 ! { dg-error "Operands of comparison" }
9805c9
+  if (8HABCDABCD.ne.b) stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if (8HABCEABCE.eq.b) stop 4 ! { dg-error "Operands of comparison" }
9805c9
+  ! character literals
9805c9
+  if (a.ne."ABCDABCD") stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.eq."ABCEABCE") stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCDABCD".ne.b) stop 7 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCEABCE".eq.b) stop 8 ! { dg-error "Operands of comparison" }
9805c9
+end program
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-int_1.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-int_1.f90
9805c9
new file mode 100644
9805c9
index 00000000000..c93b61e29cf
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-int_1.f90
9805c9
@@ -0,0 +1,31 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  integer(4) :: a
9805c9
+  integer(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCD") stop 9 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCE") stop 10 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCD".ne.b) stop 11 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".eq.b) stop 12 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".lt.a) stop 13 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.gt."ABCE") stop 14 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".le.a) stop 15 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.ge."ABCE") stop 16 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-int_2.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-int_2.f90
9805c9
new file mode 100644
9805c9
index 00000000000..cd1ae783d41
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-int_2.f90
9805c9
@@ -0,0 +1,31 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  integer(4) :: a
9805c9
+  integer(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCD") stop 9 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCE") stop 10 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCD".ne.b) stop 11 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".eq.b) stop 12 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".lt.a) stop 13 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.gt."ABCE") stop 14 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".le.a) stop 15 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.ge."ABCE") stop 16 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-int_3.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-int_3.f90
9805c9
new file mode 100644
9805c9
index 00000000000..b350075afe7
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-int_3.f90
9805c9
@@ -0,0 +1,21 @@
9805c9
+! { dg-do compile }
9805c9
+! { dg-options "-fdec -fno-dec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  integer(4) :: a
9805c9
+  integer(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-error "Operands of comparison" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-real_1.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-real_1.f90
9805c9
new file mode 100644
9805c9
index 00000000000..08b66aaebfd
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-real_1.f90
9805c9
@@ -0,0 +1,31 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  real(4) :: a
9805c9
+  real(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCD") stop 9 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCE") stop 10 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCD".ne.b) stop 11 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".eq.b) stop 12 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".lt.a) stop 13 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.gt."ABCE") stop 14 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".le.a) stop 15 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.ge."ABCE") stop 16 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-real_2.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-real_2.f90
9805c9
new file mode 100644
9805c9
index 00000000000..244abb84868
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-real_2.f90
9805c9
@@ -0,0 +1,31 @@
9805c9
+! { dg-do run }
9805c9
+! { dg-options "-std=legacy -fdec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  real(4) :: a
9805c9
+  real(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCD") stop 9 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.eq."ABCE") stop 10 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCD".ne.b) stop 11 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".eq.b) stop 12 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".lt.a) stop 13 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.gt."ABCE") stop 14 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if ("ABCE".le.a) stop 15 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+  if (a.ge."ABCE") stop 16 ! { dg-warning "Conversion from CHARACTER" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison-real_3.f90 b/gcc/testsuite/gfortran.dg/dec-comparison-real_3.f90
9805c9
new file mode 100644
9805c9
index 00000000000..111c648f08c
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison-real_3.f90
9805c9
@@ -0,0 +1,31 @@
9805c9
+! { dg-do compile }
9805c9
+! { dg-options "-std=legacy -fdec -fno-dec-comparisons -Wconversion" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+
9805c9
+program convert
9805c9
+  real(4) :: a
9805c9
+  real(4) :: b
9805c9
+  a = 4HABCD ! { dg-warning "Conversion from HOLLERITH" }
9805c9
+  b = transfer("ABCD", b)
9805c9
+  ! Hollerith constants
9805c9
+  if (a.ne.4HABCD) stop 1 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.eq.4HABCE) stop 2 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCD.ne.b) stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.eq.b) stop 4 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.lt.a) stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.gt.4HABCE) stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  if (4HABCE.le.a) stop 7 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.ge.4HABCE) stop 8 ! { dg-error "Operands of comparison" }
9805c9
+  ! Character literals
9805c9
+  if (a.ne."ABCD") stop 9 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.eq."ABCE") stop 10 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCD".ne.b) stop 11 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCE".eq.b) stop 12 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCE".lt.a) stop 13 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.gt."ABCE") stop 14 ! { dg-error "Operands of comparison" }
9805c9
+  if ("ABCE".le.a) stop 15 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.ge."ABCE") stop 16 ! { dg-error "Operands of comparison" }
9805c9
+end program
9805c9
+
9805c9
diff --git a/gcc/testsuite/gfortran.dg/dec-comparison.f90 b/gcc/testsuite/gfortran.dg/dec-comparison.f90
9805c9
new file mode 100644
9805c9
index 00000000000..b0b28e55111
9805c9
--- /dev/null
9805c9
+++ b/gcc/testsuite/gfortran.dg/dec-comparison.f90
9805c9
@@ -0,0 +1,41 @@
9805c9
+! { dg-do compile }
9805c9
+! { dg-options "-fdec" }
9805c9
+!
9805c9
+! Test case contributed by Mark Eggleston  <mark.eggleston@codethink.com>
9805c9
+!
9805c9
+! Hollerith constants and character literals are allowed in comparisons,
9805c9
+! check that character variables can not be compared with numeric variables.
9805c9
+
9805c9
+program convert
9805c9
+  character(4) :: a = 4hJMAC
9805c9
+  integer(4) :: b = "JMAC"
9805c9
+  real(4) :: c = "JMAC"
9805c9
+  complex(4) :: d = "JMACJMAC"
9805c9
+  ! integers
9805c9
+  if (a.ne.b) stop 1 ! { dg-error "Operands of comparison" }
9805c9
+  if (b.eq.a) stop 2 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.ge.b) stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if (b.ge.a) stop 4 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.gt.b) stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if (b.gt.a) stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.le.b) stop 3 ! { dg-error "Operands of comparison" }
9805c9
+  if (b.le.a) stop 4 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.lt.b) stop 5 ! { dg-error "Operands of comparison" }
9805c9
+  if (b.lt.a) stop 6 ! { dg-error "Operands of comparison" }
9805c9
+  ! reals
9805c9
+  if (a.ne.c) stop 7 ! { dg-error "Operands of comparison" }
9805c9
+  if (c.eq.a) stop 8 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.ge.c) stop 9 ! { dg-error "Operands of comparison" }
9805c9
+  if (c.ge.a) stop 10 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.gt.c) stop 11 ! { dg-error "Operands of comparison" }
9805c9
+  if (c.gt.a) stop 12 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.le.c) stop 13 ! { dg-error "Operands of comparison" }
9805c9
+  if (c.le.a) stop 14 ! { dg-error "Operands of comparison" }
9805c9
+  if (a.lt.c) stop 15 ! { dg-error "Operands of comparison" }
9805c9
+  if (c.lt.a) stop 16 ! { dg-error "Operands of comparison" }
9805c9
+  ! complexes
9805c9
+  a = "JMACJMAC"
9805c9
+  if (a.ne.d) stop 17 ! { dg-error "Operands of comparison" }
9805c9
+  if (d.eq.a) stop 18 ! { dg-error "Operands of comparison" }
9805c9
+end program
9805c9
+
9805c9
-- 
9805c9
2.11.0
9805c9