aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg
diff options
context:
space:
mode:
authorJerry DeLisle <jvdelisle@gcc.gnu.org>2008-03-15 07:32:13 +0000
committerJerry DeLisle <jvdelisle@gcc.gnu.org>2008-03-15 07:32:13 +0000
commit36193051a95f2dca22fbe613ab9820d720d69c8c (patch)
tree8a6e61bc6b744b4fd7f830b3b7cc8eb4ccdc8dac /gcc/testsuite/gfortran.dg
parent18fd89ef897c6dd493a2a55f3e94c464ace6aaab (diff)
downloadgcc-36193051a95f2dca22fbe613ab9820d720d69c8c.zip
gcc-36193051a95f2dca22fbe613ab9820d720d69c8c.tar.gz
gcc-36193051a95f2dca22fbe613ab9820d720d69c8c.tar.bz2
re PR fortran/35478 (internal compiler error: Segmentation fault)
2008-03-15 Jerry DeLisle <jvdelisle@gcc.gnu.org> PR testsuite/35478 gfortran.dg/generic_16.f90: New test. From-SVN: r133239
Diffstat (limited to 'gcc/testsuite/gfortran.dg')
-rw-r--r--gcc/testsuite/gfortran.dg/generic_16.f9034
1 files changed, 34 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/generic_16.f90 b/gcc/testsuite/gfortran.dg/generic_16.f90
new file mode 100644
index 0000000..cb6e34d
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/generic_16.f90
@@ -0,0 +1,34 @@
+! { dg-do compile }
+! PR35478 internal compiler error: Segmentation fault
+MODULE auxiliary
+ IMPLICIT NONE
+ INTEGER, PARAMETER, PRIVATE :: dp = SELECTED_REAL_KIND(15)
+ INTERFACE median
+ MODULE PROCEDURE R_valmed, I_valmed, D_valmed
+ END INTERFACE
+ PUBLIC :: median
+ PRIVATE :: R_valmed, I_valmed, D_valmed
+CONTAINS
+ RECURSIVE FUNCTION D_valmed (XDONT) RESULT (res_med)
+ Real (kind=dp), Dimension (:), Intent (In) :: XDONT
+ Real (kind=dp) :: res_med
+ res_med = 0.0d0
+ END FUNCTION D_valmed
+ RECURSIVE FUNCTION R_valmed (XDONT) RESULT (res_med)
+ Real, Dimension (:), Intent (In) :: XDONT
+ Real :: res_med
+ res_med = 0.0
+ END FUNCTION R_valmed
+ RECURSIVE FUNCTION I_valmed (XDONT) RESULT (res_med)
+ Integer, Dimension (:), Intent (In) :: XDONT
+ Integer :: res_med
+ res_med = 0
+ END FUNCTION I_valmed
+END MODULE auxiliary
+PROGRAM main
+ USE auxiliary
+ IMPLICIT NONE
+ INTEGER, PARAMETER :: dp = SELECTED_REAL_KIND(15)
+ REAL(kind=dp) :: rawData(2), data, work(3)
+ data = median(rawData, work) ! { dg-error "no specific function" }
+END PROGRAM main