38 use,
intrinsic :: iso_fortran_env, only : stdout => output_unit, &
52 integer,
private :: indent_
53 integer,
private :: section_id_
54 integer,
private :: tab_size_
55 integer,
private :: level_
56 integer,
private :: unit_
58 character(len=LOG_SIZE),
private :: section_header =
""
75 procedure,
private, pass(this) :: print_section_header => &
99 class(
log_t),
intent(inout) :: this
100 character(len=255) :: log_level
101 character(len=255) :: log_tab_size
102 character(len=255) :: log_file
103 integer :: envvar_len
108 call get_environment_variable(
"NEKO_LOG_TAB_SIZE", log_tab_size, envvar_len)
109 if (envvar_len .gt. 0)
then
110 read(log_tab_size(1:envvar_len), *) this%tab_size_
115 call get_environment_variable(
"NEKO_LOG_LEVEL", log_level, envvar_len)
116 if (envvar_len .gt. 0)
then
117 read(log_level(1:envvar_len), *) this%level_
122 call get_environment_variable(
"NEKO_LOG_FILE", log_file, envvar_len)
123 if (envvar_len .gt. 0)
then
124 open(newunit = this%unit_,
file = trim(log_file), status =
'replace', &
134 class(
log_t),
intent(inout) :: this
137 if (this%section_id_ .ne. 0)
then
147 call this%end_section()
150 if (this%unit_ .ne. stdout)
then
166 class(
log_t),
intent(inout) :: this
169 this%section_id_ = this%section_id_ + 1
170 this%indent_ = this%indent_ + this%tab_size_
177 class(
log_t),
intent(inout) :: this
180 if (this%section_id_ .eq. 0)
then
183 this%section_id_ = this%section_id_ - 1
184 this%indent_ = this%indent_ - this%tab_size_
187 this%section_header =
""
193 class(
log_t),
intent(in) :: this
196 write(this%unit_,
'(A)', advance =
'no') repeat(
' ', this%indent_)
203 class(
log_t),
intent(in) :: this
204 integer,
optional :: lvl
208 if (
present(lvl))
then
214 if (lvl_ .gt. this%level_)
then
219 write(this%unit_,
'(A)')
''
226 class(
log_t),
intent(inout) :: this
227 character(len=*),
intent(in) :: msg
228 integer,
optional :: lvl
231 if (
present(lvl))
then
237 if (lvl_ .gt. this%level_)
then
241 if (len_trim(this%section_header) .gt. 0)
then
242 call this%print_section_header(lvl)
247 write(this%unit_,
'(A)') trim(msg)
254 class(
log_t),
intent(in) :: this
255 character(len=*),
intent(in) :: version
256 character(len=*),
intent(in) :: build_info
259 write(this%unit_,
'(A)')
''
260 write(this%unit_,
'(1X,A)')
' _ __ ____ __ __ ____ '
261 write(this%unit_,
'(1X,A)')
' / |/ / / __/ / //_/ / __ \ '
262 write(this%unit_,
'(1X,A)')
' / / / _/ / ,< / /_/ / '
263 write(this%unit_,
'(1X,A)')
'/_/|_/ /___/ /_/|_| \____/ '
264 write(this%unit_,
'(A)')
''
265 write(this%unit_,
'(1X,A,A,A)')
'(version: ', trim(version),
')'
266 write(this%unit_,
'(1X,A)') trim(build_info)
267 write(this%unit_,
'(A)')
''
274 class(
log_t),
intent(in) :: this
275 character(len=*),
intent(in) :: msg
279 write(stderr,
'(A,A,A)')
'*** ERROR: ', trim(msg),
' ***'
286 class(
log_t),
intent(in) :: this
287 character(len=*),
intent(in) :: msg
291 write(this%unit_,
'(A,A,A)')
'*** WARNING: ', trim(msg),
' ***'
301 class(
log_t),
intent(inout) :: this
302 character(len=*),
intent(in) :: feature
303 character(len=*),
intent(in) :: removal_version
304 character(len=*),
intent(in),
optional :: extra_info
305 character(len=50),
dimension(:),
allocatable :: tmp_list
306 character(len=255) :: deprecation_error
307 character(len=LOG_SIZE) :: msg
317 allocate(
character(len=50) :: deprecated_list(1))
318 deprecated_list = trim(feature)
320 do i = 1,
size(deprecated_list)
321 if (trim(deprecated_list(i)) .eq. trim(feature))
return
325 call move_alloc(deprecated_list, tmp_list)
326 allocate(
character(len=50)::deprecated_list(size(tmp_list)+1))
327 deprecated_list(1:
size(tmp_list)) = tmp_list
328 deprecated_list(
size(tmp_list) + 1) = trim(feature)
333 write(msg,
'(A,A)')
'*** DEPRECATION: ', trim(feature)
335 write(msg,
'(A,A,A)')
'The feature "', trim(feature),
'" is deprecated.'
337 write(msg,
'(A,A,A)')
'It will be removed in version ', &
338 trim(removal_version),
'.'
341 if (
present(extra_info))
then
347 deprecation_error =
""
348 call get_environment_variable(
"NEKO_DEPRECATION_ERROR", &
351 if (trim(deprecation_error) .eq.
"1")
then
352 call neko_error(
'Deprecated feature "' // trim(feature) // &
353 '" is scheduled for removal in version: ' // &
354 trim(removal_version) //
' (current version: ' // &
357 call neko_warning(
'Deprecated feature "' // trim(feature) // &
358 '" is scheduled for removal in version: ' // &
359 trim(removal_version) //
' (current version: ' // &
368 class(
log_t),
intent(inout) :: this
369 character(len=*),
intent(in) :: msg
370 integer,
optional :: lvl
374 if (len_trim(this%section_header) .gt. 0)
then
375 call this%print_section_header(lvl)
381 pre = (30 - len_trim(msg)) / 2
382 pos = 30 - (len_trim(msg) + pre)
384 if (pre .lt. 0 .or. pos .lt. 0)
then
387 write(this%section_header,
'(A,A,A)') &
391 write(this%section_header,
'(A,A,A)') &
392 repeat(
'-', pre), trim(msg), repeat(
'-', pos)
400 class(
log_t),
intent(inout) :: this
401 integer,
optional :: lvl
404 if (
present(lvl))
then
410 if (lvl_ .gt. this%level_)
then
415 call this%newline(lvl)
417 write(this%unit_,
'(A)') trim(this%section_header)
418 this%section_header =
""
425 class(
log_t),
intent(inout) :: this
426 character(len=*),
intent(in),
optional :: msg
427 integer,
optional :: lvl
429 if (
present(msg))
then
430 call this%message(msg, lvl)
444 use,
intrinsic :: iso_c_binding
445 character(kind=c_char),
dimension(*),
intent(in) :: c_msg
446 character(len=LOG_SIZE) :: msg
452 if (c_msg(len+1) .eq. c_null_char)
exit
454 msg(len:len) = c_msg(len)
457 call neko_log%message(trim(msg(1:len)))
465 use,
intrinsic :: iso_c_binding
466 character(kind=c_char),
dimension(*),
intent(in) :: c_msg
467 character(len=LOG_SIZE) :: msg
473 if (c_msg(len+1) .eq. c_null_char)
exit
475 msg(len:len) = c_msg(len)
479 write(stderr,
'(A,A,A)')
'*** ERROR: ', trim(msg(1:len)),
' ***'
487 use,
intrinsic :: iso_c_binding
488 character(kind=c_char),
dimension(*),
intent(in) :: c_msg
489 character(len=LOG_SIZE) :: msg
495 if (c_msg(len+1) .eq. c_null_char)
exit
497 msg(len:len) = c_msg(len)
502 '*** WARNING: ', trim(msg(1:len)),
' ***'
510 use,
intrinsic :: iso_c_binding
511 character(kind=c_char),
dimension(*),
intent(in) :: c_msg
512 character(len=LOG_SIZE) :: msg
518 if (c_msg(len+1) .eq. c_null_char)
exit
520 msg(len:len) = c_msg(len)
523 call neko_log%section(trim(msg(1:len)))
541 character(len=*),
intent(in) :: version_removal
542 character(len=50) :: current_str, removal_str
543 integer :: current_number(3), removal_number(3)
544 integer :: i, current_size, removal_size
545 integer :: iostat_current, iostat_removal
546 logical :: versions_are_valid, is_newer_than_removal
549 removal_str = trim(version_removal)
552 do i = 1, len_trim(current_str)
553 if (current_str(i:i) .eq.
'.')
then
554 current_str(i:i) =
' '
555 current_size = current_size + 1
560 do i = 1, len_trim(removal_str)
561 if (removal_str(i:i) .eq.
'.')
then
562 removal_str(i:i) =
' '
563 removal_size = removal_size + 1
567 read(current_str, *, iostat = iostat_current) &
568 current_number(1:current_size)
569 read(removal_str, *, iostat = iostat_removal) &
570 removal_number(1:removal_size)
571 versions_are_valid = (iostat_current .eq. 0 .and. iostat_removal .eq. 0)
573 if (.not. versions_are_valid)
then
574 call neko_error(
'Invalid version string in deprecation check: ' // &
576 'removal_version=' // trim(version_removal))
580 do i = 1, current_size
581 if (current_number(i) .gt. removal_number(i))
then
584 else if (current_number(i) .lt. removal_number(i))
then
integer, public pe_rank
MPI rank.
Module for file I/O operations.
subroutine log_end_section_c()
End a log section (from C)
subroutine log_end(this)
Decrease indention level.
subroutine log_print_section_header(this, lvl)
Print a section header.
subroutine log_deprecated(this, feature, removal_version, extra_info)
Write a deprecation warning to a log.
subroutine log_header(this, version, build_info)
Write the Neko header to a log.
integer, parameter, public neko_log_deprecation
Deprecation log level.
integer, parameter, public neko_log_verbose
Verbose log level.
subroutine log_message(this, msg, lvl)
Write a message to a log.
integer, parameter, public neko_log_quiet
Always logged.
subroutine log_begin(this)
Increase indention level.
subroutine log_message_c(c_msg)
Write a message to a log (from C)
subroutine log_end_section(this, msg, lvl)
End a log section.
subroutine log_init(this)
Initialize a log.
subroutine log_warning(this, msg)
Write a warning message to a log.
character(len=50), dimension(:), allocatable deprecated_list
List of already logged deprecated features.
subroutine log_error_c(c_msg)
Write an error message to a log (from C)
subroutine log_indent(this)
Indent a log.
subroutine log_warning_c(c_msg)
Write a warning message to a log (from C)
subroutine log_newline(this, lvl)
Write a new line to a log.
logical function is_deprecated(version_removal)
Compare version strings.
integer, parameter, public sec_head_size
Length of the section header.
subroutine log_section_c(c_msg)
Begin a new log section (from C)
integer, parameter, public neko_log_debug
Debug log level.
type(log_t), public neko_log
Global log stream.
integer, parameter, public log_size
integer, parameter, public neko_log_info
Default log level.
subroutine log_free(this)
Free a log.
subroutine log_section(this, msg, lvl)
Begin a new log section.
subroutine log_error(this, msg)
Write an error message to a log.
character(len=10), parameter neko_version
subroutine, public neko_warning(warning_msg)
Reports a warning to standard output.