#!/usr/bin/env ksh #****************************************************************************** # @(#) display_terse.sh #****************************************************************************** # @(#) Copyright (C) 2017 by KUDOS BVBA (info@kudos.be). All rights reserved. # # This program is a free software; you can redistribute it and/or modify # it under the same terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS # FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details #****************************************************************************** # # DOCUMENTATION (MAIN) # ----------------------------------------------------------------------------- # @(#) MAIN: display_terse # DOES: display HC results in a terse way # EXPECTS: 1=HC name [string], 2=HC FAIL_ID [string] # RETURNS: 0 # REQUIRES: init_hc() # # ----------------------------------------------------------------------------- # DO NOT CHANGE THIS FILE UNLESS YOU KNOW WHAT YOU ARE DOING! #****************************************************************************** # ----------------------------------------------------------------------------- function display_terse { # ------------------------- CONFIGURATION starts here ------------------------- typeset _VERSION="2018-05-14" # YYYY-MM-DD typeset _SUPPORTED_PLATFORMS="AIX,HP-UX,Linux" # uname -s match # ------------------------- CONFIGURATION ends here --------------------------- # set defaults (( ARG_DEBUG != 0 && ARG_DEBUG_LEVEL > 0 )) && set "${DEBUG_OPTS}" init_hc "$0" "${_SUPPORTED_PLATFORMS}" "${_VERSION}" typeset _DISPLAY_HC="$1" typeset _DISPLAY_FAIL_ID="$2" typeset _HC_MSG_ENTRY="" typeset _DISPLAY_MSG_STC="" typeset _DISPLAY_MSG_TIME="" typeset _DISPLAY_MSG_TEXT="" typeset _DISPLAY_MSG_CUR_VAL="" typeset _DISPLAY_MSG_EXP_VAL="" typeset _ID_BIT="" # parse $HC_MSG_VAR if [[ -n "${HC_MSG_VAR}" ]] then printf "%-30s\t%s\t%-16s\t%s\n" "HC" "STC" "FAIL ID" "Message" print "${HC_MSG_VAR}" | while read _HC_MSG_ENTRY do # split fields (awk is required for multi-char delimiter) _DISPLAY_MSG_STC=$(print "${_HC_MSG_ENTRY}" | awk -F "%%" '{ print $1'}) _DISPLAY_MSG_TIME=$(print "${_HC_MSG_ENTRY}" | awk -F "%%" '{ print $2'}) _DISPLAY_MSG_TEXT=$(print "${_HC_MSG_ENTRY}" | awk -F "%%" '{ print $3'}) _DISPLAY_MSG_CUR_VAL=$(print "${_HC_MSG_ENTRY}" | awk -F "%%" '{ print $4'}) _DISPLAY_MSG_EXP_VAL=$(print "${_HC_MSG_ENTRY}" | awk -F "%%" '{ print $5'}) if (( _DISPLAY_MSG_STC > 0 )) then _ID_BIT="${_DISPLAY_FAIL_ID}" else _ID_BIT="" fi printf "%-30s\t%s\t%-16s\t%s\n" \ "${_DISPLAY_HC}" \ "${_DISPLAY_MSG_STC}" \ "${_ID_BIT}" \ "${_DISPLAY_MSG_TEXT}" done else ARG_LOG=0 ARG_VERBOSE=1 log "INFO: no HC results to display" fi # notice of other messages print ARG_LOG=0 ARG_VERBOSE=1 log "all other messages have been suppressed (except fatal errors)" return 0 } #****************************************************************************** # END of script #**************************************************************************