1 | ! $Id: $ |
---|
2 | MODULE 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 | |
---|
15 | CONTAINS |
---|
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 | |
---|
62 | END MODULE lmdz_print_control |
---|