Zsh シェルの統合

STT (Speech-to-Text) CLI との対話を容易にするために、~/.zshrc にショートカット関数を追加できます。これにより、ターミナルに「質問」と入力するだけで済みます。

セットアップ手順

  1. 任意のエディターで zsh 構成を開きます。

    nano ~/.zshrc
    kate ~/.zshrc
    
  2. ファイルの最後に次のブロックを貼り付けます。

# --- STT Project Path Resolution ---

unalias s 2>/dev/null
s() {
    LATEST_CHANGE=$(stat -c %Y /tmp/sl5_aura/sl5net_aura_project_root)
    PID=$(pgrep -f "scripts.py.service_api" | head -n 1)
    PROC_START=$(stat -c %Y /proc/$PID 2>/dev/null || echo 0)
    if [ "$LATEST_CHANGE" -gt "$PROC_START" ]; then
        echo "Code is newer. restart Api..."
        pkill -9 -f uvicorn 2>/dev/null
        start_service
    fi

    if [ $# -eq 0 ]; then
        echo "question <your question>"
        return 1
    fi

    update_github_ip

    local TEMP_FILE=$(mktemp)
    local SHORT_TIMEOUT_SECONDS=2
    local LONG_TIMEOUT_SECONDS=70

    # Path shortcuts
    local PY_EXEC="$PROJECT_ROOT/.venv/bin/python3"
    local CLI_SCRIPT="$PROJECT_ROOT/scripts/py/cli_client.py"

    # --- 1. try
    timeout $SHORT_TIMEOUT_SECONDS \
    "$PY_EXEC" -u "$CLI_SCRIPT" "$*" \
    --lang "de-DE" --unmasked < /dev/null > "$TEMP_FILE" 2>&1

    local EXIT_CODE=$?
    local OUTPUT=$(cat "$TEMP_FILE")
    rm "$TEMP_FILE"

    if echo "$OUTPUT" | grep -q "Verbindungsfehler" || ! pgrep -f "streamlit-chat.py" > /dev/null; then
        echo "Service-Check: Backend oder Frontend fehlt. Starte neu..."

        start_service

        echo '++++++++++++++++++++++++++++++++++++++++++++++++++'
        local KIWIX_SCRIPT="$PROJECT_ROOT/config/maps/plugins/standard_actions/wikipedia_local/de-DE/kiwix-docker-start-if-not-running.sh"
        if [ -f "$KIWIX_SCRIPT" ]; then
            bash "$KIWIX_SCRIPT"
        fi
        echo '++++++++++++++++++++++++++++++++++++++++++++++++++'

        echo "BITTE ERNEUT EINGEBEN: s $*"
        return 1

    # 2. Timeout (124) == OR success (0)
    elif [ $EXIT_CODE -eq 124 ] || [ $EXIT_CODE -eq 0 ]; then
        if [ $EXIT_CODE -eq 0 ]; then
            echo "$OUTPUT"
            return 0
        fi
        echo "answer > $SHORT_TIMEOUT_SECONDS sec. set Timeout= $LONG_TIMEOUT_SECONDS s..."

        local TEMP_FILE_2=$(mktemp)

        timeout $LONG_TIMEOUT_SECONDS \
        "$PY_EXEC" -u "$CLI_SCRIPT" "$*" \
        --lang "de-DE" --unmasked < /dev/null > "$TEMP_FILE_2" 2>&1

        local EXIT_CODE_2=$?
        local OUTPUT_2=$(cat "$TEMP_FILE_2")
        rm "$TEMP_FILE_2"
        echo "$OUTPUT_2"
        if [ $EXIT_CODE_2 -ne 0 ]; then
             echo "WARNUNG: Timeout > $LONG_TIMEOUT_SECONDS Sec. "
        fi
        return 0
    else
        echo "ERROR"
        echo "$OUTPUT"
        return $EXIT_CODE
    fi
}
  1. 設定をリロードします。

    source ~/.zshrc
    

## 特徴

  • 動的パス: /tmp マーカー ファイルを介してプロジェクト ルートを自動的に検索します。

  • 自動再起動: バックエンドがダウンしている場合、「start_service」とローカルの Wikipedia サービスを実行しようとします。

  • スマート タイムアウト: 最初に 2 秒の素早い応答を試み、その後 70 秒の詳細な処理モードに戻ります。 CODE_BLOCK_3