From 10f783ca377f9b5fb67c3c07bd9c6942fbf21259 Mon Sep 17 00:00:00 2001 From: Michele Guerini Rocco Date: Wed, 11 Sep 2024 17:18:37 +0200 Subject: [PATCH] src/gray_errors.f90: avoid strange macro Some compilers are not happy with this. --- src/gray_errors.f90 | 56 ++++++++++++++++++++++++++------------------- 1 file changed, 32 insertions(+), 24 deletions(-) diff --git a/src/gray_errors.f90 b/src/gray_errors.f90 index 74e8673..06b5879 100644 --- a/src/gray_errors.f90 +++ b/src/gray_errors.f90 @@ -23,8 +23,6 @@ module gray_errors end type ! macros used for defining errors -# define _ , -# define list(x) reshape([character(64) :: x], [10], [character(64) :: '']) # define after(x) x%offset + x%subcases ! All GRAY errors @@ -32,43 +30,53 @@ module gray_errors type(error_spec), parameter :: large_npl = & error_spec(offset=0, subcases=2, & mod='gray_core', proc='gray_main', & - msg=list('N∥ is too large (>0.99)'_ - 'N∥ is too large (>1.05)')) + msg=reshape([character(64) :: & + 'N∥ is too large (>0.99)', & + 'N∥ is too large (>1.05)' & + ], [10], [''])) - type(error_spec), parameter :: dielectric_tensor = & - error_spec(offset=after(large_npl), subcases=2, & - mod='gray_core', proc='gray_main', & - msg=list('ε tensor, overflow in `fsup`'_ - 'ε tensor, integration error in `hermitian_2`')) + type(error_spec), parameter :: dielectric_tensor = & + error_spec(offset=after(large_npl), subcases=2, & + mod='gray_core', proc='gray_main', & + msg=reshape([character(64) :: & + 'ε tensor, overflow in `fsup`', & + 'ε tensor, integration error in `hermitian_2`' & + ], [10], [''])) - type(error_spec), parameter :: warmdisp_convergence = & - error_spec(offset=after(dielectric_tensor), subcases=2, & - mod='dispersion', proc='warmdisp', & - msg=list('failed to converge, returned fallback value'_ - 'failed to converge, returned last value')) + type(error_spec), parameter :: warmdisp_convergence = & + error_spec(offset=after(dielectric_tensor), subcases=2, & + mod='dispersion', proc='warmdisp', & + msg=reshape([character(64) :: & + 'failed to converge, returned fallback value', & + 'failed to converge, returned last value' & + ], [10], [''])) type(error_spec), parameter :: warmdisp_result = & error_spec(offset=after(warmdisp_convergence), subcases=2, & mod='dispersion', proc='warmdisp', & - msg=list('final N⊥² is NaN or ±Infinity'_ - 'final N⊥² in 3rd quadrant')) + msg=reshape([character(64) :: & + 'final N⊥² is NaN or ±Infinity', & + 'final N⊥² in 3rd quadrant' & + ], [10], [''])) type(error_spec), parameter :: negative_absorption = & error_spec(offset=after(warmdisp_result), subcases=1, & mod='gray_core', proc='alpha_effj', & - msg=list('negative absorption coeff.')) + msg=reshape(['negative absorption coeff.'], [10], [''])) type(error_spec), parameter :: fpp_integration = & error_spec(offset=after(negative_absorption), subcases=1, & mod='eccd', proc='eccdeff', & - msg=list('fpp integration error')) + msg=reshape(['fpp integration error'], [10], [''])) - type(error_spec), parameter :: fcur_integration = & - error_spec(offset=after(fpp_integration), subcases=3, & - mod='eccd', proc='eccdeff', & - msg=list('fcur integration error (no trapping)'_ - 'fcur integration error (1st trapping region)'_ - 'fcur integration error (2st trapping region)')) + type(error_spec), parameter :: fcur_integration = & + error_spec(offset=after(fpp_integration), subcases=3, & + mod='eccd', proc='eccdeff', & + msg=reshape([character(64) :: & + 'fcur integration error (no trapping)', & + 'fcur integration error (1st trapping region)', & + 'fcur integration error (2st trapping region)' & + ], [10], [''])) ! Errors occuring during raytracing type(error_spec), parameter :: raytracing_errors(*) = [large_npl]