[multiple changes]
authorTobias Burnus <burnus@gcc.gnu.org>
Wed, 31 Oct 2007 15:10:12 +0000 (16:10 +0100)
committerTobias Burnus <burnus@gcc.gnu.org>
Wed, 31 Oct 2007 15:10:12 +0000 (16:10 +0100)
2007-10-31  Tobias Burnus  <burnus@net-b.de>

        PR fortran/33941
        * modules.c (intrinsics): Use only alphabetic names for
        intrinsic operators.

2007-10-31  Dominique d'Humieres  <dominiq@lps.ens.fr>
            Tobias Burnus  <burnus@net-b.de>

        PR fortran/33941
        * gfortran.dg/module_read_1.f90: New.

From-SVN: r129801

gcc/fortran/ChangeLog
gcc/fortran/module.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/module_read_1.f90 [new file with mode: 0644]

index 96e7a73c8843c74e6c2655732ec50866ae4749af..71c8d54c0c05827b9bdba84acdf14799a49da743 100644 (file)
@@ -1,3 +1,9 @@
+2007-10-31  Tobias Burnus  <burnus@net-b.de>
+
+       PR fortran/33941
+       * modules.c (intrinsics): Use only alphabetic names for
+       intrinsic operators.
+
 2007-10-31  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
 
        PR fortran/33162
index 12c451697df59917855e7086529e6c7f64439daa..a05437adf93899f21fe8cf34d0af3f2194d7678a 100644 (file)
@@ -2627,17 +2627,17 @@ static const mstring intrinsics[] =
     minit ("OR", INTRINSIC_OR),
     minit ("EQV", INTRINSIC_EQV),
     minit ("NEQV", INTRINSIC_NEQV),
-    minit ("==", INTRINSIC_EQ),
+    minit ("EQ_SIGN", INTRINSIC_EQ),
     minit ("EQ", INTRINSIC_EQ_OS),
-    minit ("/=", INTRINSIC_NE),
+    minit ("NE_SIGN", INTRINSIC_NE),
     minit ("NE", INTRINSIC_NE_OS),
-    minit (">", INTRINSIC_GT),
+    minit ("GT_SIGN", INTRINSIC_GT),
     minit ("GT", INTRINSIC_GT_OS),
-    minit (">=", INTRINSIC_GE),
+    minit ("GE_SIGN", INTRINSIC_GE),
     minit ("GE", INTRINSIC_GE_OS),
-    minit ("<", INTRINSIC_LT),
+    minit ("LT_SIGN", INTRINSIC_LT),
     minit ("LT", INTRINSIC_LT_OS),
-    minit ("<=", INTRINSIC_LE),
+    minit ("LE_SIGN", INTRINSIC_LE),
     minit ("LE", INTRINSIC_LE_OS),
     minit ("NOT", INTRINSIC_NOT),
     minit ("PARENTHESES", INTRINSIC_PARENTHESES),
index 46dcd8ff808805f08124a4a88b85d6b30acaf391..9ff71b51f2c9c02a6d0894a8aff3e25432adeb70 100644 (file)
@@ -1,3 +1,9 @@
+2007-10-31  Dominique d'Humieres  <dominiq@lps.ens.fr>
+           Tobias Burnus  <burnus@net-b.de>
+
+       PR fortran/33941
+       * gfortran.dg/module_read_1.f90: New.
+
 2007-10-31  Tom Tromey  <tromey@redhat.com>
 
        PR preprocessor/30786:
diff --git a/gcc/testsuite/gfortran.dg/module_read_1.f90 b/gcc/testsuite/gfortran.dg/module_read_1.f90
new file mode 100644 (file)
index 0000000..9a680a6
--- /dev/null
@@ -0,0 +1,29 @@
+! { dg-do run }
+! PR fortran/33941
+! The problem was that the intrinsic operators
+! were written to the module file as '/=' etc.
+! but this format was not understood on reading.
+!
+! Test case by Toby White, stripped down by
+! Dominique d'Humieres and Francois-Xavier Coudert
+
+module foo
+contains
+  function pop(n) result(item)
+    integer :: n
+    character(len=merge(1, 0, n > 0)) :: item
+  end function pop
+  function push(n) result(item)
+    integer :: n
+    character(len=merge(1, 0, n /= 0)) :: item
+  end function push
+end module foo
+
+program test
+  use foo
+  if(len(pop(0)) /= 0) call abort()
+  if(len(pop(1)) /= 1) call abort()
+  if(len(push(0)) /= 0) call abort()
+  if(len(push(1)) /= 1) call abort()
+end program
+! { dg-final { cleanup-modules "foo" } }