source: LMDZ6/branches/Amaury_dev/libf/phy_common/lmdz_print_control.f90 @ 5467

Last change on this file since 5467 was 5116, checked in by abarral, 6 months ago

rename modules properly lmdz_*
move ismin, ismax, minmax into new lmdz_libmath.f90
(lint) uppercase fortran keywords

File size: 2.0 KB
Line 
1! $Id: $
2MODULE lmdz_print_control
3
4  INTEGER, SAVE :: lunout ! default output file identifier (6==screen)
5  INTEGER, SAVE :: prt_level ! debug output level
6  LOGICAL, SAVE :: debug ! flag to specify if in "debug mode"
7  LOGICAL, SAVE :: alert_first_CALL = .TRUE. ! for printing alerts on first CALL to routine only
8  LOGICAL, SAVE :: call_alert ! (combination of is_master and alert_first_CALL for easier use
9  !$OMP THREADPRIVATE(lunout,prt_level,debug, alert_first_call, call_alert)
10
11  ! NB: Module variable Initializations done by set_print_control
12  !     routine from lmdz_init_print_control to avoid circular
13  !     module dependencies
14
15CONTAINS
16
17  SUBROUTINE set_print_control(lunout_, prt_level_, debug_)
18    IMPLICIT NONE
19    INTEGER, INTENT(IN) :: lunout_
20    INTEGER, INTENT(IN) :: prt_level_
21    LOGICAL, INTENT(IN) :: debug_
22
23    lunout = lunout_
24    prt_level = prt_level_
25    debug = debug_
26
27  END SUBROUTINE set_print_control
28
29  SUBROUTINE prt_alerte(message, modname, niv_alerte)
30    ! Function to print different values of alarms when first encountered
31    ! Meant for informative purposee
32    IMPLICIT NONE
33    ! Arguments:
34    ! message: message to print out
35    ! modname: module/routine name
36    ! niv_alerte: alert level (0/1/2)
37    CHARACTER(LEN = *), INTENT(IN) :: modname
38    CHARACTER(LEN = *) :: message
39    INTEGER :: niv_alerte
40    ! local variables
41    CHARACTER(LEN = 7), DIMENSION(0:2) :: alarm_color = (/ 'VERTE  ', 'ORANGE ', 'ROUGE  ' /)
42    CHARACTER(LEN = 7) :: alarm_couleur
43    INTEGER :: alarm_file = 15 ! in case we want/need to print out the special alarms in a separate file
44
45    IF (alert_first_call) THEN
46      IF (alarm_file /= lunout) THEN
47        OPEN(unit = alarm_file, file = "ALERTES.txt")
48      ENDIF
49    ENDIF
50
51    alarm_couleur = alarm_color(niv_alerte)
52    IF (niv_alerte < 0 .OR. niv_alerte > 3) THEN
53      message = 'NIVEAU ALERTE INVALIDE  ' // message
54      alarm_couleur = 'NOIRE  '
55    ENDIF
56
57    WRITE(alarm_file, *)' ALERTE ', alarm_couleur, trim(modname), trim(message)
58
59  END SUBROUTINE prt_alerte
60
61
62END MODULE lmdz_print_control
Note: See TracBrowser for help on using the repository browser.