corrected standard check to make f2py working with gfortran
This commit is contained in:
parent
0cb983606f
commit
b4775249e8
|
@ -111,7 +111,11 @@ endif
|
||||||
|
|
||||||
ifneq "$(FASTBUILD)" "YES"
|
ifneq "$(FASTBUILD)" "YES"
|
||||||
STANDARD_CHECK_ifort ?=-stand f08 -standard-semantics -warn stderrors
|
STANDARD_CHECK_ifort ?=-stand f08 -standard-semantics -warn stderrors
|
||||||
STANDARD_CHECK_gfortran ?=-std=f2008
|
STANDARD_CHECK_gfortran ?=-std=f2008 -fall-intrinsics
|
||||||
|
#-fall-intrinsics: all intrinsic procedures (including the GNU-specific extensions) are accepted. This can be useful with -std=f95 to force standard-compliance
|
||||||
|
# but get access to the full range of intrinsics available with gfortran. As a consequence, -Wintrinsics-std will be ignored and no user-defined procedure with
|
||||||
|
# the same name as any intrinsic will be called except when it is explicitly declared external
|
||||||
|
#-Wintrinsics-std: warnings because of "flush" is not longer in the standard, but still an intrinsic fuction of the compilers:
|
||||||
endif
|
endif
|
||||||
|
|
||||||
OPTIMIZATION_OFF_ifort :=-O0 -no-ip
|
OPTIMIZATION_OFF_ifort :=-O0 -no-ip
|
||||||
|
@ -190,7 +194,6 @@ COMPILE_OPTIONS_gfortran :=$(COMPILE_OPTIONS_gfortran)\
|
||||||
-ffree-line-length-132\
|
-ffree-line-length-132\
|
||||||
-fno-range-check\
|
-fno-range-check\
|
||||||
-fimplicit-none\
|
-fimplicit-none\
|
||||||
-fall-intrinsics\
|
|
||||||
-pedantic\
|
-pedantic\
|
||||||
-Warray-bounds\
|
-Warray-bounds\
|
||||||
-Wampersand\
|
-Wampersand\
|
||||||
|
@ -208,14 +211,12 @@ COMPILE_OPTIONS_gfortran :=$(COMPILE_OPTIONS_gfortran)\
|
||||||
-Wunused\
|
-Wunused\
|
||||||
-Wall\
|
-Wall\
|
||||||
-Wextra\
|
-Wextra\
|
||||||
-Wintrinsics-std
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
#-xf95-cpp-input: preprocessor
|
#-xf95-cpp-input: preprocessor
|
||||||
#-ffree-line-length-132: restrict line length to the standard 132 characters
|
#-ffree-line-length-132: restrict line length to the standard 132 characters
|
||||||
#-fno-range-check: disables checking if result can be represented by variable. Needs to be set to enable DAMASK_NaN
|
#-fno-range-check: disables checking if result can be represented by variable. Needs to be set to enable DAMASK_NaN
|
||||||
#-fimplicit-none: assume "implicit-none" even if not present in source
|
#-fimplicit-none: assume "implicit-none" even if not present in source
|
||||||
#-fall-intrinsics:
|
|
||||||
#-pedantic: more strict on standard, enables some of the warnings below
|
#-pedantic: more strict on standard, enables some of the warnings below
|
||||||
#-Warray-bounds: checks if array reference is out of bounds at compile time. use -fcheck-bounds to also check during runtime
|
#-Warray-bounds: checks if array reference is out of bounds at compile time. use -fcheck-bounds to also check during runtime
|
||||||
#-Wampersand: checks if a character expression is continued proberly by an ampersand at the end of the line and at the beginning of the new line
|
#-Wampersand: checks if a character expression is continued proberly by an ampersand at the end of the line and at the beginning of the new line
|
||||||
|
@ -234,7 +235,6 @@ endif
|
||||||
# -value:
|
# -value:
|
||||||
# -parameter: find usused variables with "parameter" attribute
|
# -parameter: find usused variables with "parameter" attribute
|
||||||
#-Wextra:
|
#-Wextra:
|
||||||
#-Wintrinsics-std: warnings because of "flush" is not longer in the standard, but still an intrinsic fuction of the compilers:
|
|
||||||
###################################################################################################
|
###################################################################################################
|
||||||
#OPTIONS FOR GFORTRAN 4.6
|
#OPTIONS FOR GFORTRAN 4.6
|
||||||
#-Wsuggest-attribute=const:
|
#-Wsuggest-attribute=const:
|
||||||
|
|
|
@ -48,8 +48,8 @@ if options.compiler not in compilers:
|
||||||
parser.error('compiler switch "--F90" has to be one out of: %s'%(', '.join(compilers)))
|
parser.error('compiler switch "--F90" has to be one out of: %s'%(', '.join(compilers)))
|
||||||
|
|
||||||
f2py_compiler = {
|
f2py_compiler = {
|
||||||
'gfortran': 'gnu95 --f90flags="-fno-range-check -xf95-cpp-input -std=f2008"',
|
'gfortran': 'gnu95 --f90flags="-fno-range-check -xf95-cpp-input -std=f2008 -fall-intrinsics"',
|
||||||
'gnu95': 'gnu95 --f90flags="-fno-range-check -xf95-cpp-input -std=f2008"',
|
'gnu95': 'gnu95 --f90flags="-fno-range-check -xf95-cpp-input -std=f2008 -fall-intrinsics"',
|
||||||
'intel32': 'intel --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
'intel32': 'intel --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
||||||
'intel': 'intelem --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
'intel': 'intelem --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
||||||
'ifort': 'intelem --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
'ifort': 'intelem --f90flags="-fpp -stand f03 -diag-disable 5268"',
|
||||||
|
|
Loading…
Reference in New Issue