#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：コース変更工事案件諸変更登録
#
# 機能          ：１、コース変更確定割引サービス情報を元に工事案件諸変更を行う。
#
# コマンド形式  ：EO20M0460J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
#
##############################################################

##############################################################
# 環境変数定義
##############################################################

#
#---ツール格納場所
#
G_TOOLSH=.

#
#---環境変数定義Shell呼び出し
#
. EOK010110J0.sh

#
#---ＪＯＢ名
#
JOBNAME=`basename $0 | sed -e "s/\.sh//g"`

#
#---サービス（業務プロセス）
#
SVC=$JOBNAME

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
# ファイルの分割
#  多重で動作させる為に、ファイルを分割する。
#
SEP_CNT=3

# アプリ入力ファイル
INFILE=${MID_DIR_KK}/KKIFM281002.csv

bsortex -sort key="0.10asc,28.5asc,25.10asc" -record recform=txtcsv -input reclen=281 include="13.2asc.eq.'01'.and.28.5asc.ne.'00019'" < ${MID_DIR_KK}/KKIFM281.csv > ${INFILE}

# 一時ファイルの削除
for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM281002_*.csv"`; do
	rm ${FILE}
done

FILE_REC_NUM=`cat ${INFILE} | wc -l`

if [ ${FILE_REC_NUM} -ne 0 ]
then
	echo "■ 入力ファイル分割実行(全行数：${FILE_REC_NUM})"
	
	# 分割行数：入力ファイル件数(余剰分は削除) / 5 + 入力ファイル件数/5の余剰分
	FILE_SEP_CNT=`expr ${FILE_REC_NUM} / ${SEP_CNT} + ${FILE_REC_NUM} % ${SEP_CNT}`
	
	echo "分割行数：${FILE_SEP_CNT}"
	
	split -l ${FILE_SEP_CNT} ${INFILE} ${MID_DIR_KK}/KKIFM281002_
	
	rc=$?
	if [ $rc -ne 0 ]
	then
	    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " split Error($SVC split:rc=$rc) "
	    echo $JOBNAME " split Error($SVC split:rc=$rc) "
	    exit ${G_RTN_ERROR}
	fi
	
	# 分割後のファイル名をリネーム
	CNT=1
	for FILE in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM281002_*"`; do
		mv $FILE ${MID_DIR_KK}/KKIFM281002_0$CNT.csv
		echo "ファイル_0${CNT}："`cat ${MID_DIR_KK}/KKIFM281002_0$CNT.csv | wc -l`
		CNT=`expr $CNT + 1`
	done
else
	# 初期ファイルの生成
	cat /dev/null > ${MID_DIR_KK}/KKIFM281002_01.csv
fi

sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

CNT=1
for filename in `find ${MID_DIR_KK} -maxdepth 1 -name "KKIFM281002_*.csv"  | sort`; do
	
	ARRAY_FILES[$CNT]=$filename
	
	#
	#---パラメタ定義
	#

	P1="OPD=,"
	P2="SVCCTL=JBSbatMultiServiceControl,"
	P3="JOB=EO20M0460J0,"
	P4="IND1=KKIFM281.def,"
	P5="INF1=${MID_DIR_KK}/KKIFM281002_0$CNT.csv,"
	P6="IND2=,"
	P7="INF2=,"
	P8="OTD1=,"
	P9="OTF1=,"
	P10="OTD2=,"
	P11="OTF2=,"
	P12="TABLENAME=,"
	P13="SQLKEY=,"
	P14="SQLPARAM=,"
	P15="ERRFILE=1,"
	P16="RECOVERY=,"
	P17="BREAKPTN=,"
	P18="FREE=${MID_DIR_KK}/KKIFM217.csv"
	PARA="$P1$P2$P3$P4$P5$P6$P7$P8$P9$P10$P11$P12$P13$P14$P15$P16$P17$P18"

	sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

	#
	#---ＡＰＬ起動
	#

	java ${JAVA_OPTION} -jar ${JAR_DIR}/koptBatch.jar $PARA &
	
	PID=$!
	ARRAY_PID[$CNT]=$PID
	
	echo "処理対象ファイル：$filename @$PID"
	
	CNT=`expr $CNT + 1`
done


# 処理終了監視
RESULT=0
for PID in "${ARRAY_PID[@]}"; do
	
	wait $PID
	
	rc=$?
	ERR_FLG=0
	if [ $rc -ne 0 ]
	then
	   if [ $rc -ne 4 ]
	   then
	       if [ $rc -ne 8 ]
	       then
	           if [ $rc -ne 127 ]
	           then
	              sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
	              echo $JOBNAME " PROGRAM Error($SVC program:rc=$rc) "
	              exit ${G_RTN_ERROR}
	           fi
	       fi
	    fi
	    ERR_FLG=1
	fi

	echo "PID($PID) => エラーコード：$rc"
	
	# 処理結果の設定（処理結果コードの最大を残す）
	if [ ${RESULT} -lt $rc ]
	then
		RESULT=$rc
	fi
done 

exit_rc=$RESULT

#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit $exit_rc
