#!/bin/bash

set -euo pipefail

DEMO_SCRIPT="Env_StandAlone/Stage2/Stage2_five.py"
PYTHON_LAUNCH="./isaacsim_4.5.0/python.sh"

TASK_NAME="StrategyB_V2"
BASE_DIR="./FlatLab/Data/${TASK_NAME}"
VIDEO_DIR="${BASE_DIR}/Video"
TRAIN_DIR="${BASE_DIR}/train_data"
POINTCLOUD_DIR="${BASE_DIR}/pointcloud"

POS_SPEC="${1:-50}"
TIMEOUT_MIN="${2:-10}"
RECORD_VIDEO="${3:-False}"
MAX_ATTEMPTS="${4:-3}"

declare -a POS_LIST=()
if [[ "${POS_SPEC}" =~ ^[0-9]+$ ]]; then
    POS_MAX=${POS_SPEC}
    if (( POS_MAX <= 0 )); then
        echo "Error: POS count must be a positive integer (current=${POS_SPEC})" >&2
        exit 1
    fi
    for ((pos_idx=1; pos_idx<=POS_MAX; pos_idx++)); do
        POS_LIST+=("${pos_idx}")
    done
else
    read -r -a POS_LIST <<< "${POS_SPEC}"
fi

declare -A DEMO_INDEXES=(
    ["Painting"]="2"
)

mkdir -p "${VIDEO_DIR}" "${TRAIN_DIR}" "${POINTCLOUD_DIR}"

echo "=========================================="
echo "Start Execution: FlatLab Demo Data Collection (Simplified Entry)"
echo "Object Types: ${!DEMO_INDEXES[*]}"
echo "POS_INDEX List: ${POS_LIST[*]}"
echo "Timeout: ${TIMEOUT_MIN} mins | Record Video: ${RECORD_VIDEO}"
echo "Output Directory: ${BASE_DIR}"
echo "=========================================="

is_true() {
    case "$1" in
        [Tt][Rr][Uu][Ee]|1|[Yy][Ee][Ss]) return 0 ;;
        *) return 1 ;;
    esac
}

position_record_ready() {
    local object_name="$1"
    local pos="$2"
    local base_path="${TRAIN_DIR}/${object_name}"
    [[ -d "${base_path}" ]] || return 1
    for outcome in T F; do
        if [[ -d "${base_path}/record_${pos}_${outcome}" ]]; then
            return 0
        fi
    done
    return 1
}

run_capture_once() {
    local object_name="$1"
    local pos="$2"
    local video_flag="False"
    if is_true "${RECORD_VIDEO}"; then
        video_flag="True"
    fi

    echo "------------------------------------------"
    echo "Start Capture: ${object_name} | POS_INDEX=${pos} | Record Video=${video_flag} | Timeout=${TIMEOUT_MIN}m"
    echo "------------------------------------------"

    local status=0
    if command -v timeout >/dev/null 2>&1; then
        if ! POS_INDEX="${pos}" timeout -k 30s "${TIMEOUT_MIN}m" "${PYTHON_LAUNCH}" "${DEMO_SCRIPT}" \
            --object_name "${object_name}" \
            --data_collection_flag True \
            --record_video_flag "${video_flag}" \
            --object_random_init True; then
            status=$?
        fi
    else
        if ! POS_INDEX="${pos}" "${PYTHON_LAUNCH}" "${DEMO_SCRIPT}" \
            --object_name "${object_name}" \
            --data_collection_flag True \
            --record_video_flag "${video_flag}" \
            --object_random_init True; then
            status=$?
        fi
    fi

    if [[ ${status} -eq 0 ]]; then
        echo "Completed: ${object_name} | POS_INDEX=${pos}"
    else
        echo "Warning: ${object_name} | POS_INDEX=${pos} | Exit Code=${status}"
    fi
    echo "Waiting 3 seconds before continuing..."
    sleep 3
}

mapfile -t SORTED_TYPES < <(printf "%s\n" "${!DEMO_INDEXES[@]}" | sort)

for object_type in "${SORTED_TYPES[@]}"; do
    idx_list="${DEMO_INDEXES[$object_type]}"
    [[ -z "${idx_list}" ]] && continue
    mapfile -t SORTED_IDXS < <(echo "${idx_list}" | xargs -n1 | sort -n)

    echo "=========================================="
    echo "Object Type: ${object_type} (Instances: ${SORTED_IDXS[*]})"
    echo "=========================================="

    for idx in "${SORTED_IDXS[@]}"; do
        object_name="${object_type}${idx}"
        for pos in "${POS_LIST[@]}"; do
            if position_record_ready "${object_name}" "${pos}"; then
                echo "Skip: ${object_name} | POS_INDEX=${pos} record_${pos}_{T|F} already exists"
                continue
            fi

            attempt=1
            while true; do
                run_capture_once "${object_name}" "${pos}"
                if position_record_ready "${object_name}" "${pos}"; then
                    echo "Capture Confirmed: ${object_name} | POS_INDEX=${pos}"
                    break
                fi
                if (( attempt >= MAX_ATTEMPTS )); then
                    echo "Warning: ${object_name} | POS_INDEX=${pos} no record_${pos}_{T|F} generated after ${MAX_ATTEMPTS} attempts"
                    break
                fi
                attempt=$((attempt + 1))
                echo "record_${pos}_{T|F} not detected, preparing ${attempt}th attempt..."
                sleep 2
            done
        done
    done

done

echo "=========================================="
echo "All data collection tasks completed."
echo "=========================================="