diff options
| author | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-05-11 14:52:51 +0000 | 
|---|---|---|
| committer | tobi <tobi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-05-11 14:52:51 +0000 | 
| commit | 65cf6ae72c1123fdf049b26ad11462f32894ee3b (patch) | |
| tree | 93b690b02e38975caed6d3a50fc5044c5bb9879b /gcc | |
| parent | dd41a27bc51c171701568a1111898742957e6f49 (diff) | |
| download | ppe42-gcc-65cf6ae72c1123fdf049b26ad11462f32894ee3b.tar.gz ppe42-gcc-65cf6ae72c1123fdf049b26ad11462f32894ee3b.zip  | |
fortran/
	* resolve.c (resolve_symbol): Copy 'pointer' and 'dimension'
	attribute from result symbol to function symbol.
testsuite/
	* gfortran.dg/func_result_2.f90: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@99580 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
| -rw-r--r-- | gcc/fortran/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/fortran/resolve.c | 2 | ||||
| -rw-r--r-- | gcc/fortran/trans-expr.c | 2 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
| -rw-r--r-- | gcc/testsuite/gfortran.dg/func_result_2.f90 | 10 | 
5 files changed, 22 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ee08d1fffb5..c5ae3929d48 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2005-05-11  Tobias Schl"uter  <tobias.schlueter@physik.uni-muenchen.de> + +	* resolve.c (resolve_symbol): Copy 'pointer' and 'dimension' +	attribute from result symbol to function symbol. +  2005-05-10  Tobias Schl"uter  <tobias.schlueter@physik.uni-muenchen.de>  	PR fortran/20178 diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 9b097fe9a15..5f7a76a57a4 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -4061,6 +4061,8 @@ resolve_symbol (gfc_symbol * sym)  	      sym->ts = sym->result->ts;  	      sym->as = gfc_copy_array_spec (sym->result->as); +	      sym->attr.dimension = sym->result->attr.dimension; +	      sym->attr.pointer = sym->result->attr.pointer;  	    }  	}      } diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index 35c3f12883d..52a532d2408 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -1288,7 +1288,7 @@ gfc_conv_function_call (gfc_se * se, gfc_symbol * sym,        if (!se->direct_byref)  	{ -	  if (sym->result->attr.dimension) +	  if (sym->attr.dimension)  	    {  	      if (flag_bounds_check)  		{ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 33a1e02c39b..6e3cae14cc9 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-05-11  Tobias Schl"uter  <tobias.schlueter@physik.uni-muenchen.de> + +	* gfortran.dg/func_result_2.f90: New test. +  2005-05-11  Bud Davis  <bdavis@gfortran.org>  	* gfortran.dg/dev_null.f90: New test. diff --git a/gcc/testsuite/gfortran.dg/func_result_2.f90 b/gcc/testsuite/gfortran.dg/func_result_2.f90 new file mode 100644 index 00000000000..2b457d9d44f --- /dev/null +++ b/gcc/testsuite/gfortran.dg/func_result_2.f90 @@ -0,0 +1,10 @@ +! { dg-do run } +! Character functions with a result clause were broken +program testch +  if (ch().ne."hello     ") call abort() +contains +  function ch result(str) +    character(len = 10)  :: str +    str ="hello" +  end function ch +end program testch  | 

