Update utils.sh

This commit is contained in:
MacRimi 2025-07-05 11:52:20 +02:00
parent 38977af9d3
commit 96c08e6563

View File

@ -298,28 +298,25 @@ translate() {
local text="$1" local text="$1"
local dest_lang="$LANGUAGE" local dest_lang="$LANGUAGE"
# If the language is English, return the original text without translating or caching
if [ "$dest_lang" = "en" ]; then
echo "$text"
return
fi
if [ ! -s "$CACHE_FILE" ] || ! jq -e . "$CACHE_FILE" > /dev/null 2>&1; then if [ ! -s "$CACHE_FILE" ] || ! jq -e . "$CACHE_FILE" > /dev/null 2>&1; then
echo "{}" > "$CACHE_FILE" echo "{}" > "$CACHE_FILE"
fi fi
local cached_translation=$(jq -r --arg text "$text" --arg lang "$dest_lang" '.[$text][$lang] // .[$text]["notranslate"] // empty' "$CACHE_FILE") local cached_translation=$(jq -r --arg text "$text" --arg lang "$dest_lang" '.[$text][$lang] // .[$text]["notranslate"] // empty' "$CACHE_FILE")
if [ -n "$cached_translation" ]; then if [ -n "$cached_translation" ]; then
echo "$cached_translation" echo "$cached_translation"
return return
fi fi
# Robust check: skip python if venv or googletrans not ready
if [ ! -d "$VENV_PATH" ] || [ ! -f "$VENV_PATH/bin/activate" ] || ! "$VENV_PATH/bin/python3" -c "import googletrans" 2>/dev/null; then if [ ! -d "$VENV_PATH" ] || [ ! -f "$VENV_PATH/bin/activate" ] || ! "$VENV_PATH/bin/python3" -c "import googletrans" 2>/dev/null; then
echo "$text" echo "$text"
return return
fi fi
source "$VENV_PATH/bin/activate" source "$VENV_PATH/bin/activate"
local translated local translated
translated=$(python3 -c " translated=$(python3 -c "
@ -328,12 +325,12 @@ import sys, json, re
def translate_text(text, dest_lang): def translate_text(text, dest_lang):
translator = Translator() translator = Translator()
# Context is not strictly necessary, but if you want it: # El contexto solo se añade aquí
context = '###CONTEXT### ' context = 'Context: sysadmin script translation. '
try: try:
result = translator.translate(context + text, dest=dest_lang).text result = translator.translate(context + text, dest=dest_lang).text
# Remove context marker if present # Remueve el contexto en el texto traducido
translated = re.sub(r'^.*###CONTEXT### ?', '', result).strip() translated = re.sub(r'^(Context: sysadmin script translation\. )?', '', result).strip()
return json.dumps({'success': True, 'text': translated}) return json.dumps({'success': True, 'text': translated})
except Exception as e: except Exception as e:
return json.dumps({'success': False, 'error': str(e)}) return json.dumps({'success': False, 'error': str(e)})
@ -348,8 +345,6 @@ print(translate_text('$text', '$dest_lang'))
if [ "$success" = "true" ]; then if [ "$success" = "true" ]; then
translated=$(echo "$translation_result" | jq -r '.text') translated=$(echo "$translation_result" | jq -r '.text')
# Post-process: Remove context marker again, just in case
translated=$(echo "$translated" | sed -E 's/^.*###CONTEXT### ?//g')
if [ "$dest_lang" != "en" ]; then if [ "$dest_lang" != "en" ]; then
local temp_cache=$(mktemp) local temp_cache=$(mktemp)
@ -358,7 +353,7 @@ print(translate_text('$text', '$dest_lang'))
.[$text][$lang] = $translated .[$text][$lang] = $translated
' "$CACHE_FILE" > "$temp_cache" && mv "$temp_cache" "$CACHE_FILE" ' "$CACHE_FILE" > "$temp_cache" && mv "$temp_cache" "$CACHE_FILE"
fi fi
echo "$translated" echo "$translated"
else else
echo "$text" echo "$text"
@ -367,6 +362,7 @@ print(translate_text('$text', '$dest_lang'))
######################################################## ########################################################