Trap command not working


 
Thread Tools Search this Thread
Top Forums Shell Programming and Scripting Trap command not working
# 8  
Old 12-16-2016
Hi Folks -

Adjusted the code accordingly, however the directory is not being removed (Error file subdirectory).

Code:
#:: ------------------------------------------------------------------------
#source /u01/Hyperion_Batch/Scripts/Batch/_env.sh

#::-- Set Script Action --::#

_ACTION=Export

#::-- Set Script Name --::#
#::-- ${_SN%%.sh*} --::

_SN=${0##*/}

#::-- Set Path Variables --::

cd $HOME

_MAINPATH=$(pwd)/Hyperion_Batch/
_LOGPATH=Logs/
_ERRORPATH=Errors/

#::-- Set Log & Error subdirectories pertaining to the specific process --::#

_PLOGPATH=LCM_Logs/
_PERRORPATH=LCM_Errors/

#::-- Set Date and Time Variable --::#
_DAY=$(date +%d)
_MONTH=$(date +%m)
_YEAR=$(date +%Y)
_DATESTAMP=${_YEAR}${_MONTH}${_DAY}
_HOUR=$(date +%H)
_MINUTE=$(date +%M)
_SECOND=$(date +%S)
_TIME=${_HOUR}${_MINUTE}
_DATETIMESTAMP=${_DATESTAMP}_${_TIME}

#::-- Establish STDOUT and STDERROR repositories --::
_ARC_LP=${_MAINPATH}${_LOGPATH}${_PLOGPATH}${_YEAR}_${_MONTH}${_DAY}
_ARC_EP=${_MAINPATH}${_ERRORPATH}${_PERRORPATH}${_YEAR}_${_MONTH}${_DAY}
    
mkdir -p ${_ARC_LP}
mkdir -p ${_ARC_EP}

#::-- Prepare File Name Format --::#
_HOST=$(hostname -f)
_FN=${_SN%%.sh*}_${_HOST}_${_TIME}

#::-- Establish STDOUT and STDERROR files --::#
_LF=${_ARC_LP}/${_FN}.log
_EF=${_ARC_EP}/${_FN}.err

#::-- Direct STDOUT and STDERROR to repositories --::# 
exec 2>${_EF} > ${_LF}

#::-- If empty, delete YYYY_MMDD error file subdirectory --::
trap "[ -s ${_EF} ] || rm -f ${_EF} ] && rmdir ${_ARC_EF}" EXIT

#::-- Establish LCM Variables --::

_EPM_SYSTEM_BIN=/u01/EPM/Oracle/Middleware/user_projects/epmsystem1/bin/
_IMPORTEXPORT_DIR=/u01/EPM/Oracle/Middleware/user_projects/epmsystem1/import_export/
_LCM_DIR=AUTODEMO_FIN_PLAN_CS/
_LCM_USER=admin
_LCM_PSWD=welcome1

#:: Begin Script Processing --::#
echo ---------------------------------------------------------
echo "${_SN} beginning at ${_TIME}"                        
echo                                                                                                        
echo "Add credentials to ${_LCM_DIR}${_ACTION}.xml"                                         
echo ---------------------------------------------------------

sed "s/name=\"\" password=\"\"/name=\"${_LCM_USER}\" password=\"${_LCM_PSWD}\"/" ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}.xml > ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}1.xml
rm ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}.xml
mv ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}1.xml ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}.xml

if [ $? -eq 0 ]
then
  echo ---------------------------------------------------------
  echo "Credentials added to ${_LCM_DIR}${_ACTION}.xml Successful"                           
  echo ---------------------------------------------------------

else
  echo ---------------------------------------------------------
  echo "Credentials added to ${_LCM_DIR}${_ACTION}.xml Unsuccessful"                      
  echo ---------------------------------------------------------
  exit 1
  fi

  #:: Begin Script Processing --::
echo ---------------------------------------------------------                                                                                                                            
echo "Execute ${_LCM_DIR} Life Cycle Management Backup"                                         
echo ---------------------------------------------------------

sh ${_EPM_SYSTEM_BIN}Utility.sh ${_IMPORTEXPORT_DIR}${_LCM_DIR}${_ACTION}.xml

if [ $? -eq 0 ]
then
  echo ---------------------------------------------------------
  echo "${_LCM_DIR} Life Cycle Management Backup Successful"                           
  echo ---------------------------------------------------------
  exit 0
  
else
  echo ---------------------------------------------------------
  echo "${_LCM_DIR} Life Cycle Management Backup Unsuccessful"                      
  echo ---------------------------------------------------------
  exit 1
  fi

Could there be a hidden file in the directory that I"m not seeing?

Thanks!
# 9  
Old 12-16-2016
Is the log file actually empty?
# 10  
Old 12-16-2016
The log file will never be empty. A log file is always generated upon execution, but not an error file.

Therefore, my script will build the following directories to direct standard output and stadnard error:

Code:
<Path>/Logs/LCM_Logs/2016_1216
<Path>/Errors/LCM_Errors/2016_1216



If <Path>/Errors/LCM_Errors/2016_1216 directory is empty (no error files generated, then delete 2016_1216.

I hope I was clear enough?

Last edited by rbatte1; 12-19-2016 at 08:37 AM.. Reason: Added CODE tags & ICODE tags for clarity
# 11  
Old 12-16-2016
But is the error log actually empty? Look at it with ls -l . Zero bytes?
# 12  
Old 12-16-2016
_ARC_EF is not defined in your script. And, there's a ] too many in your trap statement.
This User Gave Thanks to RudiC For This Post:
# 13  
Old 12-16-2016
HI -

Yup, no error file is even generated.

---------- Post updated at 12:48 PM ---------- Previous update was at 12:45 PM ----------

Found the issue,

It should be
Code:
trap "[ -s ${_EF} ] || rm -f ${_EF} ] && rmdir ${_ARC_EP}" EXIT

I changed _ARC_EF to -ARC_EP. My fault! Thank you all for your help! Sorry for the bother!
# 14  
Old 12-16-2016
You still have the extra ] in there, rm -f ${_EF} ] should be rm -f ${_EF}
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

trap command

dear all; I can't under stand what does "trap" command do: for example see below: trap "echo; echo no interrupts >&2; sleep 3" 2 3 15 Plz , can any body explain the action of this command? BR (3 Replies)
Discussion started by: ahmad.diab
3 Replies

2. UNIX for Dummies Questions & Answers

trap command

I'm learning about the trap command from my bash book. I tried out the little script they gave: trap "echo 'You hit control-C!' " INT while true; do sleep 60 done But when I type control-c, the script just stops and the message is not displayed. I checked stty all and saw that control-c... (11 Replies)
Discussion started by: Straitsfan
11 Replies

3. UNIX for Advanced & Expert Users

trap command

Hello experts! I need to know the use of trap command please In one of our program we have trap "rm -f temp1 ; exit 1" 1 2 15 0 and program always exit with 1 there is a rm -f temp1 as well at the end of the program as rm -f temp1 exit 0 when I test a probram with set... (4 Replies)
Discussion started by: ramshree01
4 Replies

4. Shell Programming and Scripting

Help with getting a Ctrl-C trap working w/ a piped tail -f...

Hi All, Although each line below seems to work by itself, I've been having trouble getting the Control-C trap working when I add the "|perl -pe..." to the end of the tail -f line, below. (That |perl -pe statement basically just adds color to highlight the word "ERROR" while tailing a log... (2 Replies)
Discussion started by: chatguy
2 Replies

5. Shell Programming and Scripting

Trap not working in orphaned child processes

I've search the various posts in these forums, but have not come up with a solution to my problem. I have a parent process that calls a child script, runs it in the background and the parent finishes - without waiting for the child process to complete. Inside the child, a trap is issued to trap... (6 Replies)
Discussion started by: HobieCoop
6 Replies

6. Shell Programming and Scripting

Cntl+z Trap is not detecting ??? Help required to add a trap detection ???

Hi folks, I have tried to add some trap detection in the below script....this script is used to monitor database activities...in a rather awkward way :rolleyes:.... The idea behind adding trap is that....this script creates lots of temporary files in the running folder to store the count... (1 Reply)
Discussion started by: frozensmilz
1 Replies

7. Shell Programming and Scripting

Use of TRAP Command

Hi, I would like to know the use of TRAP command. I am very new to the UNIX environment. I have just started learning the basic. So please teach me in a very simple way to understand. Also i would like to know the use of following command: trap 'dialog --msgbox "Script Aborted1" 6 50 ;... (2 Replies)
Discussion started by: Deepakh
2 Replies

8. UNIX for Dummies Questions & Answers

trap command

Dear All could you please explain me what does the trap command do and how I can write a program which can work as a trap command(in C Language). (1 Reply)
Discussion started by: mobile01
1 Replies

9. UNIX for Dummies Questions & Answers

trap command

i have the following script that displays the current time until the user presses CTR + c.... but it does not work properly.... Something is not right with the trap command... Help plz... :confused: # script to continuously display current time. # if script is terminated trap signal... (3 Replies)
Discussion started by: onlyc
3 Replies

10. Shell Programming and Scripting

Using TRAP command

I'm using the trap command to capture any signals received whilst my script is running. How's the best way of writing the signal and any other error messages to a file/error log' without having to type '2>$1' on the command line after the script name? Cheers (3 Replies)
Discussion started by: dbrundrett
3 Replies
Login or Register to Ask a Question