auto-coder 0.1.400__py3-none-any.whl → 2.0.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of auto-coder might be problematic. Click here for more details.
- auto_coder-2.0.0.dist-info/LICENSE +158 -0
- auto_coder-2.0.0.dist-info/METADATA +558 -0
- auto_coder-2.0.0.dist-info/RECORD +795 -0
- {auto_coder-0.1.400.dist-info → auto_coder-2.0.0.dist-info}/WHEEL +1 -1
- {auto_coder-0.1.400.dist-info → auto_coder-2.0.0.dist-info}/entry_points.txt +3 -3
- autocoder/__init__.py +31 -0
- autocoder/agent/auto_filegroup.py +32 -13
- autocoder/agent/auto_learn_from_commit.py +9 -1
- autocoder/agent/base_agentic/__init__.py +3 -0
- autocoder/agent/base_agentic/agent_hub.py +1 -1
- autocoder/agent/base_agentic/base_agent.py +235 -136
- autocoder/agent/base_agentic/default_tools.py +119 -118
- autocoder/agent/base_agentic/test_base_agent.py +1 -1
- autocoder/agent/base_agentic/tool_registry.py +32 -20
- autocoder/agent/base_agentic/tools/read_file_tool_resolver.py +25 -4
- autocoder/agent/base_agentic/tools/write_to_file_tool_resolver.py +24 -11
- autocoder/agent/base_agentic/types.py +42 -0
- autocoder/agent/entry_command_agent/chat.py +73 -59
- autocoder/auto_coder.py +31 -40
- autocoder/auto_coder_rag.py +11 -1084
- autocoder/auto_coder_runner.py +1029 -2310
- autocoder/auto_coder_terminal.py +26 -0
- autocoder/auto_coder_terminal_v3.py +190 -0
- autocoder/chat/conf_command.py +224 -124
- autocoder/chat/models_command.py +361 -299
- autocoder/chat/rules_command.py +79 -31
- autocoder/chat_auto_coder.py +1021 -372
- autocoder/chat_auto_coder_lang.py +23 -732
- autocoder/commands/auto_command.py +26 -9
- autocoder/commands/auto_web.py +1 -1
- autocoder/commands/tools.py +44 -44
- autocoder/common/__init__.py +150 -128
- autocoder/common/ac_style_command_parser/__init__.py +39 -2
- autocoder/common/ac_style_command_parser/config.py +422 -0
- autocoder/common/ac_style_command_parser/parser.py +292 -78
- autocoder/common/ac_style_command_parser/test_parser.py +241 -16
- autocoder/common/ac_style_command_parser/test_typed_parser.py +342 -0
- autocoder/common/ac_style_command_parser/typed_parser.py +653 -0
- autocoder/common/action_yml_file_manager.py +25 -13
- autocoder/common/agent_events/__init__.py +52 -0
- autocoder/common/agent_events/agent_event_emitter.py +193 -0
- autocoder/common/agent_events/event_factory.py +177 -0
- autocoder/common/agent_events/examples.py +307 -0
- autocoder/common/agent_events/types.py +113 -0
- autocoder/common/agent_events/utils.py +68 -0
- autocoder/common/agent_hooks/__init__.py +44 -0
- autocoder/common/agent_hooks/examples.py +582 -0
- autocoder/common/agent_hooks/hook_executor.py +217 -0
- autocoder/common/agent_hooks/hook_manager.py +288 -0
- autocoder/common/agent_hooks/types.py +133 -0
- autocoder/common/agent_hooks/utils.py +99 -0
- autocoder/common/agent_query_queue/queue_executor.py +324 -0
- autocoder/common/agent_query_queue/queue_manager.py +325 -0
- autocoder/common/agents/__init__.py +11 -0
- autocoder/common/agents/agent_manager.py +323 -0
- autocoder/common/agents/agent_parser.py +189 -0
- autocoder/common/agents/example_usage.py +344 -0
- autocoder/common/agents/integration_example.py +330 -0
- autocoder/common/agents/test_agent_parser.py +545 -0
- autocoder/common/async_utils.py +101 -0
- autocoder/common/auto_coder_lang.py +23 -972
- autocoder/common/autocoderargs_parser/__init__.py +14 -0
- autocoder/common/autocoderargs_parser/parser.py +184 -0
- autocoder/common/autocoderargs_parser/tests/__init__.py +1 -0
- autocoder/common/autocoderargs_parser/tests/test_args_parser.py +235 -0
- autocoder/common/autocoderargs_parser/tests/test_token_parser.py +195 -0
- autocoder/common/autocoderargs_parser/token_parser.py +290 -0
- autocoder/common/buildin_tokenizer.py +2 -4
- autocoder/common/code_auto_generate.py +149 -74
- autocoder/common/code_auto_generate_diff.py +163 -70
- autocoder/common/code_auto_generate_editblock.py +179 -89
- autocoder/common/code_auto_generate_strict_diff.py +167 -72
- autocoder/common/code_auto_merge_editblock.py +13 -6
- autocoder/common/code_modification_ranker.py +1 -1
- autocoder/common/command_completer.py +3 -3
- autocoder/common/command_file_manager/manager.py +183 -47
- autocoder/common/command_file_manager/test_command_file_manager.py +507 -0
- autocoder/common/command_templates.py +1 -1
- autocoder/common/conf_utils.py +2 -4
- autocoder/common/conversations/config.py +11 -3
- autocoder/common/conversations/get_conversation_manager.py +100 -2
- autocoder/common/conversations/llm_stats_models.py +264 -0
- autocoder/common/conversations/manager.py +112 -28
- autocoder/common/conversations/models.py +16 -2
- autocoder/common/conversations/storage/index_manager.py +134 -10
- autocoder/common/core_config/__init__.py +63 -0
- autocoder/common/core_config/agentic_mode_manager.py +109 -0
- autocoder/common/core_config/base_manager.py +123 -0
- autocoder/common/core_config/compatibility.py +151 -0
- autocoder/common/core_config/config_manager.py +156 -0
- autocoder/common/core_config/conversation_manager.py +31 -0
- autocoder/common/core_config/exclude_manager.py +72 -0
- autocoder/common/core_config/file_manager.py +177 -0
- autocoder/common/core_config/human_as_model_manager.py +129 -0
- autocoder/common/core_config/lib_manager.py +54 -0
- autocoder/common/core_config/main_manager.py +81 -0
- autocoder/common/core_config/mode_manager.py +126 -0
- autocoder/common/core_config/models.py +70 -0
- autocoder/common/core_config/test_memory_manager.py +1056 -0
- autocoder/common/env_manager.py +282 -0
- autocoder/common/env_manager_usage_example.py +211 -0
- autocoder/common/file_checkpoint/conversation_checkpoint.py +19 -19
- autocoder/common/file_checkpoint/manager.py +264 -48
- autocoder/common/file_checkpoint/test_backup.py +1 -18
- autocoder/common/file_checkpoint/test_manager.py +270 -1
- autocoder/common/file_checkpoint/test_store.py +1 -17
- autocoder/common/file_handler/__init__.py +23 -0
- autocoder/common/file_handler/active_context_handler.py +159 -0
- autocoder/common/file_handler/add_files_handler.py +409 -0
- autocoder/common/file_handler/chat_handler.py +180 -0
- autocoder/common/file_handler/coding_handler.py +401 -0
- autocoder/common/file_handler/commit_handler.py +200 -0
- autocoder/common/file_handler/lib_handler.py +156 -0
- autocoder/common/file_handler/list_files_handler.py +111 -0
- autocoder/common/file_handler/mcp_handler.py +268 -0
- autocoder/common/file_handler/models_handler.py +493 -0
- autocoder/common/file_handler/remove_files_handler.py +172 -0
- autocoder/common/file_monitor/test_file_monitor.py +307 -0
- autocoder/common/git_utils.py +51 -10
- autocoder/common/global_cancel.py +15 -6
- autocoder/common/ignorefiles/test_ignore_file_utils.py +1 -1
- autocoder/common/international/__init__.py +31 -0
- autocoder/common/international/demo_international.py +92 -0
- autocoder/common/international/message_manager.py +157 -0
- autocoder/common/international/messages/__init__.py +56 -0
- autocoder/common/international/messages/async_command_messages.py +507 -0
- autocoder/common/international/messages/auto_coder_messages.py +2208 -0
- autocoder/common/international/messages/chat_auto_coder_messages.py +1547 -0
- autocoder/common/international/messages/command_help_messages.py +986 -0
- autocoder/common/international/messages/conversation_command_messages.py +191 -0
- autocoder/common/international/messages/git_helper_plugin_messages.py +159 -0
- autocoder/common/international/messages/queue_command_messages.py +751 -0
- autocoder/common/international/messages/rules_command_messages.py +77 -0
- autocoder/common/international/messages/sdk_messages.py +1707 -0
- autocoder/common/international/messages/token_helper_plugin_messages.py +361 -0
- autocoder/common/international/messages/tool_display_messages.py +1212 -0
- autocoder/common/international/messages/workflow_exception_messages.py +473 -0
- autocoder/common/international/test_international.py +612 -0
- autocoder/common/linter_core/__init__.py +28 -0
- autocoder/common/linter_core/base_linter.py +61 -0
- autocoder/common/linter_core/config_loader.py +271 -0
- autocoder/common/linter_core/formatters/__init__.py +0 -0
- autocoder/common/linter_core/formatters/base_formatter.py +38 -0
- autocoder/common/linter_core/formatters/raw_formatter.py +17 -0
- autocoder/common/linter_core/linter.py +166 -0
- autocoder/common/linter_core/linter_factory.py +216 -0
- autocoder/common/linter_core/linter_manager.py +333 -0
- autocoder/common/linter_core/linters/__init__.py +9 -0
- autocoder/common/linter_core/linters/java_linter.py +342 -0
- autocoder/common/linter_core/linters/python_linter.py +115 -0
- autocoder/common/linter_core/linters/typescript_linter.py +119 -0
- autocoder/common/linter_core/models/__init__.py +7 -0
- autocoder/common/linter_core/models/lint_result.py +91 -0
- autocoder/common/linter_core/models.py +33 -0
- autocoder/common/linter_core/tests/__init__.py +3 -0
- autocoder/common/linter_core/tests/test_config_loader.py +323 -0
- autocoder/common/linter_core/tests/test_config_loading.py +308 -0
- autocoder/common/linter_core/tests/test_factory_manager.py +234 -0
- autocoder/common/linter_core/tests/test_formatters.py +147 -0
- autocoder/common/linter_core/tests/test_integration.py +317 -0
- autocoder/common/linter_core/tests/test_java_linter.py +496 -0
- autocoder/common/linter_core/tests/test_linters.py +265 -0
- autocoder/common/linter_core/tests/test_models.py +81 -0
- autocoder/common/linter_core/tests/verify_config_loading.py +296 -0
- autocoder/common/linter_core/tests/verify_fixes.py +183 -0
- autocoder/common/llm_friendly_package/__init__.py +31 -0
- autocoder/common/llm_friendly_package/base_manager.py +102 -0
- autocoder/common/llm_friendly_package/docs_manager.py +121 -0
- autocoder/common/llm_friendly_package/library_manager.py +171 -0
- autocoder/common/{llm_friendly_package.py → llm_friendly_package/main_manager.py} +204 -231
- autocoder/common/llm_friendly_package/models.py +40 -0
- autocoder/common/llm_friendly_package/test_llm_friendly_package.py +536 -0
- autocoder/common/llms/__init__.py +15 -0
- autocoder/common/llms/demo_error_handling.py +85 -0
- autocoder/common/llms/factory.py +142 -0
- autocoder/common/llms/manager.py +264 -0
- autocoder/common/llms/pricing.py +121 -0
- autocoder/common/llms/registry.py +288 -0
- autocoder/common/llms/schema.py +77 -0
- autocoder/common/llms/simple_demo.py +45 -0
- autocoder/common/llms/test_quick_model.py +116 -0
- autocoder/common/llms/test_remove_functionality.py +182 -0
- autocoder/common/llms/tests/__init__.py +1 -0
- autocoder/common/llms/tests/test_manager.py +330 -0
- autocoder/common/llms/tests/test_registry.py +364 -0
- autocoder/common/mcp_tools/__init__.py +62 -0
- autocoder/common/{mcp_tools.py → mcp_tools/executor.py} +49 -40
- autocoder/common/{mcp_hub.py → mcp_tools/hub.py} +42 -68
- autocoder/common/{mcp_server_install.py → mcp_tools/installer.py} +16 -28
- autocoder/common/{mcp_server.py → mcp_tools/server.py} +176 -48
- autocoder/common/mcp_tools/test_keyboard_interrupt.py +93 -0
- autocoder/common/mcp_tools/test_mcp_tools.py +391 -0
- autocoder/common/{mcp_server_types.py → mcp_tools/types.py} +121 -48
- autocoder/common/mcp_tools/verify_functionality.py +202 -0
- autocoder/common/model_speed_tester.py +32 -26
- autocoder/common/priority_directory_finder/__init__.py +142 -0
- autocoder/common/priority_directory_finder/examples.py +230 -0
- autocoder/common/priority_directory_finder/finder.py +283 -0
- autocoder/common/priority_directory_finder/models.py +236 -0
- autocoder/common/priority_directory_finder/test_priority_directory_finder.py +431 -0
- autocoder/common/project_scanner/__init__.py +18 -0
- autocoder/common/project_scanner/compat.py +77 -0
- autocoder/common/project_scanner/scanner.py +436 -0
- autocoder/common/project_tracker/__init__.py +27 -0
- autocoder/common/project_tracker/api.py +228 -0
- autocoder/common/project_tracker/demo.py +272 -0
- autocoder/common/project_tracker/tracker.py +487 -0
- autocoder/common/project_tracker/types.py +53 -0
- autocoder/common/pruner/__init__.py +67 -0
- autocoder/common/pruner/agentic_conversation_pruner.py +746 -0
- autocoder/common/{context_pruner.py → pruner/context_pruner.py} +137 -40
- autocoder/common/pruner/conversation_message_ids_api.py +386 -0
- autocoder/common/pruner/conversation_message_ids_manager.py +347 -0
- autocoder/common/pruner/conversation_message_ids_pruner.py +473 -0
- autocoder/common/pruner/conversation_normalizer.py +347 -0
- autocoder/common/{conversation_pruner.py → pruner/conversation_pruner.py} +26 -6
- autocoder/common/pruner/test_agentic_conversation_pruner.py +784 -0
- autocoder/common/pruner/test_context_pruner.py +546 -0
- autocoder/common/pruner/test_conversation_normalizer.py +502 -0
- autocoder/common/pruner/test_tool_content_detector.py +324 -0
- autocoder/common/pruner/tool_content_detector.py +227 -0
- autocoder/common/pruner/tools/__init__.py +18 -0
- autocoder/common/pruner/tools/query_message_ids.py +264 -0
- autocoder/common/pruner/tools/test_agentic_pruning_logic.py +432 -0
- autocoder/common/pruner/tools/test_message_ids_pruning_only.py +192 -0
- autocoder/common/pull_requests/__init__.py +9 -1
- autocoder/common/pull_requests/utils.py +122 -1
- autocoder/common/rag_manager/rag_manager.py +36 -40
- autocoder/common/rulefiles/__init__.py +53 -1
- autocoder/common/rulefiles/api.py +250 -0
- autocoder/common/rulefiles/core/__init__.py +14 -0
- autocoder/common/rulefiles/core/manager.py +241 -0
- autocoder/common/rulefiles/core/selector.py +805 -0
- autocoder/common/rulefiles/models/__init__.py +20 -0
- autocoder/common/rulefiles/models/index.py +16 -0
- autocoder/common/rulefiles/models/init_rule.py +18 -0
- autocoder/common/rulefiles/models/rule_file.py +18 -0
- autocoder/common/rulefiles/models/rule_relevance.py +14 -0
- autocoder/common/rulefiles/models/summary.py +16 -0
- autocoder/common/rulefiles/test_rulefiles.py +776 -0
- autocoder/common/rulefiles/utils/__init__.py +34 -0
- autocoder/common/rulefiles/utils/monitor.py +86 -0
- autocoder/common/rulefiles/utils/parser.py +230 -0
- autocoder/common/save_formatted_log.py +67 -10
- autocoder/common/search_replace.py +8 -1
- autocoder/common/search_replace_patch/__init__.py +24 -0
- autocoder/common/search_replace_patch/base.py +115 -0
- autocoder/common/search_replace_patch/manager.py +248 -0
- autocoder/common/search_replace_patch/patch_replacer.py +304 -0
- autocoder/common/search_replace_patch/similarity_replacer.py +306 -0
- autocoder/common/search_replace_patch/string_replacer.py +181 -0
- autocoder/common/search_replace_patch/tests/__init__.py +3 -0
- autocoder/common/search_replace_patch/tests/run_tests.py +126 -0
- autocoder/common/search_replace_patch/tests/test_base.py +188 -0
- autocoder/common/search_replace_patch/tests/test_empty_line_insert.py +233 -0
- autocoder/common/search_replace_patch/tests/test_integration.py +389 -0
- autocoder/common/search_replace_patch/tests/test_manager.py +351 -0
- autocoder/common/search_replace_patch/tests/test_patch_replacer.py +316 -0
- autocoder/common/search_replace_patch/tests/test_regex_replacer.py +306 -0
- autocoder/common/search_replace_patch/tests/test_similarity_replacer.py +384 -0
- autocoder/common/shell_commands/__init__.py +197 -0
- autocoder/common/shell_commands/background_process_notifier.py +346 -0
- autocoder/common/shell_commands/command_executor.py +1127 -0
- autocoder/common/shell_commands/error_recovery.py +541 -0
- autocoder/common/shell_commands/exceptions.py +120 -0
- autocoder/common/shell_commands/interactive_executor.py +476 -0
- autocoder/common/shell_commands/interactive_pexpect_process.py +623 -0
- autocoder/common/shell_commands/interactive_process.py +744 -0
- autocoder/common/shell_commands/interactive_session_manager.py +1014 -0
- autocoder/common/shell_commands/monitoring.py +529 -0
- autocoder/common/shell_commands/process_cleanup.py +386 -0
- autocoder/common/shell_commands/process_manager.py +606 -0
- autocoder/common/shell_commands/test_interactive_pexpect_process.py +281 -0
- autocoder/common/shell_commands/tests/__init__.py +6 -0
- autocoder/common/shell_commands/tests/conftest.py +118 -0
- autocoder/common/shell_commands/tests/test_background_process_notifier.py +703 -0
- autocoder/common/shell_commands/tests/test_command_executor.py +448 -0
- autocoder/common/shell_commands/tests/test_error_recovery.py +305 -0
- autocoder/common/shell_commands/tests/test_exceptions.py +299 -0
- autocoder/common/shell_commands/tests/test_execute_batch.py +588 -0
- autocoder/common/shell_commands/tests/test_indented_batch_commands.py +244 -0
- autocoder/common/shell_commands/tests/test_integration.py +664 -0
- autocoder/common/shell_commands/tests/test_monitoring.py +546 -0
- autocoder/common/shell_commands/tests/test_performance.py +632 -0
- autocoder/common/shell_commands/tests/test_process_cleanup.py +397 -0
- autocoder/common/shell_commands/tests/test_process_manager.py +606 -0
- autocoder/common/shell_commands/tests/test_timeout_config.py +343 -0
- autocoder/common/shell_commands/tests/test_timeout_manager.py +520 -0
- autocoder/common/shell_commands/timeout_config.py +315 -0
- autocoder/common/shell_commands/timeout_manager.py +352 -0
- autocoder/common/terminal_paste/__init__.py +14 -0
- autocoder/common/terminal_paste/demo.py +145 -0
- autocoder/common/terminal_paste/demo_paste_functionality.py +95 -0
- autocoder/common/terminal_paste/paste_handler.py +200 -0
- autocoder/common/terminal_paste/paste_manager.py +118 -0
- autocoder/common/terminal_paste/tests/__init__.py +1 -0
- autocoder/common/terminal_paste/tests/test_paste_handler.py +182 -0
- autocoder/common/terminal_paste/tests/test_paste_manager.py +126 -0
- autocoder/common/terminal_paste/utils.py +163 -0
- autocoder/common/test_autocoder_args.py +232 -0
- autocoder/common/test_env_manager.py +173 -0
- autocoder/common/test_env_manager_integration.py +159 -0
- autocoder/common/text_similarity/__init__.py +9 -0
- autocoder/common/text_similarity/demo.py +216 -0
- autocoder/common/text_similarity/examples.py +266 -0
- autocoder/common/text_similarity/test_text_similarity.py +306 -0
- autocoder/common/text_similarity/text_similarity.py +194 -0
- autocoder/common/text_similarity/utils.py +125 -0
- autocoder/common/todos/__init__.py +61 -0
- autocoder/common/todos/cache/__init__.py +16 -0
- autocoder/common/todos/cache/base_cache.py +89 -0
- autocoder/common/todos/cache/cache_manager.py +228 -0
- autocoder/common/todos/cache/memory_cache.py +225 -0
- autocoder/common/todos/config.py +155 -0
- autocoder/common/todos/exceptions.py +35 -0
- autocoder/common/todos/get_todo_manager.py +161 -0
- autocoder/common/todos/manager.py +537 -0
- autocoder/common/todos/models.py +239 -0
- autocoder/common/todos/storage/__init__.py +14 -0
- autocoder/common/todos/storage/base_storage.py +76 -0
- autocoder/common/todos/storage/file_storage.py +278 -0
- autocoder/common/tokens/__init__.py +15 -0
- autocoder/common/tokens/counter.py +44 -2
- autocoder/common/tools_manager/__init__.py +17 -0
- autocoder/common/tools_manager/examples.py +162 -0
- autocoder/common/tools_manager/manager.py +385 -0
- autocoder/common/tools_manager/models.py +39 -0
- autocoder/common/tools_manager/test_tools_manager.py +303 -0
- autocoder/common/tools_manager/utils.py +191 -0
- autocoder/common/v2/agent/agentic_callbacks.py +270 -0
- autocoder/common/v2/agent/agentic_edit.py +2729 -2052
- autocoder/common/v2/agent/agentic_edit_change_manager.py +474 -0
- autocoder/common/v2/agent/agentic_edit_tools/__init__.py +43 -2
- autocoder/common/v2/agent/agentic_edit_tools/ac_mod_list_tool_resolver.py +279 -0
- autocoder/common/v2/agent/agentic_edit_tools/ac_mod_read_tool_resolver.py +40 -0
- autocoder/common/v2/agent/agentic_edit_tools/ac_mod_write_tool_resolver.py +52 -0
- autocoder/common/v2/agent/agentic_edit_tools/ask_followup_question_tool_resolver.py +8 -0
- autocoder/common/v2/agent/agentic_edit_tools/background_task_tool_resolver.py +1167 -0
- autocoder/common/v2/agent/agentic_edit_tools/base_tool_resolver.py +2 -2
- autocoder/common/v2/agent/agentic_edit_tools/conversation_message_ids_read_tool_resolver.py +214 -0
- autocoder/common/v2/agent/agentic_edit_tools/conversation_message_ids_write_tool_resolver.py +299 -0
- autocoder/common/v2/agent/agentic_edit_tools/count_tokens_tool_resolver.py +290 -0
- autocoder/common/v2/agent/agentic_edit_tools/execute_command_tool_resolver.py +565 -30
- autocoder/common/v2/agent/agentic_edit_tools/execute_workflow_tool_resolver.py +485 -0
- autocoder/common/v2/agent/agentic_edit_tools/extract_to_text_tool_resolver.py +225 -0
- autocoder/common/v2/agent/agentic_edit_tools/lint_report.py +79 -0
- autocoder/common/v2/agent/agentic_edit_tools/linter_config_models.py +343 -0
- autocoder/common/v2/agent/agentic_edit_tools/linter_enabled_tool_resolver.py +189 -0
- autocoder/common/v2/agent/agentic_edit_tools/list_files_tool_resolver.py +169 -101
- autocoder/common/v2/agent/agentic_edit_tools/load_extra_document_tool_resolver.py +349 -0
- autocoder/common/v2/agent/agentic_edit_tools/read_file_tool_resolver.py +244 -51
- autocoder/common/v2/agent/agentic_edit_tools/replace_in_file_tool_resolver.py +667 -147
- autocoder/common/v2/agent/agentic_edit_tools/run_named_subagents_tool_resolver.py +691 -0
- autocoder/common/v2/agent/agentic_edit_tools/search_files_tool_resolver.py +409 -140
- autocoder/common/v2/agent/agentic_edit_tools/session_interactive_tool_resolver.py +115 -0
- autocoder/common/v2/agent/agentic_edit_tools/session_start_tool_resolver.py +190 -0
- autocoder/common/v2/agent/agentic_edit_tools/session_stop_tool_resolver.py +76 -0
- autocoder/common/v2/agent/agentic_edit_tools/test_write_to_file_tool_resolver.py +209 -194
- autocoder/common/v2/agent/agentic_edit_tools/todo_read_tool_resolver.py +135 -0
- autocoder/common/v2/agent/agentic_edit_tools/todo_write_tool_resolver.py +328 -0
- autocoder/common/v2/agent/agentic_edit_tools/use_mcp_tool_resolver.py +2 -2
- autocoder/common/v2/agent/agentic_edit_tools/web_crawl_tool_resolver.py +557 -0
- autocoder/common/v2/agent/agentic_edit_tools/web_search_tool_resolver.py +600 -0
- autocoder/common/v2/agent/agentic_edit_tools/write_to_file_tool_resolver.py +56 -121
- autocoder/common/v2/agent/agentic_edit_types.py +386 -10
- autocoder/common/v2/agent/runner/__init__.py +31 -0
- autocoder/common/v2/agent/runner/base_runner.py +92 -0
- autocoder/common/v2/agent/runner/file_based_event_runner.py +217 -0
- autocoder/common/v2/agent/runner/sdk_runner.py +182 -0
- autocoder/common/v2/agent/runner/terminal_runner.py +396 -0
- autocoder/common/v2/agent/runner/tool_display.py +589 -0
- autocoder/common/v2/agent/test_agentic_callbacks.py +265 -0
- autocoder/common/v2/agent/test_agentic_edit.py +194 -0
- autocoder/common/v2/agent/tool_caller/__init__.py +24 -0
- autocoder/common/v2/agent/tool_caller/default_tool_resolver_map.py +135 -0
- autocoder/common/v2/agent/tool_caller/integration_test.py +172 -0
- autocoder/common/v2/agent/tool_caller/plugins/__init__.py +14 -0
- autocoder/common/v2/agent/tool_caller/plugins/base_plugin.py +126 -0
- autocoder/common/v2/agent/tool_caller/plugins/examples/__init__.py +13 -0
- autocoder/common/v2/agent/tool_caller/plugins/examples/logging_plugin.py +164 -0
- autocoder/common/v2/agent/tool_caller/plugins/examples/security_filter_plugin.py +198 -0
- autocoder/common/v2/agent/tool_caller/plugins/plugin_interface.py +141 -0
- autocoder/common/v2/agent/tool_caller/test_tool_caller.py +278 -0
- autocoder/common/v2/agent/tool_caller/tool_call_plugin_manager.py +331 -0
- autocoder/common/v2/agent/tool_caller/tool_caller.py +337 -0
- autocoder/common/v2/agent/tool_caller/usage_example.py +193 -0
- autocoder/common/v2/code_agentic_editblock_manager.py +4 -4
- autocoder/common/v2/code_auto_generate.py +136 -78
- autocoder/common/v2/code_auto_generate_diff.py +135 -79
- autocoder/common/v2/code_auto_generate_editblock.py +174 -99
- autocoder/common/v2/code_auto_generate_strict_diff.py +151 -71
- autocoder/common/v2/code_auto_merge.py +1 -1
- autocoder/common/v2/code_auto_merge_editblock.py +13 -1
- autocoder/common/v2/code_diff_manager.py +3 -3
- autocoder/common/v2/code_editblock_manager.py +4 -14
- autocoder/common/v2/code_manager.py +1 -1
- autocoder/common/v2/code_strict_diff_manager.py +2 -2
- autocoder/common/wrap_llm_hint/__init__.py +10 -0
- autocoder/common/wrap_llm_hint/test_wrap_llm_hint.py +1067 -0
- autocoder/common/wrap_llm_hint/utils.py +432 -0
- autocoder/common/wrap_llm_hint/wrap_llm_hint.py +323 -0
- autocoder/completer/__init__.py +8 -0
- autocoder/completer/command_completer_v2.py +1051 -0
- autocoder/default_project/__init__.py +501 -0
- autocoder/dispacher/__init__.py +4 -12
- autocoder/dispacher/actions/action.py +165 -7
- autocoder/dispacher/actions/plugins/action_regex_project.py +2 -2
- autocoder/index/entry.py +117 -125
- autocoder/{agent → index/filter}/agentic_filter.py +323 -334
- autocoder/index/filter/normal_filter.py +5 -11
- autocoder/index/filter/quick_filter.py +1 -1
- autocoder/index/index.py +36 -9
- autocoder/index/tests/__init__.py +1 -0
- autocoder/index/tests/run_tests.py +195 -0
- autocoder/index/tests/test_entry.py +303 -0
- autocoder/index/tests/test_index_manager.py +314 -0
- autocoder/index/tests/test_module_integration.py +300 -0
- autocoder/index/tests/test_symbols_utils.py +183 -0
- autocoder/inner/__init__.py +4 -0
- autocoder/inner/agentic.py +932 -0
- autocoder/inner/async_command_handler.py +992 -0
- autocoder/inner/conversation_command_handlers.py +623 -0
- autocoder/inner/merge_command_handler.py +213 -0
- autocoder/inner/queue_command_handler.py +684 -0
- autocoder/models.py +95 -266
- autocoder/plugins/git_helper_plugin.py +31 -29
- autocoder/plugins/token_helper_plugin.py +156 -37
- autocoder/pyproject/__init__.py +32 -29
- autocoder/rag/agentic_rag.py +215 -75
- autocoder/rag/cache/simple_cache.py +1 -2
- autocoder/rag/loaders/image_loader.py +1 -1
- autocoder/rag/long_context_rag.py +42 -26
- autocoder/rag/qa_conversation_strategy.py +1 -1
- autocoder/rag/terminal/__init__.py +17 -0
- autocoder/rag/terminal/args.py +581 -0
- autocoder/rag/terminal/bootstrap.py +61 -0
- autocoder/rag/terminal/command_handlers.py +653 -0
- autocoder/rag/terminal/formatters/__init__.py +20 -0
- autocoder/rag/terminal/formatters/base.py +70 -0
- autocoder/rag/terminal/formatters/json_format.py +66 -0
- autocoder/rag/terminal/formatters/stream_json.py +95 -0
- autocoder/rag/terminal/formatters/text.py +28 -0
- autocoder/rag/terminal/init.py +120 -0
- autocoder/rag/terminal/utils.py +106 -0
- autocoder/rag/test_agentic_rag.py +389 -0
- autocoder/rag/test_doc_filter.py +3 -3
- autocoder/rag/test_long_context_rag.py +1 -1
- autocoder/rag/test_token_limiter.py +517 -10
- autocoder/rag/token_counter.py +3 -0
- autocoder/rag/token_limiter.py +19 -15
- autocoder/rag/tools/__init__.py +26 -2
- autocoder/rag/tools/bochaai_example.py +343 -0
- autocoder/rag/tools/bochaai_sdk.py +541 -0
- autocoder/rag/tools/metaso_example.py +268 -0
- autocoder/rag/tools/metaso_sdk.py +417 -0
- autocoder/rag/tools/recall_tool.py +28 -7
- autocoder/rag/tools/run_integration_tests.py +204 -0
- autocoder/rag/tools/test_all_providers.py +318 -0
- autocoder/rag/tools/test_bochaai_integration.py +482 -0
- autocoder/rag/tools/test_final_integration.py +215 -0
- autocoder/rag/tools/test_metaso_integration.py +424 -0
- autocoder/rag/tools/test_metaso_real.py +171 -0
- autocoder/rag/tools/test_web_crawl_tool.py +639 -0
- autocoder/rag/tools/test_web_search_tool.py +509 -0
- autocoder/rag/tools/todo_read_tool.py +202 -0
- autocoder/rag/tools/todo_write_tool.py +412 -0
- autocoder/rag/tools/web_crawl_tool.py +634 -0
- autocoder/rag/tools/web_search_tool.py +558 -0
- autocoder/rag/tools/web_tools_example.py +119 -0
- autocoder/rag/types.py +16 -0
- autocoder/rag/variable_holder.py +4 -2
- autocoder/rags.py +86 -79
- autocoder/regexproject/__init__.py +23 -21
- autocoder/run_context.py +9 -0
- autocoder/sdk/__init__.py +50 -161
- autocoder/sdk/api.py +370 -0
- autocoder/sdk/async_runner/__init__.py +26 -0
- autocoder/sdk/async_runner/async_executor.py +650 -0
- autocoder/sdk/async_runner/async_handler.py +356 -0
- autocoder/sdk/async_runner/markdown_processor.py +595 -0
- autocoder/sdk/async_runner/task_metadata.py +284 -0
- autocoder/sdk/async_runner/worktree_manager.py +438 -0
- autocoder/sdk/cli/__init__.py +2 -5
- autocoder/sdk/cli/formatters.py +28 -204
- autocoder/sdk/cli/handlers.py +77 -44
- autocoder/sdk/cli/main.py +158 -170
- autocoder/sdk/cli/options.py +95 -22
- autocoder/sdk/constants.py +139 -51
- autocoder/sdk/core/auto_coder_core.py +484 -267
- autocoder/sdk/core/bridge.py +298 -118
- autocoder/sdk/exceptions.py +18 -12
- autocoder/sdk/formatters/__init__.py +19 -0
- autocoder/sdk/formatters/input.py +64 -0
- autocoder/sdk/formatters/output.py +247 -0
- autocoder/sdk/formatters/stream.py +54 -0
- autocoder/sdk/models/__init__.py +6 -5
- autocoder/sdk/models/options.py +55 -18
- autocoder/sdk/utils/formatters.py +27 -195
- autocoder/suffixproject/__init__.py +28 -25
- autocoder/terminal/__init__.py +14 -0
- autocoder/terminal/app.py +454 -0
- autocoder/terminal/args.py +32 -0
- autocoder/terminal/bootstrap.py +178 -0
- autocoder/terminal/command_processor.py +521 -0
- autocoder/terminal/command_registry.py +57 -0
- autocoder/terminal/help.py +97 -0
- autocoder/terminal/tasks/__init__.py +5 -0
- autocoder/terminal/tasks/background.py +77 -0
- autocoder/terminal/tasks/task_event.py +70 -0
- autocoder/terminal/ui/__init__.py +13 -0
- autocoder/terminal/ui/completer.py +268 -0
- autocoder/terminal/ui/keybindings.py +75 -0
- autocoder/terminal/ui/session.py +41 -0
- autocoder/terminal/ui/toolbar.py +64 -0
- autocoder/terminal/utils/__init__.py +13 -0
- autocoder/terminal/utils/errors.py +18 -0
- autocoder/terminal/utils/paths.py +19 -0
- autocoder/terminal/utils/shell.py +43 -0
- autocoder/terminal_v3/__init__.py +10 -0
- autocoder/terminal_v3/app.py +201 -0
- autocoder/terminal_v3/handlers/__init__.py +5 -0
- autocoder/terminal_v3/handlers/command_handler.py +131 -0
- autocoder/terminal_v3/models/__init__.py +6 -0
- autocoder/terminal_v3/models/conversation_buffer.py +214 -0
- autocoder/terminal_v3/models/message.py +50 -0
- autocoder/terminal_v3/models/tool_display.py +247 -0
- autocoder/terminal_v3/ui/__init__.py +7 -0
- autocoder/terminal_v3/ui/keybindings.py +56 -0
- autocoder/terminal_v3/ui/layout.py +141 -0
- autocoder/terminal_v3/ui/styles.py +43 -0
- autocoder/tsproject/__init__.py +23 -23
- autocoder/utils/auto_coder_utils/chat_stream_out.py +1 -1
- autocoder/utils/llms.py +88 -80
- autocoder/utils/math_utils.py +101 -0
- autocoder/utils/model_provider_selector.py +16 -4
- autocoder/utils/operate_config_api.py +33 -5
- autocoder/utils/thread_utils.py +2 -2
- autocoder/version.py +4 -2
- autocoder/workflow_agents/__init__.py +84 -0
- autocoder/workflow_agents/agent.py +143 -0
- autocoder/workflow_agents/exceptions.py +573 -0
- autocoder/workflow_agents/executor.py +489 -0
- autocoder/workflow_agents/loader.py +737 -0
- autocoder/workflow_agents/runner.py +267 -0
- autocoder/workflow_agents/types.py +172 -0
- autocoder/workflow_agents/utils.py +434 -0
- autocoder/workflow_agents/workflow_manager.py +211 -0
- auto_coder-0.1.400.dist-info/METADATA +0 -396
- auto_coder-0.1.400.dist-info/RECORD +0 -425
- auto_coder-0.1.400.dist-info/licenses/LICENSE +0 -201
- autocoder/auto_coder_server.py +0 -672
- autocoder/benchmark.py +0 -138
- autocoder/common/ac_style_command_parser/example.py +0 -7
- autocoder/common/cleaner.py +0 -31
- autocoder/common/command_completer_v2.py +0 -615
- autocoder/common/directory_cache/__init__.py +0 -1
- autocoder/common/directory_cache/cache.py +0 -192
- autocoder/common/directory_cache/test_cache.py +0 -190
- autocoder/common/file_checkpoint/examples.py +0 -217
- autocoder/common/llm_friendly_package_example.py +0 -138
- autocoder/common/llm_friendly_package_test.py +0 -63
- autocoder/common/pull_requests/test_module.py +0 -1
- autocoder/common/rulefiles/autocoderrules_utils.py +0 -484
- autocoder/common/text.py +0 -30
- autocoder/common/v2/agent/agentic_edit_tools/list_package_info_tool_resolver.py +0 -42
- autocoder/common/v2/agent/agentic_edit_tools/test_execute_command_tool_resolver.py +0 -70
- autocoder/common/v2/agent/agentic_edit_tools/test_search_files_tool_resolver.py +0 -163
- autocoder/common/v2/agent/agentic_tool_display.py +0 -183
- autocoder/plugins/dynamic_completion_example.py +0 -148
- autocoder/plugins/sample_plugin.py +0 -160
- autocoder/sdk/cli/__main__.py +0 -26
- autocoder/sdk/cli/completion_wrapper.py +0 -38
- autocoder/sdk/cli/install_completion.py +0 -301
- autocoder/sdk/models/messages.py +0 -209
- autocoder/sdk/session/__init__.py +0 -32
- autocoder/sdk/session/session.py +0 -106
- autocoder/sdk/session/session_manager.py +0 -56
- {auto_coder-0.1.400.dist-info → auto_coder-2.0.0.dist-info}/top_level.txt +0 -0
- /autocoder/{sdk/example.py → common/agent_query_queue/__init__.py} +0 -0
|
@@ -0,0 +1,2208 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Auto-coder core messages for internationalization
|
|
3
|
+
Contains all messages used by the auto-coder core functionality
|
|
4
|
+
"""
|
|
5
|
+
|
|
6
|
+
AUTO_CODER_MESSAGES = {
|
|
7
|
+
"file_scored_message": {
|
|
8
|
+
"en": "File scored: {{file_path}} - Score: {{score}}",
|
|
9
|
+
"zh": "文件评分: {{file_path}} - 分数: {{score}}",
|
|
10
|
+
"ja": "ファイルスコア: {{file_path}} - スコア: {{score}}",
|
|
11
|
+
"ar": "تقييم الملف: {{file_path}} - النتيجة: {{score}}",
|
|
12
|
+
"ru": "Оценка файла: {{file_path}} - Баллы: {{score}}",
|
|
13
|
+
},
|
|
14
|
+
"invalid_file_pattern": {
|
|
15
|
+
"en": "Invalid file pattern: {{file_pattern}}. e.g. regex://.*/package-lock\\.json",
|
|
16
|
+
"zh": "无效的文件模式: {{file_pattern}}. 例如: regex://.*/package-lock\\.json",
|
|
17
|
+
"ja": "無効なファイルパターン: {{file_pattern}}. 例: regex://.*/package-lock\\.json",
|
|
18
|
+
"ar": "نمط ملف غير صحيح: {{file_pattern}}. مثال: regex://.*/package-lock\\.json",
|
|
19
|
+
"ru": "Неверный шаблон файла: {{file_pattern}}. Например: regex://.*/package-lock\\.json",
|
|
20
|
+
},
|
|
21
|
+
"config_validation_error": {
|
|
22
|
+
"en": "Config validation error: {{error}}",
|
|
23
|
+
"zh": "配置验证错误: {{error}}",
|
|
24
|
+
"ja": "設定検証エラー: {{error}}",
|
|
25
|
+
"ar": "خطأ في التحقق من التكوين: {{error}}",
|
|
26
|
+
"ru": "Ошибка валидации конфигурации: {{error}}",
|
|
27
|
+
},
|
|
28
|
+
"invalid_boolean_value": {
|
|
29
|
+
"en": "Value '{{value}}' is not a valid boolean(true/false)",
|
|
30
|
+
"zh": "值 '{{value}}' 不是有效的布尔值(true/false)",
|
|
31
|
+
"ja": "値 '{{value}}' は有効なブール値(true/false)ではありません",
|
|
32
|
+
"ar": "القيمة '{{value}}' ليست قيمة منطقية صحيحة(true/false)",
|
|
33
|
+
"ru": "Значение '{{value}}' не является допустимым булевым значением(true/false)",
|
|
34
|
+
},
|
|
35
|
+
"invalid_integer_value": {
|
|
36
|
+
"en": "Value '{{value}}' is not a valid integer",
|
|
37
|
+
"zh": "值 '{{value}}' 不是有效的整数",
|
|
38
|
+
"ja": "値 '{{value}}' は有効な整数ではありません",
|
|
39
|
+
"ar": "القيمة '{{value}}' ليست عددًا صحيحًا صالحًا",
|
|
40
|
+
"ru": "Значение '{{value}}' не является допустимым целым числом",
|
|
41
|
+
},
|
|
42
|
+
"invalid_float_value": {
|
|
43
|
+
"en": "Value '{{value}}' is not a valid float",
|
|
44
|
+
"zh": "值 '{{value}}' 不是有效的浮点数",
|
|
45
|
+
"ja": "値 '{{value}}' は有効な浮動小数点数ではありません",
|
|
46
|
+
"ar": "القيمة '{{value}}' ليست رقمًا عشريًا صالحًا",
|
|
47
|
+
"ru": "Значение '{{value}}' не является допустимым числом с плавающей точкой",
|
|
48
|
+
},
|
|
49
|
+
"invalid_type_value": {
|
|
50
|
+
"en": "Value '{{value}}' is not a valid type (expected: {{types}})",
|
|
51
|
+
"zh": "值 '{{value}}' 不是有效的类型 (期望: {{types}})",
|
|
52
|
+
"ja": "値 '{{value}}' は有効な型ではありません (期待値: {{types}})",
|
|
53
|
+
"ar": "القيمة '{{value}}' ليست نوعًا صالحًا (متوقع: {{types}})",
|
|
54
|
+
"ru": "Значение '{{value}}' не является допустимым типом (ожидается: {{types}})",
|
|
55
|
+
},
|
|
56
|
+
"value_out_of_range": {
|
|
57
|
+
"en": "Value {{value}} is out of allowed range({{min}}~{{max}})",
|
|
58
|
+
"zh": "值 {value} 超出允许范围({min}~{max})",
|
|
59
|
+
"ja": "値 {{value}} は許可された範囲({{min}}~{{max}})を超えています",
|
|
60
|
+
"ar": "القيمة {{value}} خارج النطاق المسموح({{min}}~{{max}})",
|
|
61
|
+
"ru": "Значение {{value}} выходит за допустимый диапазон({{min}}~{{max}})",
|
|
62
|
+
},
|
|
63
|
+
"invalid_choice": {
|
|
64
|
+
"en": "Value '{{value}}' is not in allowed options({{allowed}})",
|
|
65
|
+
"zh": "值 '{value}' 不在允许选项中({allowed})",
|
|
66
|
+
"ja": "値 '{{value}}' は許可されたオプション({{allowed}})にありません",
|
|
67
|
+
"ar": "القيمة '{{value}}' ليست في الخيارات المسموحة({{allowed}})",
|
|
68
|
+
"ru": "Значение '{{value}}' не входит в разрешенные параметры({{allowed}})",
|
|
69
|
+
},
|
|
70
|
+
"unknown_config_key": {
|
|
71
|
+
"en": "Unknown config key '{{key}}'",
|
|
72
|
+
"zh": "未知的配置项 '{key}'",
|
|
73
|
+
"ja": "不明な設定キー '{{key}}'",
|
|
74
|
+
"ar": "مفتاح التكوين غير معروف '{{key}}'",
|
|
75
|
+
"ru": "Неизвестный ключ конфигурации '{{key}}'",
|
|
76
|
+
},
|
|
77
|
+
"model_not_found": {
|
|
78
|
+
"en": "Model {{model_name}} not found",
|
|
79
|
+
"zh": "未找到模型: {{model_name}}",
|
|
80
|
+
"ja": "モデル {{model_name}} が見つかりません",
|
|
81
|
+
"ar": "لم يتم العثور على النموذج {{model_name}}",
|
|
82
|
+
"ru": "Модель {{model_name}} не найдена",
|
|
83
|
+
},
|
|
84
|
+
"model_info_not_found": {
|
|
85
|
+
"en": "Model information not found for '{{model_name}}' in {{product_mode}} mode. Please check your model configuration in ~/.auto-coder/keys/models.json or verify the model name is correct.",
|
|
86
|
+
"zh": "在 {{product_mode}} 模式下未找到模型 '{{model_name}}' 的信息。请检查 ~/.auto-coder/keys/models.json 中的模型配置或验证模型名称是否正确。",
|
|
87
|
+
"ja": "{{product_mode}} モードでモデル '{{model_name}}' の情報が見つかりません。~/.auto-coder/keys/models.json のモデル設定を確認するか、モデル名が正しいことを確認してください。",
|
|
88
|
+
"ar": "لم يتم العثور على معلومات النموذج '{{model_name}}' في وضع {{product_mode}}. يرجى التحقق من تكوين النموذج في ~/.auto-coder/keys/models.json أو التحقق من صحة اسم النموذج.",
|
|
89
|
+
"ru": "Информация о модели '{{model_name}}' не найдена в режиме {{product_mode}}. Пожалуйста, проверьте конфигурацию модели в ~/.auto-coder/keys/models.json или убедитесь, что имя модели правильное.",
|
|
90
|
+
},
|
|
91
|
+
"required_without_default": {
|
|
92
|
+
"en": "Config key '{{key}}' requires explicit value",
|
|
93
|
+
"zh": "配置项 '{key}' 需要明确设置值",
|
|
94
|
+
"ja": "設定キー '{{key}}' には明示的な値が必要です",
|
|
95
|
+
"ar": "مفتاح التكوين '{{key}}' يتطلب قيمة صريحة",
|
|
96
|
+
"ru": "Ключ конфигурации '{{key}}' требует явного значения",
|
|
97
|
+
},
|
|
98
|
+
"auto_command_action_break": {
|
|
99
|
+
"en": "Command {{command}} execution failed (got {{action}} result), no result can be obtained, please try again",
|
|
100
|
+
"zh": "命令 {{command}} 执行失败(获取到了 {{action}} 的结果),无法获得任何结果,请重试",
|
|
101
|
+
"ja": "コマンド {{command}} の実行に失敗しました({{action}} の結果を取得)、結果を取得できません、再試行してください",
|
|
102
|
+
"ar": "فشل تنفيذ الأمر {{command}} (تم الحصول على نتيجة {{action}})، لا يمكن الحصول على أي نتيجة، يرجى المحاولة مرة أخرى",
|
|
103
|
+
"ru": "Выполнение команды {{command}} не удалось (получен результат {{action}}), невозможно получить результат, попробуйте снова",
|
|
104
|
+
},
|
|
105
|
+
"auto_command_break": {
|
|
106
|
+
"en": "Auto command execution failed to execute command: {{command}}",
|
|
107
|
+
"zh": "自动命令执行失败: {{command}}",
|
|
108
|
+
"ja": "自動コマンドの実行に失敗しました: {{command}}",
|
|
109
|
+
"ar": "فشل تنفيذ الأمر التلقائي: {{command}}",
|
|
110
|
+
"ru": "Не удалось выполнить автоматическую команду: {{command}}",
|
|
111
|
+
},
|
|
112
|
+
"auto_command_executing": {
|
|
113
|
+
"en": "\n\n============= Executing command: {{command}} =============\n\n",
|
|
114
|
+
"zh": "\n\n============= 正在执行指令: {{command}} =============\n\n",
|
|
115
|
+
"ja": "\n\n============= コマンドを実行中: {{command}} =============\n\n",
|
|
116
|
+
"ar": "\n\n============= تنفيذ الأمر: {{command}} =============\n\n",
|
|
117
|
+
"ru": "\n\n============= Выполнение команды: {{command}} =============\n\n",
|
|
118
|
+
},
|
|
119
|
+
"model_provider_select_title": {
|
|
120
|
+
"en": "Select Model Provider",
|
|
121
|
+
"zh": "选择模型供应商",
|
|
122
|
+
"ja": "モデルプロバイダーを選択",
|
|
123
|
+
"ar": "اختيار مزود النموذج",
|
|
124
|
+
"ru": "Выберите провайдера модели",
|
|
125
|
+
},
|
|
126
|
+
"auto_config_analyzing": {
|
|
127
|
+
"en": "Analyzing configuration...",
|
|
128
|
+
"zh": "正在分析配置...",
|
|
129
|
+
"ja": "設定を分析中...",
|
|
130
|
+
"ar": "تحليل التكوين...",
|
|
131
|
+
"ru": "Анализ конфигурации...",
|
|
132
|
+
},
|
|
133
|
+
"config_delete_success": {
|
|
134
|
+
"en": "Successfully deleted configuration: {{key}}",
|
|
135
|
+
"zh": "成功删除配置: {{key}}",
|
|
136
|
+
"ja": "設定を正常に削除しました: {{key}}",
|
|
137
|
+
"ar": "تم حذف التكوين بنجاح: {{key}}",
|
|
138
|
+
"ru": "Конфигурация успешно удалена: {{key}}",
|
|
139
|
+
},
|
|
140
|
+
"config_not_found": {
|
|
141
|
+
"en": "Configuration not found: {{key}}",
|
|
142
|
+
"zh": "未找到配置: {{key}}",
|
|
143
|
+
"ja": "設定が見つかりません: {{key}}",
|
|
144
|
+
"ar": "لم يتم العثور على التكوين: {{key}}",
|
|
145
|
+
"ru": "Конфигурация не найдена: {{key}}",
|
|
146
|
+
},
|
|
147
|
+
"config_invalid_format": {
|
|
148
|
+
"en": "Invalid configuration format. Expected 'key:value'",
|
|
149
|
+
"zh": "配置格式无效,应为'key:value'格式",
|
|
150
|
+
"ja": "無効な設定形式です。'key:value'形式が期待されます",
|
|
151
|
+
"ar": "تنسيق التكوين غير صحيح. متوقع 'key:value'",
|
|
152
|
+
"ru": "Неверный формат конфигурации. Ожидается 'key:value'",
|
|
153
|
+
},
|
|
154
|
+
"config_value_empty": {
|
|
155
|
+
"en": "Configuration value cannot be empty",
|
|
156
|
+
"zh": "配置值不能为空",
|
|
157
|
+
"ja": "設定値は空にできません",
|
|
158
|
+
"ar": "قيمة التكوين لا يمكن أن تكون فارغة",
|
|
159
|
+
"ru": "Значение конфигурации не может быть пустым",
|
|
160
|
+
},
|
|
161
|
+
"config_set_success": {
|
|
162
|
+
"en": "Successfully set configuration: {{key}} = {{value}}",
|
|
163
|
+
"zh": "成功设置配置: {{key}} = {{value}}",
|
|
164
|
+
"ja": "設定を正常に設定しました: {{key}} = {{value}}",
|
|
165
|
+
"ar": "تم تعيين التكوين بنجاح: {{key}} = {{value}}",
|
|
166
|
+
"ru": "Конфигурация успешно установлена: {{key}} = {{value}}",
|
|
167
|
+
},
|
|
168
|
+
"model_provider_select_text": {
|
|
169
|
+
"en": "Please select your model provider:",
|
|
170
|
+
"zh": "请选择您的模型供应商:",
|
|
171
|
+
"ja": "モデルプロバイダーを選択してください:",
|
|
172
|
+
"ar": "يرجى اختيار مزود النموذج الخاص بك:",
|
|
173
|
+
"ru": "Пожалуйста, выберите вашего провайдера модели:",
|
|
174
|
+
},
|
|
175
|
+
"model_provider_volcano": {
|
|
176
|
+
"en": "Volcano Engine",
|
|
177
|
+
"zh": "火山方舟",
|
|
178
|
+
"ja": "Volcano Engine",
|
|
179
|
+
"ar": "محرك البركان",
|
|
180
|
+
"ru": "Volcano Engine",
|
|
181
|
+
},
|
|
182
|
+
"model_provider_siliconflow": {
|
|
183
|
+
"en": "SiliconFlow AI",
|
|
184
|
+
"zh": "硅基流动",
|
|
185
|
+
"ja": "SiliconFlow AI",
|
|
186
|
+
"ar": "SiliconFlow AI",
|
|
187
|
+
"ru": "SiliconFlow AI",
|
|
188
|
+
},
|
|
189
|
+
"model_provider_deepseek": {
|
|
190
|
+
"en": "DeepSeek Official",
|
|
191
|
+
"zh": "DeepSeek官方",
|
|
192
|
+
"ja": "DeepSeek公式",
|
|
193
|
+
"ar": "DeepSeek الرسمي",
|
|
194
|
+
"ru": "DeepSeek Официальный",
|
|
195
|
+
},
|
|
196
|
+
"model_provider_openrouter": {
|
|
197
|
+
"en": "OpenRouter",
|
|
198
|
+
"zh": "OpenRouter",
|
|
199
|
+
"ja": "OpenRouter",
|
|
200
|
+
"ar": "OpenRouter",
|
|
201
|
+
"ru": "OpenRouter",
|
|
202
|
+
},
|
|
203
|
+
"model_provider_api_key_title": {
|
|
204
|
+
"en": "API Key",
|
|
205
|
+
"zh": "API密钥",
|
|
206
|
+
"ja": "APIキー",
|
|
207
|
+
"ar": "مفتاح API",
|
|
208
|
+
"ru": "API ключ",
|
|
209
|
+
},
|
|
210
|
+
"model_provider_volcano_api_key_text": {
|
|
211
|
+
"en": "Please enter your Volcano Engine API key:",
|
|
212
|
+
"zh": "请输入您的火山方舟API密钥:",
|
|
213
|
+
"ja": "Volcano Engine APIキーを入力してください:",
|
|
214
|
+
"ar": "يرجى إدخال مفتاح API الخاص بـ Volcano Engine:",
|
|
215
|
+
"ru": "Пожалуйста, введите ваш API ключ Volcano Engine:",
|
|
216
|
+
},
|
|
217
|
+
"model_provider_openrouter_api_key_text": {
|
|
218
|
+
"en": "Please enter your OpenRouter API key:",
|
|
219
|
+
"zh": "请输入您的OpenRouter API密钥:",
|
|
220
|
+
"ja": "OpenRouter APIキーを入力してください:",
|
|
221
|
+
"ar": "يرجى إدخال مفتاح API الخاص بـ OpenRouter:",
|
|
222
|
+
"ru": "Пожалуйста, введите ваш API ключ OpenRouter:",
|
|
223
|
+
},
|
|
224
|
+
"model_provider_volcano_r1_text": {
|
|
225
|
+
"en": "Please enter your Volcano Engine R1 endpoint (format: ep-20250204215011-vzbsg):",
|
|
226
|
+
"zh": "请输入您的火山方舟 R1 推理点(格式如: ep-20250204215011-vzbsg):",
|
|
227
|
+
"ja": "Volcano Engine R1エンドポイントを入力してください (形式: ep-20250204215011-vzbsg):",
|
|
228
|
+
"ar": "يرجى إدخال نقطة النهاية R1 الخاصة بـ Volcano Engine (التنسيق: ep-20250204215011-vzbsg):",
|
|
229
|
+
"ru": "Пожалуйста, введите ваш R1 эндпойнт Volcano Engine (формат: ep-20250204215011-vzbsg):",
|
|
230
|
+
},
|
|
231
|
+
"model_provider_volcano_v3_text": {
|
|
232
|
+
"en": "Please enter your Volcano Engine V3 endpoint (format: ep-20250204215011-vzbsg):",
|
|
233
|
+
"zh": "请输入您的火山方舟 V3 推理点(格式如: ep-20250204215011-vzbsg):",
|
|
234
|
+
"ja": "Volcano Engine V3エンドポイントを入力してください (形式: ep-20250204215011-vzbsg):",
|
|
235
|
+
"ar": "يرجى إدخال نقطة النهاية V3 الخاصة بـ Volcano Engine (التنسيق: ep-20250204215011-vzbsg):",
|
|
236
|
+
"ru": "Пожалуйста, введите ваш V3 эндпойнт Volcano Engine (формат: ep-20250204215011-vzbsg):",
|
|
237
|
+
},
|
|
238
|
+
"model_provider_siliconflow_api_key_text": {
|
|
239
|
+
"en": "Please enter your SiliconFlow AI API key:",
|
|
240
|
+
"zh": "请输入您的硅基流动API密钥:",
|
|
241
|
+
"ja": "SiliconFlow AI APIキーを入力してください:",
|
|
242
|
+
"ar": "يرجى إدخال مفتاح API الخاص بـ SiliconFlow AI:",
|
|
243
|
+
"ru": "Пожалуйста, введите ваш API ключ SiliconFlow AI:",
|
|
244
|
+
},
|
|
245
|
+
"model_provider_deepseek_api_key_text": {
|
|
246
|
+
"en": "Please enter your DeepSeek API key:",
|
|
247
|
+
"zh": "请输入您的DeepSeek API密钥:",
|
|
248
|
+
"ja": "DeepSeek APIキーを入力してください:",
|
|
249
|
+
"ar": "يرجى إدخال مفتاح API الخاص بـ DeepSeek:",
|
|
250
|
+
"ru": "Пожалуйста, введите ваш API ключ DeepSeek:",
|
|
251
|
+
},
|
|
252
|
+
"model_provider_selected": {
|
|
253
|
+
"en": "Provider configuration completed successfully! You can use /models command to view, add and modify all models later.",
|
|
254
|
+
"zh": "供应商配置已成功完成!后续你可以使用 /models 命令,查看,新增和修改所有模型",
|
|
255
|
+
"ja": "プロバイダー設定が正常に完了しました!後で /models コマンドを使用してすべてのモデルを表示、追加、変更できます。",
|
|
256
|
+
"ar": "تم إكمال تكوين المزود بنجاح! يمكنك استخدام أمر /models لعرض وإضافة وتعديل جميع النماذج لاحقاً.",
|
|
257
|
+
"ru": "Конфигурация провайдера успешно завершена! Вы можете использовать команду /models для просмотра, добавления и изменения всех моделей позже.",
|
|
258
|
+
},
|
|
259
|
+
"model_provider_success_title": {
|
|
260
|
+
"en": "Success",
|
|
261
|
+
"zh": "成功",
|
|
262
|
+
"ja": "成功",
|
|
263
|
+
"ar": "نجح",
|
|
264
|
+
"ru": "Успех",
|
|
265
|
+
},
|
|
266
|
+
"index_file_filtered": {
|
|
267
|
+
"en": "File {{file_path}} is filtered by model {{model_name}} restrictions",
|
|
268
|
+
"zh": "文件 {{file_path}} 被模型 {{model_name}} 的访问限制过滤",
|
|
269
|
+
"ja": "ファイル {{file_path}} はモデル {{model_name}} の制限によってフィルタリングされています",
|
|
270
|
+
"ar": "تم تصفية الملف {{file_path}} بواسطة قيود النموذج {{model_name}}",
|
|
271
|
+
"ru": "Файл {{file_path}} отфильтрован ограничениями модели {{model_name}}",
|
|
272
|
+
},
|
|
273
|
+
"models_no_active": {
|
|
274
|
+
"en": "No active models found",
|
|
275
|
+
"zh": "未找到激活的模型",
|
|
276
|
+
"ja": "アクティブなモデルが見つかりません",
|
|
277
|
+
"ar": "لم يتم العثور على نماذج نشطة",
|
|
278
|
+
"ru": "Активные модели не найдены",
|
|
279
|
+
},
|
|
280
|
+
"models_speed_test_results": {
|
|
281
|
+
"en": "Model Speed Test Results",
|
|
282
|
+
"zh": "模型速度测试结果",
|
|
283
|
+
"ja": "モデル速度テスト結果",
|
|
284
|
+
"ar": "نتائج اختبار سرعة النموذج",
|
|
285
|
+
"ru": "Результаты теста скорости модели",
|
|
286
|
+
},
|
|
287
|
+
"models_testing": {
|
|
288
|
+
"en": "Testing model: {{name}}...",
|
|
289
|
+
"zh": "正在测试模型: {{name}}...",
|
|
290
|
+
"ja": "モデルをテスト中: {{name}}...",
|
|
291
|
+
"ar": "اختبار النموذج: {{name}}...",
|
|
292
|
+
"ru": "Тестирование модели: {{name}}...",
|
|
293
|
+
},
|
|
294
|
+
"models_testing_start": {
|
|
295
|
+
"en": "Starting speed test for all active models...",
|
|
296
|
+
"zh": "开始对所有激活的模型进行速度测试...",
|
|
297
|
+
"ja": "すべてのアクティブモデルの速度テストを開始しています...",
|
|
298
|
+
"ar": "بدء اختبار السرعة لجميع النماذج النشطة...",
|
|
299
|
+
"ru": "Запуск теста скорости для всех активных моделей...",
|
|
300
|
+
},
|
|
301
|
+
"models_testing_progress": {
|
|
302
|
+
"en": "Testing progress: {{ completed }}/{{ total }} models",
|
|
303
|
+
"zh": "测试进度: {{ completed }}/{{ total }} 个模型",
|
|
304
|
+
"ja": "テスト進行状況: {{ completed }}/{{ total }} モデル",
|
|
305
|
+
"ar": "تقدم الاختبار: {{ completed }}/{{ total }} نموذج",
|
|
306
|
+
"ru": "Прогресс тестирования: {{ completed }}/{{ total }} моделей",
|
|
307
|
+
},
|
|
308
|
+
"generation_cancelled": {
|
|
309
|
+
"en": "[Interrupted] Generation cancelled",
|
|
310
|
+
"zh": "[已中断] 生成已取消",
|
|
311
|
+
"ja": "[中断] 生成がキャンセルされました",
|
|
312
|
+
"ar": "[مقاطع] تم إلغاء التوليد",
|
|
313
|
+
"ru": "[Прервано] Генерация отменена",
|
|
314
|
+
},
|
|
315
|
+
"model_not_found": {
|
|
316
|
+
"en": "Model {{model_name}} not found",
|
|
317
|
+
"zh": "未找到模型: {{model_name}}",
|
|
318
|
+
"ja": "モデル {{model_name}} が見つかりません",
|
|
319
|
+
"ar": "لم يتم العثور على النموذج {{model_name}}",
|
|
320
|
+
"ru": "Модель {{model_name}} не найдена",
|
|
321
|
+
},
|
|
322
|
+
"generating_shell_script": {
|
|
323
|
+
"en": "Generating Shell Script",
|
|
324
|
+
"zh": "正在生成 Shell 脚本",
|
|
325
|
+
"ja": "シェルスクリプトを生成中",
|
|
326
|
+
"ar": "توليد نص شل",
|
|
327
|
+
"ru": "Генерация Shell скрипта",
|
|
328
|
+
},
|
|
329
|
+
"new_session_started": {
|
|
330
|
+
"en": "New session started. Previous chat history has been archived.",
|
|
331
|
+
"zh": "新会话已开始。之前的聊天历史已存档。",
|
|
332
|
+
"ja": "新しいセッションが開始されました。以前のチャット履歴はアーカイブされました。",
|
|
333
|
+
"ar": "بدأت جلسة جديدة. تم أرشفة تاريخ المحادثة السابق.",
|
|
334
|
+
"ru": "Новая сессия началась. Предыдущая история чата была заархивирована.",
|
|
335
|
+
},
|
|
336
|
+
"memory_save_success": {
|
|
337
|
+
"en": "✅ Saved to your memory(path: {{path}})",
|
|
338
|
+
"zh": "✅ 已保存到您的记忆中(路径: {{path}})",
|
|
339
|
+
"ja": "✅ メモリに保存されました(パス: {{path}})",
|
|
340
|
+
"ar": "✅ تم الحفظ في ذاكرتك (المسار: {{path}})",
|
|
341
|
+
"ru": "✅ Сохранено в вашей памяти (путь: {{path}})",
|
|
342
|
+
},
|
|
343
|
+
"file_decode_error": {
|
|
344
|
+
"en": "Failed to decode file: {{file_path}}. Tried encodings: {{encodings}}",
|
|
345
|
+
"zh": "无法解码文件: {{file_path}}。尝试的编码: {{encodings}}",
|
|
346
|
+
"ja": "ファイルのデコードに失敗しました: {{file_path}}。試行したエンコーディング: {{encodings}}",
|
|
347
|
+
"ar": "فشل في فك تشفير الملف: {{file_path}}. الترميزات المجربة: {{encodings}}",
|
|
348
|
+
"ru": "Не удалось декодировать файл: {{file_path}}. Испробованные кодировки: {{encodings}}",
|
|
349
|
+
},
|
|
350
|
+
"file_write_error": {
|
|
351
|
+
"en": "Failed to write file: {{file_path}}. Error: {{error}}",
|
|
352
|
+
"zh": "无法写入文件: {{file_path}}. 错误: {{error}}",
|
|
353
|
+
"ja": "ファイルの書き込みに失敗しました: {{file_path}}. エラー: {{error}}",
|
|
354
|
+
"ar": "فشل في كتابة الملف: {{file_path}}. خطأ: {{error}}",
|
|
355
|
+
"ru": "Не удалось записать файл: {{file_path}}. Ошибка: {{error}}",
|
|
356
|
+
},
|
|
357
|
+
"yaml_load_error": {
|
|
358
|
+
"en": "Error loading yaml file {{yaml_file}}: {{error}}",
|
|
359
|
+
"zh": "加载YAML文件出错 {{yaml_file}}: {{error}}",
|
|
360
|
+
"ja": "YAMLファイルの読み込みエラー {{yaml_file}}: {{error}}",
|
|
361
|
+
"ar": "خطأ في تحميل ملف yaml {{yaml_file}}: {{error}}",
|
|
362
|
+
"ru": "Ошибка загрузки YAML файла {{yaml_file}}: {{error}}",
|
|
363
|
+
},
|
|
364
|
+
"git_command_error": {
|
|
365
|
+
"en": "Git command execution error: {{error}}",
|
|
366
|
+
"zh": "Git命令执行错误: {{error}}",
|
|
367
|
+
"ja": "Gitコマンド実行エラー: {{error}}",
|
|
368
|
+
"ar": "خطأ في تنفيذ أمر Git: {{error}}",
|
|
369
|
+
"ru": "Ошибка выполнения Git команды: {{error}}",
|
|
370
|
+
},
|
|
371
|
+
"get_commit_diff_error": {
|
|
372
|
+
"en": "Error getting commit diff: {{error}}",
|
|
373
|
+
"zh": "获取commit diff时出错: {{error}}",
|
|
374
|
+
"ja": "コミット差分の取得エラー: {{error}}",
|
|
375
|
+
"ar": "خطأ في الحصول على فرق الكوميت: {{error}}",
|
|
376
|
+
"ru": "Ошибка получения разности коммитов: {{error}}",
|
|
377
|
+
},
|
|
378
|
+
"no_latest_commit": {
|
|
379
|
+
"en": "Unable to get latest commit information",
|
|
380
|
+
"zh": "无法获取最新的提交信息",
|
|
381
|
+
"ja": "最新のコミット情報を取得できません",
|
|
382
|
+
"ar": "غير قادر على الحصول على معلومات أحدث كوميت",
|
|
383
|
+
"ru": "Невозможно получить информацию о последнем коммите",
|
|
384
|
+
},
|
|
385
|
+
"code_review_error": {
|
|
386
|
+
"en": "Code review process error: {{error}}",
|
|
387
|
+
"zh": "代码审查过程出错: {{error}}",
|
|
388
|
+
"ja": "コードレビュープロセスエラー: {{error}}",
|
|
389
|
+
"ar": "خطأ في عملية مراجعة الكود: {{error}}",
|
|
390
|
+
"ru": "Ошибка процесса ревью кода: {{error}}",
|
|
391
|
+
},
|
|
392
|
+
"index_file_too_large": {
|
|
393
|
+
"en": "⚠️ File {{ file_path }} is too large ({{ file_size }} > {{ max_length }}), splitting into chunks...",
|
|
394
|
+
"zh": "⚠️ 文件 {{ file_path }} 过大 ({{ file_size }} > {{ max_length }}), 正在分块处理...",
|
|
395
|
+
"ja": "⚠️ ファイル {{ file_path }} が大きすぎます ({{ file_size }} > {{ max_length }})、チャンクに分割中...",
|
|
396
|
+
"ar": "⚠️ الملف {{ file_path }} كبير جداً ({{ file_size }} > {{ max_length }})، جاري التقسيم إلى أجزاء...",
|
|
397
|
+
"ru": "⚠️ Файл {{ file_path }} слишком большой ({{ file_size }} > {{ max_length }}), разделение на части...",
|
|
398
|
+
},
|
|
399
|
+
"index_update_success": {
|
|
400
|
+
"en": "✅ {{ model_name }} Successfully updated index for {{ file_path }} (md5: {{ md5 }}) in {{ duration }}s, input_tokens: {{ input_tokens }}, output_tokens: {{ output_tokens }}, input_cost: {{ input_cost }}, output_cost: {{ output_cost }}",
|
|
401
|
+
"zh": "✅ {{ model_name }} 成功更新 {{ file_path }} 的索引 (md5: {{ md5 }}), 耗时 {{ duration }} 秒, 输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }}",
|
|
402
|
+
"ja": "✅ {{ model_name }} {{ file_path }} のインデックスを正常に更新しました (md5: {{ md5 }}) {{ duration }}秒で完了, 入力トークン数: {{ input_tokens }}, 出力トークン数: {{ output_tokens }}, 入力コスト: {{ input_cost }}, 出力コスト: {{ output_cost }}",
|
|
403
|
+
"ar": "✅ {{ model_name }} تم تحديث فهرس {{ file_path }} بنجاح (md5: {{ md5 }}) في {{ duration }} ثانية, رموز الإدخال: {{ input_tokens }}, رموز الإخراج: {{ output_tokens }}, تكلفة الإدخال: {{ input_cost }}, تكلفة الإخراج: {{ output_cost }}",
|
|
404
|
+
"ru": "✅ {{ model_name }} Успешно обновлен индекс для {{ file_path }} (md5: {{ md5 }}) за {{ duration }}с, входные токены: {{ input_tokens }}, выходные токены: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }}",
|
|
405
|
+
},
|
|
406
|
+
"index_build_error": {
|
|
407
|
+
"en": "❌ {{ model_name }} Error building index for {{ file_path }}: {{ error }}",
|
|
408
|
+
"zh": "❌ {{ model_name }} 构建 {{ file_path }} 索引时出错: {{ error }}",
|
|
409
|
+
"ja": "❌ {{ model_name }} {{ file_path }} のインデックス構築エラー: {{ error }}",
|
|
410
|
+
"ar": "❌ {{ model_name }} خطأ في بناء فهرس {{ file_path }}: {{ error }}",
|
|
411
|
+
"ru": "❌ {{ model_name }} Ошибка построения индекса для {{ file_path }}: {{ error }}",
|
|
412
|
+
},
|
|
413
|
+
"index_build_summary": {
|
|
414
|
+
"en": "📊 Total Files: {{ total_files }}, Need to Build Index: {{ num_files }}",
|
|
415
|
+
"zh": "📊 总文件数: {{ total_files }}, 需要构建索引: {{ num_files }}",
|
|
416
|
+
"ja": "📊 総ファイル数: {{ total_files }}, インデックス構築が必要: {{ num_files }}",
|
|
417
|
+
"ar": "📊 إجمالي الملفات: {{ total_files }}, يحتاج لبناء فهرس: {{ num_files }}",
|
|
418
|
+
"ru": "📊 Всего файлов: {{ total_files }}, Нужно построить индекс: {{ num_files }}",
|
|
419
|
+
},
|
|
420
|
+
"building_index_progress": {
|
|
421
|
+
"en": "⏳ Building Index: {{ counter }}/{{ num_files }}...",
|
|
422
|
+
"zh": "⏳ 正在构建索引: {{ counter }}/{{ num_files }}...",
|
|
423
|
+
"ja": "⏳ インデックス構築中: {{ counter }}/{{ num_files }}...",
|
|
424
|
+
"ar": "⏳ بناء الفهرس: {{ counter }}/{{ num_files }}...",
|
|
425
|
+
"ru": "⏳ Построение индекса: {{ counter }}/{{ num_files }}...",
|
|
426
|
+
},
|
|
427
|
+
"index_source_dir_mismatch": {
|
|
428
|
+
"en": "⚠️ Source directory mismatch (file_path: {{ file_path }}, source_dir: {{ source_dir }})",
|
|
429
|
+
"zh": "⚠️ 源目录不匹配 (文件路径: {{ file_path }}, 源目录: {{ source_dir }})",
|
|
430
|
+
"ja": "⚠️ ソースディレクトリの不一致 (ファイルパス: {{ file_path }}, ソースディレクトリ: {{ source_dir }})",
|
|
431
|
+
"ar": "⚠️ عدم تطابق مجلد المصدر (مسار الملف: {{ file_path }}, مجلد المصدر: {{ source_dir }})",
|
|
432
|
+
"ru": "⚠️ Несоответствие исходной директории (путь файла: {{ file_path }}, исходная директория: {{ source_dir }})",
|
|
433
|
+
},
|
|
434
|
+
"index_related_files_fail": {
|
|
435
|
+
"en": "⚠️ Failed to find related files for chunk {{ chunk_count }}",
|
|
436
|
+
"zh": "⚠️ 无法为块 {{ chunk_count }} 找到相关文件",
|
|
437
|
+
"ja": "⚠️ チャンク {{ chunk_count }} の関連ファイルの検索に失敗しました",
|
|
438
|
+
"ar": "⚠️ فشل في العثور على الملفات ذات الصلة للجزء {{ chunk_count }}",
|
|
439
|
+
"ru": "⚠️ Не удалось найти связанные файлы для части {{ chunk_count }}",
|
|
440
|
+
},
|
|
441
|
+
"index_threads_completed": {
|
|
442
|
+
"en": "✅ Completed {{ completed_threads }}/{{ total_threads }} threads",
|
|
443
|
+
"zh": "✅ 已完成 {{ completed_threads }}/{{ total_threads }} 个线程",
|
|
444
|
+
"ja": "✅ {{ completed_threads }}/{{ total_threads }} スレッドが完了しました",
|
|
445
|
+
"ar": "✅ تم إكمال {{ completed_threads }}/{{ total_threads }} خيوط",
|
|
446
|
+
"ru": "✅ Завершено {{ completed_threads }}/{{ total_threads }} потоков",
|
|
447
|
+
},
|
|
448
|
+
"index_file_removed": {
|
|
449
|
+
"en": "🗑️ Removed non-existent file index: {{ file_path }}",
|
|
450
|
+
"zh": "🗑️ 已移除不存在的文件索引:{{ file_path }}",
|
|
451
|
+
"ja": "🗑️ 存在しないファイルのインデックスを削除しました:{{ file_path }}",
|
|
452
|
+
"ar": "🗑️ تم إزالة فهرس الملف غير الموجود: {{ file_path }}",
|
|
453
|
+
"ru": "🗑️ Удален индекс несуществующего файла: {{ file_path }}",
|
|
454
|
+
},
|
|
455
|
+
"index_file_saved": {
|
|
456
|
+
"en": "💾 Saved index file, updated {{ updated_files }} files, removed {{ removed_files }} files, input_tokens: {{ input_tokens }}, output_tokens: {{ output_tokens }}, input_cost: {{ input_cost }}, output_cost: {{ output_cost }}",
|
|
457
|
+
"zh": "💾 已保存索引文件,更新了 {{ updated_files }} 个文件,移除了 {{ removed_files }} 个文件,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }}",
|
|
458
|
+
"ja": "💾 インデックスファイルを保存しました、{{ updated_files }} ファイルを更新、{{ removed_files }} ファイルを削除、入力トークン数: {{ input_tokens }}, 出力トークン数: {{ output_tokens }}, 入力コスト: {{ input_cost }}, 出力コスト: {{ output_cost }}",
|
|
459
|
+
"ar": "💾 تم حفظ ملف الفهرس، تم تحديث {{ updated_files }} ملف، تم إزالة {{ removed_files }} ملف، رموز الإدخال: {{ input_tokens }}, رموز الإخراج: {{ output_tokens }}, تكلفة الإدخال: {{ input_cost }}, تكلفة الإخراج: {{ output_cost }}",
|
|
460
|
+
"ru": "💾 Индексный файл сохранен, обновлено {{ updated_files }} файлов, удалено {{ removed_files }} файлов, входные токены: {{ input_tokens }}, выходные токены: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }}",
|
|
461
|
+
},
|
|
462
|
+
"manual_file_saved": {
|
|
463
|
+
"en": "📄 Manual file saved: {{ file_path }}",
|
|
464
|
+
"zh": "📄 手册文件已保存: {{ file_path }}",
|
|
465
|
+
"ja": "📄 マニュアルファイルが保存されました: {{ file_path }}",
|
|
466
|
+
"ar": "📄 تم حفظ ملف الدليل: {{ file_path }}",
|
|
467
|
+
"ru": "📄 Файл руководства сохранен: {{ file_path }}",
|
|
468
|
+
},
|
|
469
|
+
"conversations_saved": {
|
|
470
|
+
"en": "💬 Conversations saved to {{ directory }} directory",
|
|
471
|
+
"zh": "💬 对话内容已保存到 {{ directory }} 目录",
|
|
472
|
+
"ja": "💬 会話が {{ directory }} ディレクトリに保存されました",
|
|
473
|
+
"ar": "💬 تم حفظ المحادثات في دليل {{ directory }}",
|
|
474
|
+
"ru": "💬 Разговоры сохранены в директории {{ directory }}",
|
|
475
|
+
},
|
|
476
|
+
"conversations_save_failed": {
|
|
477
|
+
"en": "❌ Failed to save conversations: {{ error }}",
|
|
478
|
+
"zh": "❌ 保存对话内容失败: {{ error }}",
|
|
479
|
+
"ja": "❌ 会話の保存に失敗しました: {{ error }}",
|
|
480
|
+
"ar": "❌ فشل في حفظ المحادثات: {{ error }}",
|
|
481
|
+
"ru": "❌ Не удалось сохранить разговоры: {{ error }}",
|
|
482
|
+
},
|
|
483
|
+
"task_cancelled_by_user": {
|
|
484
|
+
"en": "Task was cancelled by user",
|
|
485
|
+
"zh": "任务被用户取消",
|
|
486
|
+
"ja": "タスクがユーザーによってキャンセルされました",
|
|
487
|
+
"ar": "تم إلغاء المهمة من قبل المستخدم",
|
|
488
|
+
"ru": "Задача была отменена пользователем",
|
|
489
|
+
},
|
|
490
|
+
"cancellation_requested": {
|
|
491
|
+
"en": "Cancellation requested, waiting for thread to terminate...",
|
|
492
|
+
"zh": "已请求取消,正在等待线程终止...",
|
|
493
|
+
"ja": "キャンセルが要求されました、スレッドの終了を待機中...",
|
|
494
|
+
"ar": "تم طلب الإلغاء، في انتظار إنهاء الخيط...",
|
|
495
|
+
"ru": "Запрошена отмена, ожидание завершения потока...",
|
|
496
|
+
},
|
|
497
|
+
"force_terminating_thread": {
|
|
498
|
+
"en": "Force terminating thread after timeout",
|
|
499
|
+
"zh": "线程超时强制终止",
|
|
500
|
+
"ja": "タイムアウト後にスレッドを強制終了",
|
|
501
|
+
"ar": "إنهاء الخيط بالقوة بعد انتهاء المهلة",
|
|
502
|
+
"ru": "Принудительное завершение потока после таймаута",
|
|
503
|
+
},
|
|
504
|
+
"force_raising_keyboard_interrupt": {
|
|
505
|
+
"en": "Force raising KeyboardInterrupt after timeout",
|
|
506
|
+
"zh": "超时强制抛出键盘中断异常",
|
|
507
|
+
"ja": "タイムアウト後にKeyboardInterruptを強制発生",
|
|
508
|
+
"ar": "فرض رفع KeyboardInterrupt بعد انتهاء المهلة",
|
|
509
|
+
"ru": "Принудительное вызов KeyboardInterrupt после таймаута",
|
|
510
|
+
},
|
|
511
|
+
"thread_terminated": {
|
|
512
|
+
"en": "Thread terminated",
|
|
513
|
+
"zh": "线程已终止",
|
|
514
|
+
"ja": "スレッドが終了しました",
|
|
515
|
+
"ar": "تم إنهاء الخيط",
|
|
516
|
+
"ru": "Поток завершен",
|
|
517
|
+
},
|
|
518
|
+
"human_as_model_instructions": {
|
|
519
|
+
"en": "You are now in Human as Model mode. The content has been copied to your clipboard.\nThe system is waiting for your input. When finished, enter 'EOF' on a new line to submit.\nUse '/break' to exit this mode. If you have issues with copy-paste, use '/clear' to clean and paste again.",
|
|
520
|
+
"zh": "您现在处于人类作为模型模式。内容已复制到您的剪贴板。\n系统正在等待您的输入。完成后,在新行输入'EOF'提交。\n使用'/break'退出此模式。如果复制粘贴有问题,使用'/clear'清理并重新粘贴。",
|
|
521
|
+
"ja": "人間モデルモードになりました。内容はクリップボードにコピーされました。\nシステムはあなたの入力を待っています。完了したら、新しい行に'EOF'を入力して送信してください。\nこのモードを終了するには'/break'を使用してください。コピー&ペーストに問題がある場合は、'/clear'を使用してクリアしてから再度ペーストしてください。",
|
|
522
|
+
"ar": "أنت الآن في وضع الإنسان كنموذج. تم نسخ المحتوى إلى الحافظة الخاصة بك.\nالنظام ينتظر إدخالك. عند الانتهاء، أدخل 'EOF' في سطر جديد للإرسال.\nاستخدم '/break' للخروج من هذا الوضع. إذا كانت لديك مشاكل مع النسخ واللصق، استخدم '/clear' للتنظيف واللصق مرة أخرى.",
|
|
523
|
+
"ru": "Вы находитесь в режиме \"Человек как модель\". Содержимое скопировано в ваш буфер обмена.\nСистема ожидает ваш ввод. После завершения введите 'EOF' на новой строке для отправки.\nИспользуйте '/break' для выхода из этого режима. Если у вас проблемы с копированием и вставкой, используйте '/clear' для очистки и повторной вставки.",
|
|
524
|
+
},
|
|
525
|
+
"clipboard_not_supported": {
|
|
526
|
+
"en": "pyperclip not installed or clipboard is not supported, instruction will not be copied to clipboard.",
|
|
527
|
+
"zh": "未安装pyperclip或不支持剪贴板,指令将不会被复制到剪贴板。",
|
|
528
|
+
"ja": "pyperclipがインストールされていないか、クリップボードがサポートされていません。指示はクリップボードにコピーされません。",
|
|
529
|
+
"ar": "pyperclip غير مثبت أو الحافظة غير مدعومة، لن يتم نسخ التعليمات إلى الحافظة.",
|
|
530
|
+
"ru": "pyperclip не установлен или буфер обмена не поддерживается, инструкция не будет скопирована в буфер обмена.",
|
|
531
|
+
},
|
|
532
|
+
"human_as_model_instructions_no_clipboard": {
|
|
533
|
+
"en": "You are now in Human as Model mode. [bold red]The content could not be copied to your clipboard.[/bold red]\nbut you can copy prompt from output.txt file.\nThe system is waiting for your input. When finished, enter 'EOF' on a new line to submit.\nUse '/break' to exit this mode. If you have issues with copy-paste, use '/clear' to clean and paste again.",
|
|
534
|
+
"zh": "您现在处于人类作为模型模式。[bold red]内容无法复制到您的剪贴板。[/bold red]\n但您可以从output.txt文件复制提示。\n系统正在等待您的输入。完成后,在新行输入'EOF'提交。\n使用'/break'退出此模式。如果复制粘贴有问题,使用'/clear'清理并重新粘贴。",
|
|
535
|
+
"ja": "人間モデルモードになりました。[bold red]内容をクリップボードにコピーできませんでした。[/bold red]\nただし、output.txtファイルからプロンプトをコピーできます。\nシステムはあなたの入力を待っています。完了したら、新しい行に'EOF'を入力して送信してください。\nこのモードを終了するには'/break'を使用してください。コピー&ペーストに問題がある場合は、'/clear'を使用してクリアしてから再度ペーストしてください。",
|
|
536
|
+
"ar": "أنت الآن في وضع الإنسان كنموذج. [bold red]لا يمكن نسخ المحتوى إلى الحافظة الخاصة بك.[/bold red]\nولكن يمكنك نسخ المطالبة من ملف output.txt.\nالنظام ينتظر إدخالك. عند الانتهاء، أدخل 'EOF' في سطر جديد للإرسال.\nاستخدم '/break' للخروج من هذا الوضع. إذا كانت لديك مشاكل مع النسخ واللصق، استخدم '/clear' للتنظيف واللصق مرة أخرى.",
|
|
537
|
+
"ru": "Вы находитесь в режиме \"Человек как модель\". [bold red]Содержимое не может быть скопировано в ваш буфер обмена.[/bold red]\nно вы можете скопировать запрос из файла output.txt.\nСистема ожидает ваш ввод. После завершения введите 'EOF' на новой строке для отправки.\nИспользуйте '/break' для выхода из этого режима. Если у вас проблемы с копированием и вставкой, используйте '/clear' для очистки и повторной вставки.",
|
|
538
|
+
},
|
|
539
|
+
"phase1_processing_sources": {
|
|
540
|
+
"en": "Phase 1: Processing REST/RAG/Search sources...",
|
|
541
|
+
"zh": "阶段 1: 正在处理 REST/RAG/Search 源...",
|
|
542
|
+
"ja": "フェーズ 1: REST/RAG/Search ソースを処理中...",
|
|
543
|
+
"ar": "المرحلة 1: معالجة مصادر REST/RAG/Search...",
|
|
544
|
+
"ru": "Фаза 1: Обработка источников REST/RAG/Search...",
|
|
545
|
+
},
|
|
546
|
+
"phase2_building_index": {
|
|
547
|
+
"en": "Phase 2: Building index for all files...",
|
|
548
|
+
"zh": "阶段 2: 正在为所有文件构建索引...",
|
|
549
|
+
"ja": "フェーズ 2: すべてのファイルのインデックスを構築中...",
|
|
550
|
+
"ar": "المرحلة 2: بناء فهرس لجميع الملفات...",
|
|
551
|
+
"ru": "Фаза 2: Построение индекса для всех файлов...",
|
|
552
|
+
},
|
|
553
|
+
"phase6_file_selection": {
|
|
554
|
+
"en": "Phase 6: Processing file selection and limits...",
|
|
555
|
+
"zh": "阶段 6: 正在处理文件选择和限制...",
|
|
556
|
+
"ja": "フェーズ 6: ファイル選択と制限を処理中...",
|
|
557
|
+
"ar": "المرحلة 6: معالجة اختيار الملفات والحدود...",
|
|
558
|
+
"ru": "Фаза 6: Обработка выбора файлов и ограничений...",
|
|
559
|
+
},
|
|
560
|
+
"phase7_preparing_output": {
|
|
561
|
+
"en": "Phase 7: Preparing final output...",
|
|
562
|
+
"zh": "阶段 7: 正在准备最终输出...",
|
|
563
|
+
"ja": "フェーズ 7: 最終出力を準備中...",
|
|
564
|
+
"ar": "المرحلة 7: إعداد الإخراج النهائي...",
|
|
565
|
+
"ru": "Фаза 7: Подготовка финального вывода...",
|
|
566
|
+
},
|
|
567
|
+
"chat_human_as_model_instructions": {
|
|
568
|
+
"en": "Chat is now in Human as Model mode.\nThe question has been copied to your clipboard.\nPlease use Web version model to get the answer.\nOr use /conf human_as_model:false to close this mode and get the answer in terminal directlyPaste the answer to the input box below, use '/break' to exit, '/clear' to clear the screen, '/eof' to submit.",
|
|
569
|
+
"zh": "\n============= Chat 处于 Human as Model 模式 =============\n问题已复制到剪贴板\n请使用Web版本模型获取答案\n或者使用 /conf human_as_model:false 关闭该模式直接在终端获得答案。将获得答案黏贴到下面的输入框,换行后,使用 '/break' 退出,'/clear' 清屏,'/eof' 提交。",
|
|
570
|
+
"ja": "チャットは人間モデルモードになりました。\n質問はクリップボードにコピーされました。\nWeb版モデルを使用して回答を取得してください。\nまたは /conf human_as_model:false を使用してこのモードを閉じ、ターミナルで直接回答を取得してください。下の入力ボックスに回答をペーストし、'/break'で終了、'/clear'で画面クリア、'/eof'で送信してください。",
|
|
571
|
+
"ar": "المحادثة الآن في وضع الإنسان كنموذج.\nتم نسخ السؤال إلى الحافظة الخاصة بك.\nيرجى استخدام النموذج الإصدار الويب للحصول على الإجابة.\nأو استخدم /conf human_as_model:false لإغلاق هذا الوضع والحصول على الإجابة في المحطة مباشرة. الصق الإجابة في مربع الإدخال أدناه، استخدم '/break' للخروج، '/clear' لمسح الشاشة، '/eof' للإرسال.",
|
|
572
|
+
"ru": "Чат находится в режиме \"Человек как модель\".\nВопрос скопирован в ваш буфер обмена.\nПожалуйста, используйте веб-версию модели для получения ответа.\nИли используйте /conf human_as_model:false для закрытия этого режима и получения ответа прямо в терминале. Вставьте ответ в поле ввода ниже, используйте '/break' для выхода, '/clear' для очистки экрана, '/eof' для отправки.",
|
|
573
|
+
},
|
|
574
|
+
"code_generation_start": {
|
|
575
|
+
"en": "Auto generate the code...",
|
|
576
|
+
"zh": "正在自动生成代码...",
|
|
577
|
+
"ja": "コードを自動生成中...",
|
|
578
|
+
"ar": "توليد الكود تلقائياً...",
|
|
579
|
+
"ru": "Автоматическая генерация кода...",
|
|
580
|
+
},
|
|
581
|
+
"code_generation_complete": {
|
|
582
|
+
"en": "{{ model_names}} Code generation completed in {{ duration }} seconds (sampling_count: {{ sampling_count }}), input_tokens_count: {{ input_tokens }}, generated_tokens_count: {{ output_tokens }}, input_cost: {{ input_cost }}, output_cost: {{ output_cost }}, speed: {{ speed }} tokens/s",
|
|
583
|
+
"zh": "{{ model_names}} 代码生成完成,耗时 {{ duration }} 秒 (采样数: {{ sampling_count }}), 输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }}, 速度: {{ speed }} tokens/秒",
|
|
584
|
+
"ja": "{{ model_names}} コード生成が完了しました {{ duration }} 秒 (サンプリング数: {{ sampling_count }})、入力トークン数: {{ input_tokens }}、出力トークン数: {{ output_tokens }}、入力コスト: {{ input_cost }}、出力コスト: {{ output_cost }}、速度: {{ speed }} tokens/秒",
|
|
585
|
+
"ar": "{{ model_names}} اكتمل توليد الكود في {{ duration }} ثانية (عدد العينات: {{ sampling_count }})، عدد رموز الإدخال: {{ input_tokens }}، عدد رموز الإخراج: {{ output_tokens }}، تكلفة الإدخال: {{ input_cost }}، تكلفة الإخراج: {{ output_cost }}، السرعة: {{ speed }} رمز/ثانية",
|
|
586
|
+
"ru": "{{ model_names}} Генерация кода завершена за {{ duration }} секунд (количество выборок: {{ sampling_count }}), входных токенов: {{ input_tokens }}, выходных токенов: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }}, скорость: {{ speed }} токенов/с",
|
|
587
|
+
},
|
|
588
|
+
"generate_max_rounds_reached": {
|
|
589
|
+
"en": "⚠️ Generation stopped after reaching the maximum allowed rounds ({{ count }}/{{ max_rounds }}). Current generated content length: {{ generated_tokens }}. If the output is incomplete, consider increasing 'generate_max_rounds' in configuration.",
|
|
590
|
+
"zh": "⚠️ 生成已停止,因为达到了最大允许轮数 ({{ count }}/{{ max_rounds }})。当前生成内容长度: {{ generated_tokens }} tokens。如果输出不完整,请考虑在配置中增加 'generate_max_rounds'。",
|
|
591
|
+
"ja": "⚠️ 最大許可ラウンド数に達したため生成が停止しました ({{ count }}/{{ max_rounds }})。現在の生成コンテンツ長: {{ generated_tokens }} トークン。出力が不完全な場合は、設定で 'generate_max_rounds' を増やすことを検討してください。",
|
|
592
|
+
"ar": "⚠️ توقف التوليد بعد الوصول إلى أقصى عدد جولات مسموح ({{ count }}/{{ max_rounds }})। طول المحتوى المولد الحالي: {{ generated_tokens }} رمز。إذا كان الإخراج غير مكتمل، فكر في زيادة 'generate_max_rounds' في التكوين.",
|
|
593
|
+
"ru": "⚠️ Генерация остановлена после достижения максимального количества раундов ({{ count }}/{{ max_rounds }}). Текущая длина сгенерированного контента: {{ generated_tokens }} токенов. Если вывод неполный, рассмотрите увеличение 'generate_max_rounds' в конфигурации.",
|
|
594
|
+
},
|
|
595
|
+
"code_merge_start": {
|
|
596
|
+
"en": "Auto merge the code...",
|
|
597
|
+
"zh": "正在自动合并代码...",
|
|
598
|
+
"ja": "コードを自動マージ中...",
|
|
599
|
+
"ar": "دمج الكود تلقائياً...",
|
|
600
|
+
"ru": "Автоматическое слияние кода...",
|
|
601
|
+
},
|
|
602
|
+
"code_execution_warning": {
|
|
603
|
+
"en": "Content(send to model) is {{ content_length }} tokens (you may collect too much files), which is larger than the maximum input length {{ max_length }}",
|
|
604
|
+
"zh": "发送给模型的内容长度为 {{ content_length }} tokens(您可能收集了太多文件),超过了最大输入长度 {{ max_length }}",
|
|
605
|
+
"ja": "モデルに送信されるコンテンツは {{ content_length }} トークンです(ファイルを集めすぎている可能性があります)、最大入力長 {{ max_length }} を超えています",
|
|
606
|
+
"ar": "المحتوى (المرسل إلى النموذج) هو {{ content_length }} رمز (قد تكون جمعت ملفات كثيرة جداً)، وهو أكبر من الطول الأقصى للإدخال {{ max_length }}",
|
|
607
|
+
"ru": "Содержимое (отправляемое в модель) составляет {{ content_length }} токенов (возможно, вы собрали слишком много файлов), что больше максимальной длины ввода {{ max_length }}",
|
|
608
|
+
},
|
|
609
|
+
"quick_filter_start": {
|
|
610
|
+
"en": "{{ model_name }} Starting filter context(quick_filter)...",
|
|
611
|
+
"zh": "{{ model_name }} 开始查找上下文(quick_filter)...",
|
|
612
|
+
"ja": "{{ model_name }} コンテキストのフィルタリングを開始(quick_filter)...",
|
|
613
|
+
"ar": "{{ model_name }} بدء تصفية السياق(quick_filter)...",
|
|
614
|
+
"ru": "{{ model_name }} Начинаем фильтрацию контекста(quick_filter)...",
|
|
615
|
+
},
|
|
616
|
+
"normal_filter_start": {
|
|
617
|
+
"en": "{{ model_name }} Starting filter context(normal_filter)...",
|
|
618
|
+
"zh": "{{ model_name }} 开始查找上下文(normal_filter)...",
|
|
619
|
+
"ja": "{{ model_name }} コンテキストのフィルタリングを開始(normal_filter)...",
|
|
620
|
+
"ar": "{{ model_name }} بدء تصفية السياق(normal_filter)...",
|
|
621
|
+
"ru": "{{ model_name }} Начинаем фильтрацию контекста(normal_filter)...",
|
|
622
|
+
},
|
|
623
|
+
"pylint_check_failed": {
|
|
624
|
+
"en": "⚠️ Pylint check failed: {{ error_message }}",
|
|
625
|
+
"zh": "⚠️ Pylint 检查失败: {{ error_message }}",
|
|
626
|
+
"ja": "⚠️ Pylint チェックが失敗しました: {{ error_message }}",
|
|
627
|
+
"ar": "⚠️ فشل فحص Pylint: {{ error_message }}",
|
|
628
|
+
"ru": "⚠️ Проверка Pylint не удалась: {{ error_message }}",
|
|
629
|
+
},
|
|
630
|
+
"pylint_error": {
|
|
631
|
+
"en": "❌ Error running pylint: {{ error_message }}",
|
|
632
|
+
"zh": "❌ 运行 Pylint 时出错: {{ error_message }}",
|
|
633
|
+
"ja": "❌ Pylint の実行エラー: {{ error_message }}",
|
|
634
|
+
"ar": "❌ خطأ في تشغيل pylint: {{ error_message }}",
|
|
635
|
+
"ru": "❌ Ошибка запуска pylint: {{ error_message }}",
|
|
636
|
+
},
|
|
637
|
+
"unmerged_blocks_warning": {
|
|
638
|
+
"en": "⚠️ Found {{ num_blocks }} unmerged blocks, the changes will not be applied. Please review them manually then try again.",
|
|
639
|
+
"zh": "⚠️ 发现 {{ num_blocks }} 个未合并的代码块,更改将不会被应用。请手动检查后重试。",
|
|
640
|
+
"ja": "⚠️ {{ num_blocks }} 個のマージされていないブロックが見つかりました、変更は適用されません。手動で確認してから再試行してください。",
|
|
641
|
+
"ar": "⚠️ تم العثور على {{ num_blocks }} كتل غير مدموجة، لن يتم تطبيق التغييرات. يرجى مراجعتها يدوياً ثم المحاولة مرة أخرى.",
|
|
642
|
+
"ru": "⚠️ Найдено {{ num_blocks }} неслитых блоков, изменения не будут применены. Пожалуйста, проверьте их вручную и попробуйте снова.",
|
|
643
|
+
},
|
|
644
|
+
"pylint_file_check_failed": {
|
|
645
|
+
"en": "⚠️ Pylint check failed for {{ file_path }}. Changes not applied. Error: {{ error_message }}",
|
|
646
|
+
"zh": "⚠️ {{ file_path }} 的 Pylint 检查失败。更改未应用。错误: {{ error_message }}",
|
|
647
|
+
"ja": "⚠️ {{ file_path }} の Pylint チェックが失敗しました。変更は適用されませんでした。エラー: {{ error_message }}",
|
|
648
|
+
"ar": "⚠️ فشل فحص Pylint لـ {{ file_path }}. لم يتم تطبيق التغييرات. خطأ: {{ error_message }}",
|
|
649
|
+
"ru": "⚠️ Проверка Pylint не удалась для {{ file_path }}. Изменения не применены. Ошибка: {{ error_message }}",
|
|
650
|
+
},
|
|
651
|
+
"merge_success": {
|
|
652
|
+
"en": "✅ Merged changes in {{ num_files }} files {{ num_changes }}/{{ total_blocks }} blocks.",
|
|
653
|
+
"zh": "✅ 成功合并了 {{ num_files }} 个文件中的更改 {{ num_changes }}/{{ total_blocks }} 个代码块。",
|
|
654
|
+
"ja": "✅ {{ num_files }} ファイルの変更をマージしました {{ num_changes }}/{{ total_blocks }} ブロック。",
|
|
655
|
+
"ar": "✅ تم دمج التغييرات في {{ num_files }} ملف {{ num_changes }}/{{ total_blocks }} كتلة.",
|
|
656
|
+
"ru": "✅ Слияние изменений в {{ num_files }} файлах {{ num_changes }}/{{ total_blocks }} блоков.",
|
|
657
|
+
},
|
|
658
|
+
"no_changes_made": {
|
|
659
|
+
"en": "⚠️ No changes were made to any files.",
|
|
660
|
+
"zh": "⚠️ 未对任何文件进行更改。这个原因可能是因为coding函数生成的文本块格式有问题,导致无法合并进项目",
|
|
661
|
+
"ja": "⚠️ どのファイルも変更されませんでした。",
|
|
662
|
+
"ar": "⚠️ لم يتم إجراء أي تغييرات على أي ملفات.",
|
|
663
|
+
"ru": "⚠️ Никаких изменений в файлах не было внесено.",
|
|
664
|
+
},
|
|
665
|
+
"files_merged": {
|
|
666
|
+
"en": "✅ Merged {{ total }} files into the project.",
|
|
667
|
+
"zh": "✅ 成功合并了 {{ total }} 个文件到项目中。",
|
|
668
|
+
"ja": "✅ {{ total }} ファイルをプロジェクトにマージしました。",
|
|
669
|
+
"ar": "✅ تم دمج {{ total }} ملف في المشروع.",
|
|
670
|
+
"ru": "✅ Слито {{ total }} файлов в проект.",
|
|
671
|
+
},
|
|
672
|
+
"merge_failed": {
|
|
673
|
+
"en": "❌ Merge file {{ path }} failed: {{ error }}",
|
|
674
|
+
"zh": "❌ 合并文件 {{ path }} 失败: {{ error }}",
|
|
675
|
+
"ja": "❌ ファイル {{ path }} のマージに失敗しました: {{ error }}",
|
|
676
|
+
"ar": "❌ فشل دمج الملف {{ path }}: {{ error }}",
|
|
677
|
+
"ru": "❌ Слияние файла {{ path }} не удалось: {{ error }}",
|
|
678
|
+
},
|
|
679
|
+
"files_merged_total": {
|
|
680
|
+
"en": "✅ Merged {{ total }} files into the project.",
|
|
681
|
+
"zh": "✅ 合并了 {{ total }} 个文件到项目中。",
|
|
682
|
+
"ja": "✅ {{ total }} ファイルをプロジェクトにマージしました。",
|
|
683
|
+
"ar": "✅ تم دمج {{ total }} ملف في المشروع.",
|
|
684
|
+
"ru": "✅ Слито {{ total }} файлов в проект.",
|
|
685
|
+
},
|
|
686
|
+
"ranking_skip": {
|
|
687
|
+
"en": "Only 1 candidate, skip ranking",
|
|
688
|
+
"zh": "只有1个候选项,跳过排序",
|
|
689
|
+
"ja": "候補が1つのみ、ランキングをスキップ",
|
|
690
|
+
"ar": "مرشح واحد فقط، تخطي الترتيب",
|
|
691
|
+
"ru": "Только 1 кандидат, пропускаем ранжирование",
|
|
692
|
+
},
|
|
693
|
+
"ranking_start": {
|
|
694
|
+
"en": "Start ranking {{ count }} candidates using model {{ model_name }}",
|
|
695
|
+
"zh": "开始对 {{ count }} 个候选项进行排序,使用模型 {{ model_name }} 打分",
|
|
696
|
+
"ja": "モデル {{ model_name }} を使用して {{ count }} 個の候補のランキングを開始",
|
|
697
|
+
"ar": "بدء ترتيب {{ count }} مرشحين باستخدام النموذج {{ model_name }}",
|
|
698
|
+
"ru": "Начинаем ранжирование {{ count }} кандидатов с использованием модели {{ model_name }}",
|
|
699
|
+
},
|
|
700
|
+
"ranking_failed_request": {
|
|
701
|
+
"en": "Ranking request failed: {{ error }}",
|
|
702
|
+
"zh": "排序请求失败: {{ error }}",
|
|
703
|
+
"ja": "ランキングリクエストが失敗しました: {{ error }}",
|
|
704
|
+
"ar": "فشل طلب الترتيب: {{ error }}",
|
|
705
|
+
"ru": "Запрос ранжирования не удался: {{ error }}",
|
|
706
|
+
},
|
|
707
|
+
"ranking_all_failed": {
|
|
708
|
+
"en": "All ranking requests failed",
|
|
709
|
+
"zh": "所有排序请求都失败",
|
|
710
|
+
"ja": "すべてのランキングリクエストが失敗しました",
|
|
711
|
+
"ar": "فشلت جميع طلبات الترتيب",
|
|
712
|
+
"ru": "Все запросы ранжирования не удались",
|
|
713
|
+
},
|
|
714
|
+
"ranking_complete": {
|
|
715
|
+
"en": "{{ model_names }} Ranking completed in {{ elapsed }}s, total voters: {{ total_tasks }}, best candidate index: {{ best_candidate }}, scores: {{ scores }}, input_tokens: {{ input_tokens }}, output_tokens: {{ output_tokens }}, input_cost: {{ input_cost }}, output_cost: {{ output_cost }}, speed: {{ speed }} tokens/s",
|
|
716
|
+
"zh": "{{ model_names }} 排序完成,耗时 {{ elapsed }} 秒,总投票数: {{ total_tasks }},最佳候选索引: {{ best_candidate }},得分: {{ scores }},输入token数: {{ input_tokens }},输出token数: {{ output_tokens }},输入成本: {{ input_cost }}, 输出成本: {{ output_cost }},速度: {{ speed }} tokens/秒",
|
|
717
|
+
"ja": "{{ model_names }} ランキング完了 {{ elapsed }}秒、総投票者数: {{ total_tasks }}、最適候補インデックス: {{ best_candidate }}、スコア: {{ scores }}、入力トークン数: {{ input_tokens }}、出力トークン数: {{ output_tokens }}、入力コスト: {{ input_cost }}, 出力コスト: {{ output_cost }}、速度: {{ speed }} tokens/秒",
|
|
718
|
+
"ar": "{{ model_names }} اكتمل الترتيب في {{ elapsed }} ثانية، إجمالي المصوتين: {{ total_tasks }}، أفضل فهرس مرشح: {{ best_candidate }}، النقاط: {{ scores }}، رموز الإدخال: {{ input_tokens }}، رموز الإخراج: {{ output_tokens }}، تكلفة الإدخال: {{ input_cost }}، تكلفة الإخراج: {{ output_cost }}، السرعة: {{ speed }} رمز/ثانية",
|
|
719
|
+
"ru": "{{ model_names }} Ранжирование завершено за {{ elapsed }}с, всего голосующих: {{ total_tasks }}, индекс лучшего кандидата: {{ best_candidate }}, баллы: {{ scores }}, входных токенов: {{ input_tokens }}, выходных токенов: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }}, скорость: {{ speed }} токенов/с",
|
|
720
|
+
},
|
|
721
|
+
"ranking_process_failed": {
|
|
722
|
+
"en": "Ranking process failed: {{ error }}",
|
|
723
|
+
"zh": "排序过程失败: {{ error }}",
|
|
724
|
+
"ja": "ランキングプロセスが失敗しました: {{ error }}",
|
|
725
|
+
"ar": "فشل عملية الترتيب: {{ error }}",
|
|
726
|
+
"ru": "Процесс ранжирования не удался: {{ error }}",
|
|
727
|
+
},
|
|
728
|
+
"ranking_failed": {
|
|
729
|
+
"en": "Ranking failed in {{ elapsed }}s, using original order",
|
|
730
|
+
"zh": "排序失败,耗时 {{ elapsed }} 秒,使用原始顺序",
|
|
731
|
+
"ja": "ランキングが {{ elapsed }}秒で失敗しました、元の順序を使用します",
|
|
732
|
+
"ar": "فشل الترتيب في {{ elapsed }} ثانية، استخدام الترتيب الأصلي",
|
|
733
|
+
"ru": "Ранжирование не удалось за {{ elapsed }}с, используем исходный порядок",
|
|
734
|
+
},
|
|
735
|
+
"begin_index_source_code": {
|
|
736
|
+
"en": "🚀 Begin to index source code in {{ source_dir }}",
|
|
737
|
+
"zh": "🚀 开始为 {{ source_dir }} 中的源代码建立索引",
|
|
738
|
+
"ja": "🚀 {{ source_dir }} のソースコードのインデックス作成を開始",
|
|
739
|
+
"ar": "🚀 بدء فهرسة الكود المصدري في {{ source_dir }}",
|
|
740
|
+
"ru": "🚀 Начинаем индексацию исходного кода в {{ source_dir }}",
|
|
741
|
+
},
|
|
742
|
+
"stream_out_stats": {
|
|
743
|
+
"en": "Model: {{ model_name }}, Total time: {{ elapsed_time }} seconds, First token time: {{ first_token_time }} seconds, Speed: {{ speed }} tokens/s, Input tokens: {{ input_tokens }}, Output tokens: {{ output_tokens }}, Input cost: {{ input_cost }}, Output cost: {{ output_cost }}",
|
|
744
|
+
"zh": "模型: {{ model_name }},总耗时 {{ elapsed_time }} 秒,首token时间: {{ first_token_time }} 秒, 速度: {{ speed }} tokens/秒, 输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }}",
|
|
745
|
+
"ja": "モデル: {{ model_name }}、総時間: {{ elapsed_time }} 秒、最初のトークン時間: {{ first_token_time }} 秒、速度: {{ speed }} tokens/秒、入力トークン数: {{ input_tokens }}、出力トークン数: {{ output_tokens }}、入力コスト: {{ input_cost }}、出力コスト: {{ output_cost }}",
|
|
746
|
+
"ar": "النموذج: {{ model_name }}، إجمالي الوقت: {{ elapsed_time }} ثانية، وقت أول رمز: {{ first_token_time }} ثانية، السرعة: {{ speed }} رمز/ثانية، رموز الإدخال: {{ input_tokens }}، رموز الإخراج: {{ output_tokens }}، تكلفة الإدخال: {{ input_cost }}، تكلفة الإخراج: {{ output_cost }}",
|
|
747
|
+
"ru": "Модель: {{ model_name }}, Общее время: {{ elapsed_time }} секунд, Время первого токена: {{ first_token_time }} секунд, Скорость: {{ speed }} токенов/с, Входных токенов: {{ input_tokens }}, Выходных токенов: {{ output_tokens }}, Стоимость входа: {{ input_cost }}, Стоимость выхода: {{ output_cost }}",
|
|
748
|
+
},
|
|
749
|
+
"quick_filter_stats": {
|
|
750
|
+
"en": "{{ model_names }} Quick filter completed in {{ elapsed_time }} seconds, input tokens: {{ input_tokens }}, output tokens: {{ output_tokens }}, input cost: {{ input_cost }}, output cost: {{ output_cost }} speed: {{ speed }} tokens/s",
|
|
751
|
+
"zh": "{{ model_names }} Quick Filter 完成耗时 {{ elapsed_time }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }} 速度: {{ speed }} tokens/秒",
|
|
752
|
+
"ja": "{{ model_names }} クイックフィルター完了 {{ elapsed_time }} 秒、入力トークン数: {{ input_tokens }}、出力トークン数: {{ output_tokens }}、入力コスト: {{ input_cost }}、出力コスト: {{ output_cost }} 速度: {{ speed }} tokens/秒",
|
|
753
|
+
"ar": "{{ model_names }} اكتمل التصفية السريعة في {{ elapsed_time }} ثانية، رموز الإدخال: {{ input_tokens }}، رموز الإخراج: {{ output_tokens }}، تكلفة الإدخال: {{ input_cost }}، تكلفة الإخراج: {{ output_cost }} السرعة: {{ speed }} رمز/ثانية",
|
|
754
|
+
"ru": "{{ model_names }} Быстрая фильтрация завершена за {{ elapsed_time }} секунд, входных токенов: {{ input_tokens }}, выходных токенов: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }} скорость: {{ speed }} токенов/с",
|
|
755
|
+
},
|
|
756
|
+
"upsert_file": {
|
|
757
|
+
"en": "✅ Updated file: {{ file_path }}",
|
|
758
|
+
"zh": "✅ 更新文件: {{ file_path }}",
|
|
759
|
+
"ja": "✅ ファイルを更新しました: {{ file_path }}",
|
|
760
|
+
"ar": "✅ تم تحديث الملف: {{ file_path }}",
|
|
761
|
+
"ru": "✅ Обновлен файл: {{ file_path }}",
|
|
762
|
+
},
|
|
763
|
+
"unmerged_blocks_title": {
|
|
764
|
+
"en": "Unmerged Blocks",
|
|
765
|
+
"zh": "未合并代码块",
|
|
766
|
+
"ja": "マージされていないブロック",
|
|
767
|
+
"ar": "الكتل غير المدموجة",
|
|
768
|
+
"ru": "Неслитые блоки",
|
|
769
|
+
},
|
|
770
|
+
"merged_blocks_title": {
|
|
771
|
+
"en": "Merged Changes",
|
|
772
|
+
"zh": "合并的更改",
|
|
773
|
+
"ja": "マージされた変更",
|
|
774
|
+
"ar": "التغييرات المدموجة",
|
|
775
|
+
"ru": "Слитые изменения",
|
|
776
|
+
},
|
|
777
|
+
"quick_filter_title": {
|
|
778
|
+
"en": "{{ model_name }} is analyzing how to filter context...",
|
|
779
|
+
"zh": "{{ model_name }} 正在分析如何筛选上下文...",
|
|
780
|
+
"ja": "{{ model_name }} がコンテキストをフィルタリングする方法を分析中...",
|
|
781
|
+
"ar": "{{ model_name }} يحلل كيفية تصفية السياق...",
|
|
782
|
+
"ru": "{{ model_name }} анализирует как фильтровать контекст...",
|
|
783
|
+
},
|
|
784
|
+
"quick_filter_failed": {
|
|
785
|
+
"en": "❌ Quick filter failed: {{ error }}. ",
|
|
786
|
+
"zh": "❌ 快速过滤器失败: {{ error }}. ",
|
|
787
|
+
"ja": "❌ クイックフィルターが失敗しました: {{ error }}. ",
|
|
788
|
+
"ar": "❌ فشل التصفية السريعة: {{ error }}. ",
|
|
789
|
+
"ru": "❌ Быстрая фильтрация не удалась: {{ error }}. ",
|
|
790
|
+
},
|
|
791
|
+
"unmerged_file_path": {
|
|
792
|
+
"en": "File: {{file_path}}",
|
|
793
|
+
"zh": "文件: {{file_path}}",
|
|
794
|
+
"ja": "ファイル: {{file_path}}",
|
|
795
|
+
"ar": "الملف: {{file_path}}",
|
|
796
|
+
"ru": "Файл: {{file_path}}",
|
|
797
|
+
},
|
|
798
|
+
"unmerged_search_block": {
|
|
799
|
+
"en": "Search Block({{similarity}}):",
|
|
800
|
+
"zh": "Search Block({{similarity}}):",
|
|
801
|
+
"ja": "検索ブロック({{similarity}}):",
|
|
802
|
+
"ar": "كتلة البحث({{similarity}}):",
|
|
803
|
+
"ru": "Блок поиска({{similarity}}):",
|
|
804
|
+
},
|
|
805
|
+
"unmerged_replace_block": {
|
|
806
|
+
"en": "Replace Block:",
|
|
807
|
+
"zh": "Replace Block:",
|
|
808
|
+
"ja": "置換ブロック:",
|
|
809
|
+
"ar": "كتلة الاستبدال:",
|
|
810
|
+
"ru": "Блок замены:",
|
|
811
|
+
},
|
|
812
|
+
"unmerged_blocks_total": {
|
|
813
|
+
"en": "Total unmerged blocks: {{num_blocks}}",
|
|
814
|
+
"zh": "未合并代码块数量: {{num_blocks}}",
|
|
815
|
+
"ja": "マージされていないブロック総数: {{num_blocks}}",
|
|
816
|
+
"ar": "إجمالي الكتل غير المدموجة: {{num_blocks}}",
|
|
817
|
+
"ru": "Общее количество неслитых блоков: {{num_blocks}}",
|
|
818
|
+
},
|
|
819
|
+
"git_init_required": {
|
|
820
|
+
"en": "⚠️ auto_merge only applies to git repositories.\n\nPlease try using git init in the source directory:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nThen run auto - coder again.\nError: {{ error }}",
|
|
821
|
+
"zh": "⚠️ auto_merge 仅适用于 git 仓库。\n\n请尝试在源目录中使用 git init:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\n然后再次运行 auto-coder。\n错误: {{ error }}",
|
|
822
|
+
"ja": "⚠️ auto_merge は git リポジトリにのみ適用されます。\n\nソースディレクトリで git init を試してください:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nその後、auto-coder を再実行してください。\nエラー: {{ error }}",
|
|
823
|
+
"ar": "⚠️ auto_merge ينطبق فقط على مستودعات git.\n\nيرجى محاولة استخدام git init في مجلد المصدر:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nثم قم بتشغيل auto-coder مرة أخرى.\nخطأ: {{ error }}",
|
|
824
|
+
"ru": "⚠️ auto_merge применяется только к git репозиториям.\n\nПожалуйста, попробуйте использовать git init в исходной директории:\n\n```shell\ncd {{ source_dir }}\ngit init.\n```\n\nЗатем запустите auto-coder снова.\nОшибка: {{ error }}",
|
|
825
|
+
},
|
|
826
|
+
"quick_filter_reason": {
|
|
827
|
+
"en": "Auto get(quick_filter mode)",
|
|
828
|
+
"zh": "自动获取(quick_filter模式)",
|
|
829
|
+
"ja": "自動取得(quick_filterモード)",
|
|
830
|
+
"ar": "الحصول التلقائي(وضع quick_filter)",
|
|
831
|
+
"ru": "Автоматическое получение(режим quick_filter)",
|
|
832
|
+
},
|
|
833
|
+
"quick_filter_too_long": {
|
|
834
|
+
"en": "⚠️ index file is too large ({{ tokens_len }}/{{ max_tokens }}). The query will be split into {{ split_size }} chunks.",
|
|
835
|
+
"zh": "⚠️ 索引文件过大 ({{ tokens_len }}/{{ max_tokens }})。查询将被分成 {{ split_size }} 个部分执行。",
|
|
836
|
+
"ja": "⚠️ インデックスファイルが大きすぎます ({{ tokens_len }}/{{ max_tokens }})。クエリは {{ split_size }} 個のチャンクに分割されます。",
|
|
837
|
+
"ar": "⚠️ ملف الفهرس كبير جداً ({{ tokens_len }}/{{ max_tokens }})。سيتم تقسيم الاستعلام إلى {{ split_size }} أجزاء.",
|
|
838
|
+
"ru": "⚠️ Индексный файл слишком большой ({{ tokens_len }}/{{ max_tokens }}). Запрос будет разделен на {{ split_size }} частей.",
|
|
839
|
+
},
|
|
840
|
+
"quick_filter_tokens_len": {
|
|
841
|
+
"en": "📊 Current index size: {{ tokens_len }} tokens",
|
|
842
|
+
"zh": "📊 当前索引大小: {{ tokens_len }} tokens",
|
|
843
|
+
"ja": "📊 現在のインデックスサイズ: {{ tokens_len }} トークン",
|
|
844
|
+
"ar": "📊 حجم الفهرس الحالي: {{ tokens_len }} رمز",
|
|
845
|
+
"ru": "📊 Текущий размер индекса: {{ tokens_len }} токенов",
|
|
846
|
+
},
|
|
847
|
+
"estimated_chat_input_tokens": {
|
|
848
|
+
"en": "Estimated chat input tokens: {{ estimated_input_tokens }}",
|
|
849
|
+
"zh": "对话输入token预估为: {{ estimated_input_tokens }}",
|
|
850
|
+
"ja": "推定チャット入力トークン数: {{ estimated_input_tokens }}",
|
|
851
|
+
"ar": "رموز إدخال المحادثة المقدرة: {{ estimated_input_tokens }}",
|
|
852
|
+
"ru": "Ожидаемое количество входных токенов чата: {{ estimated_input_tokens }}",
|
|
853
|
+
},
|
|
854
|
+
"estimated_input_tokens_in_generate": {
|
|
855
|
+
"en": "Estimated input tokens in generate ({{ generate_mode }}): {{ estimated_input_tokens_in_generate }}",
|
|
856
|
+
"zh": "生成代码({{ generate_mode }})预计输入token数: {{ estimated_input_tokens_in_generate }}",
|
|
857
|
+
"ja": "生成時の推定入力トークン数 ({{ generate_mode }}): {{ estimated_input_tokens_in_generate }}",
|
|
858
|
+
"ar": "رموز الإدخال المقدرة في التوليد ({{ generate_mode }}): {{ estimated_input_tokens_in_generate }}",
|
|
859
|
+
"ru": "Ожидаемое количество входных токенов при генерации ({{ generate_mode }}): {{ estimated_input_tokens_in_generate }}",
|
|
860
|
+
},
|
|
861
|
+
"model_has_access_restrictions": {
|
|
862
|
+
"en": "{{model_name}} has access restrictions, cannot use the current function",
|
|
863
|
+
"zh": "{{model_name}} 有访问限制,无法使用当前功能",
|
|
864
|
+
"ja": "{{model_name}} にはアクセス制限があり、現在の機能を使用できません",
|
|
865
|
+
"ar": "{{model_name}} لديه قيود الوصول، لا يمكن استخدام الوظيفة الحالية",
|
|
866
|
+
"ru": "{{model_name}} имеет ограничения доступа, невозможно использовать текущую функцию",
|
|
867
|
+
},
|
|
868
|
+
"auto_command_not_found": {
|
|
869
|
+
"en": "Auto command not found: {{command}}. Please check your input and try again.",
|
|
870
|
+
"zh": "未找到自动命令: {{command}}。请检查您的输入并重试。",
|
|
871
|
+
"ja": "自動コマンドが見つかりません: {{command}}。入力を確認して再試行してください。",
|
|
872
|
+
"ar": "لم يتم العثور على الأمر التلقائي: {{command}}. يرجى التحقق من إدخالك والمحاولة مرة أخرى.",
|
|
873
|
+
"ru": "Автоматическая команда не найдена: {{command}}. Пожалуйста, проверьте ваш ввод и попробуйте снова.",
|
|
874
|
+
},
|
|
875
|
+
"auto_command_failed": {
|
|
876
|
+
"en": "Auto command failed: {{error}}. Please check your input and try again.",
|
|
877
|
+
"zh": "自动命令执行失败: {{error}}。请检查您的输入并重试。",
|
|
878
|
+
"ja": "自動コマンドが失敗しました: {{error}}。入力を確認して再試行してください。",
|
|
879
|
+
"ar": "فشل الأمر التلقائي: {{error}}. يرجى التحقق من إدخالك والمحاولة مرة أخرى.",
|
|
880
|
+
"ru": "Автоматическая команда не удалась: {{error}}. Пожалуйста, проверьте ваш ввод и попробуйте снова.",
|
|
881
|
+
},
|
|
882
|
+
"command_execution_result": {
|
|
883
|
+
"en": "{{action}} execution result",
|
|
884
|
+
"zh": "{{action}} 执行结果",
|
|
885
|
+
"ja": "{{action}} 実行結果",
|
|
886
|
+
"ar": "نتيجة تنفيذ {{action}}",
|
|
887
|
+
"ru": "Результат выполнения {{action}}",
|
|
888
|
+
},
|
|
889
|
+
"satisfied_prompt": {
|
|
890
|
+
"en": "Requirements satisfied, no further action needed",
|
|
891
|
+
"zh": "已满足需求,无需进一步操作",
|
|
892
|
+
"ja": "要件が満たされました、さらなるアクションは不要です",
|
|
893
|
+
"ar": "تم تلبية المتطلبات، لا حاجة لإجراء إضافي",
|
|
894
|
+
"ru": "Требования выполнены, дополнительных действий не требуется",
|
|
895
|
+
},
|
|
896
|
+
"auto_command_analyzed": {
|
|
897
|
+
"en": "Selected command",
|
|
898
|
+
"zh": "被选择指令",
|
|
899
|
+
"ja": "選択されたコマンド",
|
|
900
|
+
"ar": "الأمر المحدد",
|
|
901
|
+
"ru": "Выбранная команда",
|
|
902
|
+
},
|
|
903
|
+
"invalid_enum_value": {
|
|
904
|
+
"en": "Value '{{value}}' is not in allowed values ({{allowed}})",
|
|
905
|
+
"zh": "值 '{{value}}' 不在允许的值列表中 ({{allowed}})",
|
|
906
|
+
"ja": "値 '{{value}}' は許可された値 ({{allowed}}) にありません",
|
|
907
|
+
"ar": "القيمة '{{value}}' ليست في القيم المسموحة ({{allowed}})",
|
|
908
|
+
"ru": "Значение '{{value}}' не входит в разрешенные значения ({{allowed}})",
|
|
909
|
+
},
|
|
910
|
+
"conversation_pruning_start": {
|
|
911
|
+
"en": "⚠️ Conversation pruning started, total tokens: {{total_tokens}}, safe zone: {{safe_zone}}",
|
|
912
|
+
"zh": "⚠️ 对话长度 {{total_tokens}} tokens 超过安全阈值 {{safe_zone}},开始修剪对话。",
|
|
913
|
+
"ja": "⚠️ 会話の剪定を開始しました、総トークン数: {{total_tokens}}、安全ゾーン: {{safe_zone}}",
|
|
914
|
+
"ar": "⚠️ بدأت عملية تقليم المحادثة، إجمالي الرموز: {{total_tokens}}، المنطقة الآمنة: {{safe_zone}}",
|
|
915
|
+
"ru": "⚠️ Начата обрезка разговора, общее количество токенов: {{total_tokens}}, безопасная зона: {{safe_zone}}",
|
|
916
|
+
},
|
|
917
|
+
"invalid_file_number": {
|
|
918
|
+
"en": "⚠️ Invalid file number {{file_number}}, total files: {{total_files}}",
|
|
919
|
+
"zh": "⚠️ 无效的文件编号 {{file_number}},总文件数为 {{total_files}}",
|
|
920
|
+
"ja": "⚠️ 無効なファイル番号 {{file_number}}、総ファイル数: {{total_files}}",
|
|
921
|
+
"ar": "⚠️ رقم الملف غير صحيح {{file_number}}، إجمالي الملفات: {{total_files}}",
|
|
922
|
+
"ru": "⚠️ Неверный номер файла {{file_number}}, общее количество файлов: {{total_files}}",
|
|
923
|
+
},
|
|
924
|
+
"all_merge_results_failed": {
|
|
925
|
+
"en": "⚠️ All merge attempts failed, returning first candidate",
|
|
926
|
+
"zh": "⚠️ 所有合并尝试都失败,返回第一个候选",
|
|
927
|
+
"ja": "⚠️ すべてのマージ試行が失敗しました、最初の候補を返します",
|
|
928
|
+
"ar": "⚠️ فشلت جميع محاولات الدمج، إرجاع المرشح الأول",
|
|
929
|
+
"ru": "⚠️ Все попытки слияния не удались, возвращаем первого кандидата",
|
|
930
|
+
},
|
|
931
|
+
"only_one_merge_result_success": {
|
|
932
|
+
"en": "✅ Only one merge result succeeded, returning that candidate",
|
|
933
|
+
"zh": "✅ 只有一个合并结果成功,返回该候选",
|
|
934
|
+
"ja": "✅ 1つのマージ結果のみが成功しました、その候補を返します",
|
|
935
|
+
"ar": "✅ نجح نتيجة دمج واحدة فقط، إرجاع ذلك المرشح",
|
|
936
|
+
"ru": "✅ Только один результат слияния был успешным, возвращаем этого кандидата",
|
|
937
|
+
},
|
|
938
|
+
"conf_import_success": {
|
|
939
|
+
"en": "Successfully imported configuration: {{path}}",
|
|
940
|
+
"zh": "成功导入配置: {{path}}",
|
|
941
|
+
"ja": "設定のインポートが成功しました: {{path}}",
|
|
942
|
+
"ar": "تم استيراد التكوين بنجاح: {{path}}",
|
|
943
|
+
"ru": "Конфигурация успешно импортирована: {{path}}",
|
|
944
|
+
},
|
|
945
|
+
"conf_export_success": {
|
|
946
|
+
"en": "Successfully exported configuration: {{path}}",
|
|
947
|
+
"zh": "成功导出配置: {{path}}",
|
|
948
|
+
"ja": "設定のエクスポートが成功しました: {{path}}",
|
|
949
|
+
"ar": "تم تصدير التكوين بنجاح: {{path}}",
|
|
950
|
+
"ru": "Конфигурация успешно экспортирована: {{path}}",
|
|
951
|
+
},
|
|
952
|
+
"conf_import_error": {
|
|
953
|
+
"en": "Error importing configuration: {{error}}",
|
|
954
|
+
"zh": "导入配置出错: {{error}}",
|
|
955
|
+
"ja": "設定のインポートエラー: {{error}}",
|
|
956
|
+
"ar": "خطأ في استيراد التكوين: {{error}}",
|
|
957
|
+
"ru": "Ошибка импорта конфигурации: {{error}}",
|
|
958
|
+
},
|
|
959
|
+
"conf_export_error": {
|
|
960
|
+
"en": "Error exporting configuration: {{error}}",
|
|
961
|
+
"zh": "导出配置出错: {{error}}",
|
|
962
|
+
"ja": "設定のエクスポートエラー: {{error}}",
|
|
963
|
+
"ar": "خطأ في تصدير التكوين: {{error}}",
|
|
964
|
+
"ru": "Ошибка экспорта конфигурации: {{error}}",
|
|
965
|
+
},
|
|
966
|
+
"conf_import_invalid_format": {
|
|
967
|
+
"en": "Invalid import configuration format, expected 'key:value'",
|
|
968
|
+
"zh": "导入配置格式无效, 应为 'key:value' 格式",
|
|
969
|
+
"ja": "無効なインポート設定形式です、'key:value'形式が期待されます",
|
|
970
|
+
"ar": "تنسيق تكوين الاستيراد غير صحيح، متوقع 'key:value'",
|
|
971
|
+
"ru": "Неверный формат импорта конфигурации, ожидается 'key:value'",
|
|
972
|
+
},
|
|
973
|
+
"conf_export_invalid_format": {
|
|
974
|
+
"en": "Invalid export configuration format, expected 'key:value'",
|
|
975
|
+
"zh": "导出配置格式无效, 应为 'key:value' 格式",
|
|
976
|
+
"ja": "無効なエクスポート設定形式です、'key:value'形式が期待されます",
|
|
977
|
+
"ar": "تنسيق تكوين التصدير غير صحيح، متوقع 'key:value'",
|
|
978
|
+
"ru": "Неверный формат экспорта конфигурации, ожидается 'key:value'",
|
|
979
|
+
},
|
|
980
|
+
"conf_import_file_not_found": {
|
|
981
|
+
"en": "Import configuration file not found: {{file_path}}",
|
|
982
|
+
"zh": "未找到导入配置文件: {{file_path}}",
|
|
983
|
+
"ja": "インポート設定ファイルが見つかりません: {{file_path}}",
|
|
984
|
+
"ar": "لم يتم العثور على ملف تكوين الاستيراد: {{file_path}}",
|
|
985
|
+
"ru": "Файл импорта конфигурации не найден: {{file_path}}",
|
|
986
|
+
},
|
|
987
|
+
"conf_export_file_not_found": {
|
|
988
|
+
"en": "Export configuration file not found: {{file_path}}",
|
|
989
|
+
"zh": "未找到导出配置文件: {{file_path}}",
|
|
990
|
+
"ja": "エクスポート設定ファイルが見つかりません: {{file_path}}",
|
|
991
|
+
"ar": "لم يتم العثور على ملف تكوين التصدير: {{file_path}}",
|
|
992
|
+
"ru": "Файл экспорта конфигурации не найден: {{file_path}}",
|
|
993
|
+
},
|
|
994
|
+
"conf_import_file_empty": {
|
|
995
|
+
"en": "Import configuration file is empty: {{file_path}}",
|
|
996
|
+
"zh": "导入配置文件为空: {{file_path}}",
|
|
997
|
+
"ja": "インポート設定ファイルが空です: {{file_path}}",
|
|
998
|
+
"ar": "ملف تكوين الاستيراد فارغ: {{file_path}}",
|
|
999
|
+
"ru": "Файл импорта конфигурации пуст: {{file_path}}",
|
|
1000
|
+
},
|
|
1001
|
+
"conf_export_file_empty": {
|
|
1002
|
+
"en": "Export configuration file is empty: {{file_path}}",
|
|
1003
|
+
"zh": "导出配置文件为空: {{file_path}}",
|
|
1004
|
+
"ja": "エクスポート設定ファイルが空です: {{file_path}}",
|
|
1005
|
+
"ar": "ملف تكوين التصدير فارغ: {{file_path}}",
|
|
1006
|
+
"ru": "Файл экспорта конфигурации пуст: {{file_path}}",
|
|
1007
|
+
},
|
|
1008
|
+
"generated_shell_script": {
|
|
1009
|
+
"en": "Generated Shell Script",
|
|
1010
|
+
"zh": "生成的 Shell 脚本",
|
|
1011
|
+
"ja": "生成されたシェルスクリプト",
|
|
1012
|
+
"ar": "نص الشل المولد",
|
|
1013
|
+
"ru": "Сгенерированный Shell скрипт",
|
|
1014
|
+
},
|
|
1015
|
+
"confirm_execute_shell_script": {
|
|
1016
|
+
"en": "Do you want to execute this shell script?",
|
|
1017
|
+
"zh": "您要执行此 shell 脚本吗?",
|
|
1018
|
+
"ja": "このシェルスクリプトを実行しますか?",
|
|
1019
|
+
"ar": "هل تريد تنفيذ نص الشل هذا؟",
|
|
1020
|
+
"ru": "Хотите ли вы выполнить этот shell скрипт?",
|
|
1021
|
+
},
|
|
1022
|
+
"shell_script_not_executed": {
|
|
1023
|
+
"en": "Shell script was not executed",
|
|
1024
|
+
"zh": "Shell 脚本未执行",
|
|
1025
|
+
"ja": "シェルスクリプトは実行されませんでした",
|
|
1026
|
+
"ar": "لم يتم تنفيذ نص الشل",
|
|
1027
|
+
"ru": "Shell скрипт не был выполнен",
|
|
1028
|
+
},
|
|
1029
|
+
"index_export_success": {
|
|
1030
|
+
"en": "Index exported successfully: {{path}}",
|
|
1031
|
+
"zh": "索引导出成功: {{path}}",
|
|
1032
|
+
"ja": "インデックスのエクスポートが成功しました: {{path}}",
|
|
1033
|
+
"ar": "تم تصدير الفهرس بنجاح: {{path}}",
|
|
1034
|
+
"ru": "Индекс успешно экспортирован: {{path}}",
|
|
1035
|
+
},
|
|
1036
|
+
"index_import_success": {
|
|
1037
|
+
"en": "Index imported successfully: {{path}}",
|
|
1038
|
+
"zh": "索引导入成功: {{path}}",
|
|
1039
|
+
"ja": "インデックスのインポートが成功しました: {{path}}",
|
|
1040
|
+
"ar": "تم استيراد الفهرس بنجاح: {{path}}",
|
|
1041
|
+
"ru": "Индекс успешно импортирован: {{path}}",
|
|
1042
|
+
},
|
|
1043
|
+
"edits_title": {
|
|
1044
|
+
"en": "edits",
|
|
1045
|
+
"zh": "编辑块",
|
|
1046
|
+
"ja": "編集",
|
|
1047
|
+
"ar": "التعديلات",
|
|
1048
|
+
"ru": "редактирования",
|
|
1049
|
+
},
|
|
1050
|
+
"diff_blocks_title": {
|
|
1051
|
+
"en": "diff blocks",
|
|
1052
|
+
"zh": "差异块",
|
|
1053
|
+
"ja": "差分ブロック",
|
|
1054
|
+
"ar": "كتل الاختلاف",
|
|
1055
|
+
"ru": "блоки различий",
|
|
1056
|
+
},
|
|
1057
|
+
"index_exclude_files_error": {
|
|
1058
|
+
"en": "index filter exclude files fail: {{ error }}",
|
|
1059
|
+
"zh": "索引排除文件时出错: {{error}}",
|
|
1060
|
+
"ja": "インデックスフィルターでファイル除外に失敗: {{ error }}",
|
|
1061
|
+
"ar": "فشل في استبعاد الملفات من مرشح الفهرس: {{ error }}",
|
|
1062
|
+
"ru": "Ошибка исключения файлов индексного фильтра: {{ error }}",
|
|
1063
|
+
},
|
|
1064
|
+
"file_sliding_window_processing": {
|
|
1065
|
+
"en": "File {{ file_path }} is too large ({{ tokens }} tokens), processing with sliding window...",
|
|
1066
|
+
"zh": "文件 {{ file_path }} 过大 ({{ tokens }} tokens),正在使用滑动窗口处理...",
|
|
1067
|
+
"ja": "ファイル {{ file_path }} が大きすぎます ({{ tokens }} トークン)、スライディングウィンドウで処理中...",
|
|
1068
|
+
"ar": "الملف {{ file_path }} كبير جداً ({{ tokens }} رمز)، معالجة بنافذة منزلقة...",
|
|
1069
|
+
"ru": "Файл {{ file_path }} слишком большой ({{ tokens }} токенов), обработка с использованием скользящего окна...",
|
|
1070
|
+
},
|
|
1071
|
+
"file_snippet_processing": {
|
|
1072
|
+
"en": "Processing file {{ file_path }} with code snippet extraction...",
|
|
1073
|
+
"zh": "正在对文件 {{ file_path }} 进行代码片段提取...",
|
|
1074
|
+
"ja": "ファイル {{ file_path }} のコードスニペット抽出を処理中...",
|
|
1075
|
+
"ar": "معالجة الملف {{ file_path }} مع استخراج مقتطفات الكود...",
|
|
1076
|
+
"ru": "Обработка файла {{ file_path }} с извлечением фрагментов кода...",
|
|
1077
|
+
},
|
|
1078
|
+
"context_pruning_start": {
|
|
1079
|
+
"en": "⚠️ Context pruning started. Total tokens: {{ total_tokens }} (max allowed: {{ max_tokens }}). Applying strategy: {{ strategy }}.",
|
|
1080
|
+
"zh": "⚠️ 开始上下文剪枝。总token数: {{ total_tokens }} (最大允许: {{ max_tokens }})。正在应用策略: {{ strategy }}。",
|
|
1081
|
+
"ja": "⚠️ コンテキストの剪定を開始しました。総トークン数: {{ total_tokens }} (最大許可: {{ max_tokens }})。戦略を適用中: {{ strategy }}。",
|
|
1082
|
+
"ar": "⚠️ بدأت عملية تقليم السياق. إجمالي الرموز: {{ total_tokens }} (الحد الأقصى المسموح: {{ max_tokens }})。تطبيق الاستراتيجية: {{ strategy }}。",
|
|
1083
|
+
"ru": "⚠️ Начата обрезка контекста. Общее количество токенов: {{ total_tokens }} (максимально разрешено: {{ max_tokens }}). Применяется стратегия: {{ strategy }}.",
|
|
1084
|
+
},
|
|
1085
|
+
"context_pruning_reason": {
|
|
1086
|
+
"en": "Context length exceeds maximum limit ({{ total_tokens }} > {{ max_tokens }}). Pruning is required to fit within the model's context window.",
|
|
1087
|
+
"zh": "上下文长度超过最大限制 ({{ total_tokens }} > {{ max_tokens }})。需要进行剪枝以适配模型的上下文窗口。",
|
|
1088
|
+
"ja": "コンテキスト長が最大制限を超えています ({{ total_tokens }} > {{ max_tokens }})。モデルのコンテキストウィンドウに収めるために剪定が必要です。",
|
|
1089
|
+
"ar": "طول السياق يتجاوز الحد الأقصى ({{ total_tokens }} > {{ max_tokens }})。التقليم مطلوب للتناسب مع نافذة سياق النموذج。",
|
|
1090
|
+
"ru": "Длина контекста превышает максимальный лимит ({{ total_tokens }} > {{ max_tokens }}). Требуется обрезка для размещения в контекстном окне модели.",
|
|
1091
|
+
},
|
|
1092
|
+
"rank_code_modification_title": {
|
|
1093
|
+
"en": "{{model_name}} ranking codes",
|
|
1094
|
+
"zh": "模型{{model_name}}对代码打分",
|
|
1095
|
+
"ja": "{{model_name}} コードランキング",
|
|
1096
|
+
"ar": "{{model_name}} ترتيب الأكواد",
|
|
1097
|
+
"ru": "{{model_name}} ранжирование кода",
|
|
1098
|
+
},
|
|
1099
|
+
"sorted_files_message": {
|
|
1100
|
+
"en": "Reordered files:\n{% for file in files %}- {{ file }}\n{% endfor %}",
|
|
1101
|
+
"zh": "重新排序后的文件路径:\n{% for file in files %}- {{ file }}\n{% endfor %}",
|
|
1102
|
+
"ja": "並び替えられたファイル:\n{% for file in files %}- {{ file }}\n{% endfor %}",
|
|
1103
|
+
"ar": "الملفات المعاد ترتيبها:\n{% for file in files %}- {{ file }}\n{% endfor %}",
|
|
1104
|
+
"ru": "Переупорядоченные файлы:\n{% for file in files %}- {{ file }}\n{% endfor %}",
|
|
1105
|
+
},
|
|
1106
|
+
"estimated_input_tokens_in_ranking": {
|
|
1107
|
+
"en": "estimate input token {{ estimated_input_tokens }} when ranking",
|
|
1108
|
+
"zh": "排序预计输入token数: {{ estimated_input_tokens }}",
|
|
1109
|
+
"ja": "ランキング時の推定入力トークン数: {{ estimated_input_tokens }}",
|
|
1110
|
+
"ar": "تقدير رموز الإدخال {{ estimated_input_tokens }} عند الترتيب",
|
|
1111
|
+
"ru": "Ожидаемое количество входных токенов при ранжировании: {{ estimated_input_tokens }}",
|
|
1112
|
+
},
|
|
1113
|
+
"file_snippet_procesed": {
|
|
1114
|
+
"en": "{{ file_path }} processed with tokens: {{ tokens }} => {{ snippet_tokens }}. Current total tokens: {{ total_tokens }}",
|
|
1115
|
+
"zh": "文件 {{ file_path }} 处理后token数: {{ tokens }} => {{ snippet_tokens }} 当前总token数: {{ total_tokens }}",
|
|
1116
|
+
"ja": "{{ file_path }} 処理済みトークン数: {{ tokens }} => {{ snippet_tokens }} 現在の総トークン数: {{ total_tokens }}",
|
|
1117
|
+
"ar": "{{ file_path }} معالج برموز: {{ tokens }} => {{ snippet_tokens }} إجمالي الرموز الحالي: {{ total_tokens }}",
|
|
1118
|
+
"ru": "{{ file_path }} обработан с токенами: {{ tokens }} => {{ snippet_tokens }} Текущее общее количество токенов: {{ total_tokens }}",
|
|
1119
|
+
},
|
|
1120
|
+
"tool_ask_user": {
|
|
1121
|
+
"en": "Your Reply: ",
|
|
1122
|
+
"zh": "您的回复: ",
|
|
1123
|
+
"ja": "あなたの返信: ",
|
|
1124
|
+
"ar": "ردك: ",
|
|
1125
|
+
"ru": "Ваш ответ: ",
|
|
1126
|
+
},
|
|
1127
|
+
"tool_ask_user_accept": {
|
|
1128
|
+
"en": "Your Response received",
|
|
1129
|
+
"zh": "收到您的回复",
|
|
1130
|
+
"ja": "あなたの回答を受信しました",
|
|
1131
|
+
"ar": "تم استلام ردك",
|
|
1132
|
+
"ru": "Ваш ответ получен",
|
|
1133
|
+
},
|
|
1134
|
+
"auto_web_analyzing": {
|
|
1135
|
+
"en": "Analyzing web automation task...",
|
|
1136
|
+
"zh": "正在分析网页自动化任务...",
|
|
1137
|
+
"ja": "ウェブ自動化タスクを分析中...",
|
|
1138
|
+
"ar": "تحليل مهمة أتمتة الويب...",
|
|
1139
|
+
"ru": "Анализ задачи веб-автоматизации...",
|
|
1140
|
+
},
|
|
1141
|
+
"auto_web_analyzed": {
|
|
1142
|
+
"en": "Web automation task analysis completed",
|
|
1143
|
+
"zh": "网页自动化任务分析完成",
|
|
1144
|
+
"ja": "ウェブ自動化タスクの分析が完了しました",
|
|
1145
|
+
"ar": "اكتمل تحليل مهمة أتمتة الويب",
|
|
1146
|
+
"ru": "Анализ задачи веб-автоматизации завершен",
|
|
1147
|
+
},
|
|
1148
|
+
"executing_web_action": {
|
|
1149
|
+
"en": "Executing action: {{action}} - {{description}}",
|
|
1150
|
+
"zh": "执行操作: {{action}} - {{description}}",
|
|
1151
|
+
"ja": "アクションを実行中: {{action}} - {{description}}",
|
|
1152
|
+
"ar": "تنفيذ الإجراء: {{action}} - {{description}}",
|
|
1153
|
+
"ru": "Выполнение действия: {{action}} - {{description}}",
|
|
1154
|
+
},
|
|
1155
|
+
"executing_step": {
|
|
1156
|
+
"en": "Executing step {{step}}: {{description}}",
|
|
1157
|
+
"zh": "执行步骤 {{step}}: {{description}}",
|
|
1158
|
+
"ja": "ステップ {{step}} を実行中: {{description}}",
|
|
1159
|
+
"ar": "تنفيذ الخطوة {{step}}: {{description}}",
|
|
1160
|
+
"ru": "Выполнение шага {{step}}: {{description}}",
|
|
1161
|
+
},
|
|
1162
|
+
"operation_cancelled": {
|
|
1163
|
+
"en": "Operation cancelled",
|
|
1164
|
+
"zh": "操作已取消",
|
|
1165
|
+
"ja": "操作がキャンセルされました",
|
|
1166
|
+
"ar": "تم إلغاء العملية",
|
|
1167
|
+
"ru": "Операция отменена",
|
|
1168
|
+
},
|
|
1169
|
+
"element_not_found": {
|
|
1170
|
+
"en": "Element not found: {{element}}",
|
|
1171
|
+
"zh": "未找到元素: {{element}}",
|
|
1172
|
+
"ja": "要素が見つかりません: {{element}}",
|
|
1173
|
+
"ar": "لم يتم العثور على العنصر: {{element}}",
|
|
1174
|
+
"ru": "Элемент не найден: {{element}}",
|
|
1175
|
+
},
|
|
1176
|
+
"analyzing_results": {
|
|
1177
|
+
"en": "Analyzing execution results...",
|
|
1178
|
+
"zh": "分析执行结果...",
|
|
1179
|
+
"ja": "実行結果を分析中...",
|
|
1180
|
+
"ar": "تحليل نتائج التنفيذ...",
|
|
1181
|
+
"ru": "Анализ результатов выполнения...",
|
|
1182
|
+
},
|
|
1183
|
+
"next_steps_determined": {
|
|
1184
|
+
"en": "Next steps determined",
|
|
1185
|
+
"zh": "已确定下一步操作",
|
|
1186
|
+
"ja": "次のステップが決定されました",
|
|
1187
|
+
"ar": "تم تحديد الخطوات التالية",
|
|
1188
|
+
"ru": "Следующие шаги определены",
|
|
1189
|
+
},
|
|
1190
|
+
"max_iterations_reached": {
|
|
1191
|
+
"en": "Max iterations reached ({max_iterations})",
|
|
1192
|
+
"zh": "已达到最大迭代次数 {{max_iterations}}",
|
|
1193
|
+
"ja": "最大反復回数に達しました ({{max_iterations}})",
|
|
1194
|
+
"ar": "تم الوصول إلى أقصى عدد تكرارات ({{max_iterations}})",
|
|
1195
|
+
"ru": "Достигнуто максимальное количество итераций ({{max_iterations}})",
|
|
1196
|
+
},
|
|
1197
|
+
"action_verification_failed": {
|
|
1198
|
+
"en": "Action verification failed: {{action}} - {{reason}}",
|
|
1199
|
+
"zh": "操作验证失败: {{action}} - {{reason}}",
|
|
1200
|
+
"ja": "アクションの検証に失敗しました: {{action}} - {{reason}}",
|
|
1201
|
+
"ar": "فشل التحقق من الإجراء: {{action}} - {{reason}}",
|
|
1202
|
+
"ru": "Проверка действия не удалась: {{action}} - {{reason}}",
|
|
1203
|
+
},
|
|
1204
|
+
"action_succeeded": {
|
|
1205
|
+
"en": "Action succeeded: {{action}}",
|
|
1206
|
+
"zh": "操作成功: {{action}}",
|
|
1207
|
+
"ja": "アクションが成功しました: {{action}}",
|
|
1208
|
+
"ar": "نجح الإجراء: {{action}}",
|
|
1209
|
+
"ru": "Действие выполнено успешно: {{action}}",
|
|
1210
|
+
},
|
|
1211
|
+
"replanned_actions": {
|
|
1212
|
+
"en": "Replanned {{count}} actions",
|
|
1213
|
+
"zh": "已重新规划 {{count}} 个操作",
|
|
1214
|
+
"ja": "{{count}} 個のアクションを再計画しました",
|
|
1215
|
+
"ar": "تم إعادة التخطيط لـ {{count}} إجراءات",
|
|
1216
|
+
"ru": "Перепланировано {{count}} действий",
|
|
1217
|
+
},
|
|
1218
|
+
"web_automation_ask_user": {
|
|
1219
|
+
"en": "Your answer: ",
|
|
1220
|
+
"zh": "您的回答: ",
|
|
1221
|
+
"ja": "あなたの回答: ",
|
|
1222
|
+
"ar": "إجابتك: ",
|
|
1223
|
+
"ru": "Ваш ответ: ",
|
|
1224
|
+
},
|
|
1225
|
+
"filter_mode_normal": {
|
|
1226
|
+
"en": "Using normal filter mode for index processing...",
|
|
1227
|
+
"zh": "正在使用普通过滤模式处理索引...",
|
|
1228
|
+
"ja": "インデックス処理に通常フィルターモードを使用中...",
|
|
1229
|
+
"ar": "استخدام وضع التصفية العادي لمعالجة الفهرس...",
|
|
1230
|
+
"ru": "Использование обычного режима фильтрации для обработки индекса...",
|
|
1231
|
+
},
|
|
1232
|
+
"filter_mode_big": {
|
|
1233
|
+
"en": "Index file is large ({{ tokens_len }} tokens), using big_filter mode for processing...",
|
|
1234
|
+
"zh": "索引文件较大 ({{ tokens_len }} tokens),正在使用 big_filter 模式处理...",
|
|
1235
|
+
"ja": "インデックスファイルが大きいです ({{ tokens_len }} トークン)、big_filter モードで処理中...",
|
|
1236
|
+
"ar": "ملف الفهرس كبير ({{ tokens_len }} رمز)، استخدام وضع big_filter للمعالجة...",
|
|
1237
|
+
"ru": "Индексный файл большой ({{ tokens_len }} токенов), используется режим big_filter для обработки...",
|
|
1238
|
+
},
|
|
1239
|
+
"filter_mode_super_big": {
|
|
1240
|
+
"en": "Index file is very large ({{ tokens_len }} tokens), using super_big_filter mode for processing...",
|
|
1241
|
+
"zh": "索引文件非常大 ({{ tokens_len }} tokens),正在使用 super_big_filter 模式处理...",
|
|
1242
|
+
"ja": "インデックスファイルが非常に大きいです ({{ tokens_len }} トークン)、super_big_filter モードで処理中...",
|
|
1243
|
+
"ar": "ملف الفهرس كبير جداً ({{ tokens_len }} رمز)، استخدام وضع super_big_filter للمعالجة...",
|
|
1244
|
+
"ru": "Индексный файл очень большой ({{ tokens_len }} токенов), используется режим super_big_filter для обработки...",
|
|
1245
|
+
},
|
|
1246
|
+
"super_big_filter_failed": {
|
|
1247
|
+
"en": "❌ Super big filter failed: {{ error }}.",
|
|
1248
|
+
"zh": "❌ 超大过滤器失败: {{ error }}.",
|
|
1249
|
+
"ja": "❌ スーパー大容量フィルターが失敗しました: {{ error }}.",
|
|
1250
|
+
"ar": "❌ فشل المرشح الفائق الكبر: {{ error }}.",
|
|
1251
|
+
"ru": "❌ Сверхбольшой фильтр не удался: {{ error }}.",
|
|
1252
|
+
},
|
|
1253
|
+
"super_big_filter_stats": {
|
|
1254
|
+
"en": "{{ model_names }} Super big filter completed in {{ elapsed_time }} seconds, input tokens: {{ input_tokens }}, output tokens: {{ output_tokens }}, input cost: {{ input_cost }}, output cost: {{ output_cost }}, speed: {{ speed }} tokens/s, chunk_index: {{ chunk_index }}",
|
|
1255
|
+
"zh": "{{ model_names }} 超大过滤器完成耗时 {{ elapsed_time }} 秒,输入token数: {{ input_tokens }}, 输出token数: {{ output_tokens }}, 输入成本: {{ input_cost }}, 输出成本: {{ output_cost }}, 速度: {{ speed }} tokens/秒, 块索引: {{ chunk_index }}",
|
|
1256
|
+
"ja": "{{ model_names }} スーパー大容量フィルター完了 {{ elapsed_time }} 秒、入力トークン数: {{ input_tokens }}、出力トークン数: {{ output_tokens }}、入力コスト: {{ input_cost }}、出力コスト: {{ output_cost }}、速度: {{ speed }} tokens/秒、チャンクインデックス: {{ chunk_index }}",
|
|
1257
|
+
"ar": "{{ model_names }} اكتمل المرشح الفائق الكبر في {{ elapsed_time }} ثانية، رموز الإدخال: {{ input_tokens }}، رموز الإخراج: {{ output_tokens }}، تكلفة الإدخال: {{ input_cost }}، تكلفة الإخراج: {{ output_cost }}، السرعة: {{ speed }} رمز/ثانية، فهرس الجزء: {{ chunk_index }}",
|
|
1258
|
+
"ru": "{{ model_names }} Сверхбольшой фильтр завершен за {{ elapsed_time }} секунд, входных токенов: {{ input_tokens }}, выходных токенов: {{ output_tokens }}, стоимость входа: {{ input_cost }}, стоимость выхода: {{ output_cost }}, скорость: {{ speed }} токенов/с, индекс части: {{ chunk_index }}",
|
|
1259
|
+
},
|
|
1260
|
+
"super_big_filter_splitting": {
|
|
1261
|
+
"en": "⚠️ Index file is extremely large ({{ tokens_len }}/{{ max_tokens }}). The query will be split into {{ split_size }} chunks for processing.",
|
|
1262
|
+
"zh": "⚠️ 索引文件极其庞大 ({{ tokens_len }}/{{ max_tokens }})。查询将被分成 {{ split_size }} 个部分进行处理。",
|
|
1263
|
+
"ja": "⚠️ インデックスファイルが極めて大きいです ({{ tokens_len }}/{{ max_tokens }})。クエリは処理のために {{ split_size }} 個のチャンクに分割されます。",
|
|
1264
|
+
"ar": "⚠️ ملف الفهرس كبير بشكل استثنائي ({{ tokens_len }}/{{ max_tokens }})。سيتم تقسيم الاستعلام إلى {{ split_size }} أجزاء للمعالجة。",
|
|
1265
|
+
"ru": "⚠️ Индексный файл чрезвычайно большой ({{ tokens_len }}/{{ max_tokens }}). Запрос будет разделен на {{ split_size }} частей для обработки.",
|
|
1266
|
+
},
|
|
1267
|
+
"super_big_filter_title": {
|
|
1268
|
+
"en": "{{ model_name }} is analyzing how to filter extremely large context...",
|
|
1269
|
+
"zh": "{{ model_name }} 正在分析如何过滤极大规模上下文...",
|
|
1270
|
+
"ja": "{{ model_name }} が極めて大きなコンテキストをフィルタリングする方法を分析中...",
|
|
1271
|
+
"ar": "{{ model_name }} يحلل كيفية تصفية السياق الكبير للغاية...",
|
|
1272
|
+
"ru": "{{ model_name }} анализирует как фильтровать чрезвычайно большой контекст...",
|
|
1273
|
+
},
|
|
1274
|
+
"mcp_server_info_error": {
|
|
1275
|
+
"en": "Error getting MCP server info: {{ error }}",
|
|
1276
|
+
"zh": "获取MCP服务器信息时出错: {{ error }}",
|
|
1277
|
+
"ja": "MCPサーバー情報の取得エラー: {{ error }}",
|
|
1278
|
+
"ar": "خطأ في الحصول على معلومات خادم MCP: {{ error }}",
|
|
1279
|
+
"ru": "Ошибка получения информации о MCP сервере: {{ error }}",
|
|
1280
|
+
},
|
|
1281
|
+
"mcp_server_info_title": {
|
|
1282
|
+
"en": "Connected MCP Server Info",
|
|
1283
|
+
"zh": "已连接的MCP服务器信息",
|
|
1284
|
+
"ja": "接続されたMCPサーバー情報",
|
|
1285
|
+
"ar": "معلومات خادم MCP المتصل",
|
|
1286
|
+
"ru": "Информация о подключенном MCP сервере",
|
|
1287
|
+
},
|
|
1288
|
+
"no_commit_file_name": {
|
|
1289
|
+
"en": "Cannot get the file name of the commit_id in the actions directory: {{commit_id}}",
|
|
1290
|
+
"zh": "无法获取commit_id关联的actions 目录下的文件名: {{commit_id}}",
|
|
1291
|
+
"ja": "actionsディレクトリ内のcommit_idのファイル名を取得できません: {{commit_id}}",
|
|
1292
|
+
"ar": "لا يمكن الحصول على اسم الملف للcommit_id في مجلد الإجراءات: {{commit_id}}",
|
|
1293
|
+
"ru": "Невозможно получить имя файла commit_id в директории actions: {{commit_id}}",
|
|
1294
|
+
},
|
|
1295
|
+
"yaml_update_success": {
|
|
1296
|
+
"en": "✅ Successfully updated YAML file: {{yaml_file}}",
|
|
1297
|
+
"zh": "✅ 成功更新YAML文件: {{yaml_file}}",
|
|
1298
|
+
"ja": "✅ YAMLファイルの更新が成功しました: {{yaml_file}}",
|
|
1299
|
+
"ar": "✅ تم تحديث ملف YAML بنجاح: {{yaml_file}}",
|
|
1300
|
+
"ru": "✅ YAML файл успешно обновлен: {{yaml_file}}",
|
|
1301
|
+
},
|
|
1302
|
+
"yaml_save_error": {
|
|
1303
|
+
"en": "❌ Error saving YAML file {{yaml_file}}: {{error}}",
|
|
1304
|
+
"zh": "❌ 保存YAML文件出错 {{yaml_file}}: {{error}}",
|
|
1305
|
+
"ja": "❌ YAMLファイル {{yaml_file}} の保存エラー: {{error}}",
|
|
1306
|
+
"ar": "❌ خطأ في حفظ ملف YAML {{yaml_file}}: {{error}}",
|
|
1307
|
+
"ru": "❌ Ошибка сохранения YAML файла {{yaml_file}}: {{error}}",
|
|
1308
|
+
},
|
|
1309
|
+
"active_context_background_task": {
|
|
1310
|
+
"en": "🔄 Active context generation started in background (task ID: {{task_id}})",
|
|
1311
|
+
"zh": "🔄 正在后台生成活动上下文 (任务ID: {{task_id}})",
|
|
1312
|
+
"ja": "🔄 アクティブコンテキストの生成をバックグラウンドで開始しました (タスクID: {{task_id}})",
|
|
1313
|
+
"ar": "🔄 بدأ توليد السياق النشط في الخلفية (معرف المهمة: {{task_id}})",
|
|
1314
|
+
"ru": "🔄 Генерация активного контекста запущена в фоне (ID задачи: {{task_id}})",
|
|
1315
|
+
},
|
|
1316
|
+
"conf_not_found": {
|
|
1317
|
+
"en": "Configuration not found: {{path}}",
|
|
1318
|
+
"zh": "未找到配置文件: {{path}}",
|
|
1319
|
+
"ja": "設定が見つかりません: {{path}}",
|
|
1320
|
+
"ar": "لم يتم العثور على التكوين: {{path}}",
|
|
1321
|
+
"ru": "Конфигурация не найдена: {{path}}",
|
|
1322
|
+
},
|
|
1323
|
+
"code_generate_title": {
|
|
1324
|
+
"en": "{{model_name}} is generating code",
|
|
1325
|
+
"zh": "{{model_name}}正在生成代码",
|
|
1326
|
+
"ja": "{{model_name}}がコードを生成中",
|
|
1327
|
+
"ar": "{{model_name}} يولد الكود",
|
|
1328
|
+
"ru": "{{model_name}} генерирует код",
|
|
1329
|
+
},
|
|
1330
|
+
"generating_initial_code": {
|
|
1331
|
+
"en": "Generating initial code...",
|
|
1332
|
+
"zh": "正在生成初始代码...",
|
|
1333
|
+
"ja": "初期コードを生成中...",
|
|
1334
|
+
"ar": "توليد الكود الأولي...",
|
|
1335
|
+
"ru": "Генерация начального кода...",
|
|
1336
|
+
},
|
|
1337
|
+
"generation_failed": {
|
|
1338
|
+
"en": "Code generation failed",
|
|
1339
|
+
"zh": "代码生成失败",
|
|
1340
|
+
"ja": "コード生成が失敗しました",
|
|
1341
|
+
"ar": "فشل توليد الكود",
|
|
1342
|
+
"ru": "Генерация кода не удалась",
|
|
1343
|
+
},
|
|
1344
|
+
"no_files_to_lint": {
|
|
1345
|
+
"en": "No files to lint",
|
|
1346
|
+
"zh": "没有需要检查的文件",
|
|
1347
|
+
"ja": "Lintするファイルがありません",
|
|
1348
|
+
"ar": "لا توجد ملفات للفحص",
|
|
1349
|
+
"ru": "Нет файлов для проверки",
|
|
1350
|
+
},
|
|
1351
|
+
"no_lint_errors_found": {
|
|
1352
|
+
"en": "No lint errors found",
|
|
1353
|
+
"zh": "未发现代码质量问题",
|
|
1354
|
+
"ja": "Lintエラーは見つかりませんでした",
|
|
1355
|
+
"ar": "لم يتم العثور على أخطاء فحص الكود",
|
|
1356
|
+
"ru": "Ошибки линтинга не найдены",
|
|
1357
|
+
},
|
|
1358
|
+
"lint_attempt_status": {
|
|
1359
|
+
"en": "Lint attempt {{attempt}}/{{max_correction_attempts}}: {{error_count}} errors found. {{ formatted_issues }}",
|
|
1360
|
+
"zh": "代码质量检查尝试 {{attempt}}/{{max_correction_attempts}}: 发现 {{error_count}} 个错误. {{ formatted_issues }}",
|
|
1361
|
+
"ja": "Lint試行 {{attempt}}/{{max_correction_attempts}}: {{error_count}} 個のエラーが見つかりました. {{ formatted_issues }}",
|
|
1362
|
+
"ar": "محاولة فحص الكود {{attempt}}/{{max_correction_attempts}}: تم العثور على {{error_count}} أخطاء. {{ formatted_issues }}",
|
|
1363
|
+
"ru": "Попытка линтинга {{attempt}}/{{max_correction_attempts}}: найдено {{error_count}} ошибок. {{ formatted_issues }}",
|
|
1364
|
+
},
|
|
1365
|
+
"max_attempts_reached": {
|
|
1366
|
+
"en": "Maximum correction attempts reached",
|
|
1367
|
+
"zh": "已达到最大修复尝试次数",
|
|
1368
|
+
"ja": "最大修正試行回数に達しました",
|
|
1369
|
+
"ar": "تم الوصول إلى أقصى عدد محاولات التصحيح",
|
|
1370
|
+
"ru": "Достигнуто максимальное количество попыток исправления",
|
|
1371
|
+
},
|
|
1372
|
+
"compile_success": {
|
|
1373
|
+
"en": "Compile success",
|
|
1374
|
+
"zh": "编译成功",
|
|
1375
|
+
"ja": "コンパイル成功",
|
|
1376
|
+
"ar": "نجح التجميع",
|
|
1377
|
+
"ru": "Компиляция успешна",
|
|
1378
|
+
},
|
|
1379
|
+
"compile_failed": {
|
|
1380
|
+
"en": "Compile failed",
|
|
1381
|
+
"zh": "编译失败",
|
|
1382
|
+
"ja": "コンパイル失敗",
|
|
1383
|
+
"ar": "فشل التجميع",
|
|
1384
|
+
"ru": "Компиляция не удалась",
|
|
1385
|
+
},
|
|
1386
|
+
"compile_attempt_status": {
|
|
1387
|
+
"en": "Compile attempt {{attempt}}/{{max_correction_attempts}}: {{error_count}} errors found. {{ formatted_issues }}",
|
|
1388
|
+
"zh": "编译尝试 {{attempt}}/{{max_correction_attempts}}: 发现 {{error_count}} 个错误. {{ formatted_issues }}",
|
|
1389
|
+
"ja": "コンパイル試行 {{attempt}}/{{max_correction_attempts}}: {{error_count}} 個のエラーが見つかりました. {{ formatted_issues }}",
|
|
1390
|
+
"ar": "محاولة التجميع {{attempt}}/{{max_correction_attempts}}: تم العثور على {{error_count}} أخطاء. {{ formatted_issues }}",
|
|
1391
|
+
"ru": "Попытка компиляции {{attempt}}/{{max_correction_attempts}}: найдено {{error_count}} ошибок. {{ formatted_issues }}",
|
|
1392
|
+
},
|
|
1393
|
+
"max_compile_attempts_reached": {
|
|
1394
|
+
"en": "Maximum compilation attempts reached",
|
|
1395
|
+
"zh": "已达到最大编译尝试次数",
|
|
1396
|
+
"ja": "最大コンパイル試行回数に達しました",
|
|
1397
|
+
"ar": "تم الوصول إلى أقصى عدد محاولات التجميع",
|
|
1398
|
+
"ru": "Достигнуто максимальное количество попыток компиляции",
|
|
1399
|
+
},
|
|
1400
|
+
"unmerged_blocks_fixed": {
|
|
1401
|
+
"en": "Unmerged blocks fixed successfully",
|
|
1402
|
+
"zh": "未合并代码块已成功修复",
|
|
1403
|
+
"ja": "マージされていないブロックが正常に修正されました",
|
|
1404
|
+
"ar": "تم إصلاح الكتل غير المدموجة بنجاح",
|
|
1405
|
+
"ru": "Неслитые блоки успешно исправлены",
|
|
1406
|
+
},
|
|
1407
|
+
"unmerged_blocks_attempt_status": {
|
|
1408
|
+
"en": "Fixing unmerged blocks attempt {{attempt}}/{{max_correction_attempts}}",
|
|
1409
|
+
"zh": "正在尝试修复未合并代码块 {{attempt}}/{{max_correction_attempts}}",
|
|
1410
|
+
"ja": "マージされていないブロックの修正試行 {{attempt}}/{{max_correction_attempts}}",
|
|
1411
|
+
"ar": "محاولة إصلاح الكتل غير المدموجة {{attempt}}/{{max_correction_attempts}}",
|
|
1412
|
+
"ru": "Попытка исправления неслитых блоков {{attempt}}/{{max_correction_attempts}}",
|
|
1413
|
+
},
|
|
1414
|
+
"max_unmerged_blocks_attempts_reached": {
|
|
1415
|
+
"en": "Maximum unmerged blocks fix attempts reached",
|
|
1416
|
+
"zh": "已达到最大未合并代码块修复尝试次数",
|
|
1417
|
+
"ja": "マージされていないブロックの修正の最大試行回数に達しました",
|
|
1418
|
+
"ar": "تم الوصول إلى أقصى عدد محاولات إصلاح الكتل غير المدموجة",
|
|
1419
|
+
"ru": "Достигнуто максимальное количество попыток исправления неслитых блоков",
|
|
1420
|
+
},
|
|
1421
|
+
"agenticFilterContext": {
|
|
1422
|
+
"en": "Start to find context...",
|
|
1423
|
+
"zh": "开始智能查找上下文....",
|
|
1424
|
+
"ja": "コンテキストの検索を開始...",
|
|
1425
|
+
"ar": "بدء البحث عن السياق...",
|
|
1426
|
+
"ru": "Начинаем поиск контекста...",
|
|
1427
|
+
},
|
|
1428
|
+
"agenticFilterContextFinished": {
|
|
1429
|
+
"en": "End to find context...",
|
|
1430
|
+
"zh": "结束智能查找上下文....",
|
|
1431
|
+
"ja": "コンテキストの検索を終了...",
|
|
1432
|
+
"ar": "انتهاء البحث عن السياق...",
|
|
1433
|
+
"ru": "Завершение поиска контекста...",
|
|
1434
|
+
},
|
|
1435
|
+
"/context/check/start": {
|
|
1436
|
+
"en": "Starting missing context checking process.",
|
|
1437
|
+
"zh": "开始缺失上下文检查过程.",
|
|
1438
|
+
"ja": "不足しているコンテキストの確認プロセスを開始します。",
|
|
1439
|
+
"ar": "بدء عملية فحص السياق المفقود.",
|
|
1440
|
+
"ru": "Начинается процесс проверки отсутствующего контекста.",
|
|
1441
|
+
},
|
|
1442
|
+
"/context/check/end": {
|
|
1443
|
+
"en": "Finished missing context checking process.",
|
|
1444
|
+
"zh": "结束缺失上下文检查过程.",
|
|
1445
|
+
"ja": "不足しているコンテキストの確認プロセスが完了しました。",
|
|
1446
|
+
"ar": "انتهت عملية فحص السياق المفقود.",
|
|
1447
|
+
"ru": "Процесс проверки отсутствующего контекста завершен.",
|
|
1448
|
+
},
|
|
1449
|
+
"/unmerged_blocks/check/start": {
|
|
1450
|
+
"en": "Starting unmerged blocks checking process.",
|
|
1451
|
+
"zh": "开始未合并代码检查过程.",
|
|
1452
|
+
"ja": "マージされていないブロックの確認プロセスを開始します。",
|
|
1453
|
+
"ar": "بدء عملية فحص الكتل غير المدموجة.",
|
|
1454
|
+
"ru": "Начинается процесс проверки неслитых блоков.",
|
|
1455
|
+
},
|
|
1456
|
+
"/unmerged_blocks/check/end": {
|
|
1457
|
+
"en": "Finished unmerged blocks checking process.",
|
|
1458
|
+
"zh": "结束未合并代码检查过程.",
|
|
1459
|
+
"ja": "マージされていないブロックの確認プロセスが完了しました。",
|
|
1460
|
+
"ar": "انتهت عملية فحص الكتل غير المدموجة.",
|
|
1461
|
+
"ru": "Процесс проверки неслитых блоков завершен.",
|
|
1462
|
+
},
|
|
1463
|
+
"/lint/check/start": {
|
|
1464
|
+
"en": "Starting lint error checking process.",
|
|
1465
|
+
"zh": "开始代码质量检查过程.",
|
|
1466
|
+
"ja": "Lintエラーの確認プロセスを開始します。",
|
|
1467
|
+
"ar": "بدء عملية فحص أخطاء الكود.",
|
|
1468
|
+
"ru": "Начинается процесс проверки ошибок линтинга.",
|
|
1469
|
+
},
|
|
1470
|
+
"/lint/check/end": {
|
|
1471
|
+
"en": "Finished lint error checking process.",
|
|
1472
|
+
"zh": "结束代码质量检查过程.",
|
|
1473
|
+
"ja": "Lintエラーの確認プロセスが完了しました。",
|
|
1474
|
+
"ar": "انتهت عملية فحص أخطاء الكود.",
|
|
1475
|
+
"ru": "Процесс проверки ошибок линтинга завершен.",
|
|
1476
|
+
},
|
|
1477
|
+
"/compile/check/start": {
|
|
1478
|
+
"en": "Starting compile error checking process.",
|
|
1479
|
+
"zh": "开始编译错误检查过程.",
|
|
1480
|
+
"ja": "コンパイルエラーの確認プロセスを開始します。",
|
|
1481
|
+
"ar": "بدء عملية فحص أخطاء التجميع.",
|
|
1482
|
+
"ru": "Начинается процесс проверки ошибок компиляции.",
|
|
1483
|
+
},
|
|
1484
|
+
"/compile/check/end": {
|
|
1485
|
+
"en": "Finished compile error checking process.",
|
|
1486
|
+
"zh": "结束编译错误检查过程.",
|
|
1487
|
+
"ja": "コンパイルエラーの確認プロセスが完了しました。",
|
|
1488
|
+
"ar": "انتهت عملية فحص أخطاء التجميع.",
|
|
1489
|
+
"ru": "Процесс проверки ошибок компиляции завершен.",
|
|
1490
|
+
},
|
|
1491
|
+
"/agent/edit/objective": {
|
|
1492
|
+
"en": "Objective",
|
|
1493
|
+
"zh": "目标",
|
|
1494
|
+
"ja": "目的",
|
|
1495
|
+
"ar": "الهدف",
|
|
1496
|
+
"ru": "Цель",
|
|
1497
|
+
},
|
|
1498
|
+
"/agent/edit/user_query": {
|
|
1499
|
+
"en": "User Query",
|
|
1500
|
+
"zh": "用户查询",
|
|
1501
|
+
"ja": "ユーザークエリ",
|
|
1502
|
+
"ar": "استعلام المستخدم",
|
|
1503
|
+
"ru": "Запрос пользователя",
|
|
1504
|
+
},
|
|
1505
|
+
"/agent/edit/apply_pre_changes": {
|
|
1506
|
+
"en": "Commit user changes",
|
|
1507
|
+
"zh": "检查用户是否有手动修改(如有,会自动提交)...",
|
|
1508
|
+
"ja": "ユーザーの変更をコミット",
|
|
1509
|
+
"ar": "تأكيد تغييرات المستخدم",
|
|
1510
|
+
"ru": "Подтверждение изменений пользователя",
|
|
1511
|
+
},
|
|
1512
|
+
"/agent/edit/apply_changes": {
|
|
1513
|
+
"en": "Commit the changes in preview steps",
|
|
1514
|
+
"zh": "提交前面步骤的修改",
|
|
1515
|
+
"ja": "プレビューステップの変更をコミット",
|
|
1516
|
+
"ar": "تأكيد التغييرات في خطوات المعاينة",
|
|
1517
|
+
"ru": "Подтверждение изменений на этапах предварительного просмотра",
|
|
1518
|
+
},
|
|
1519
|
+
"/agent/edit/pull_request/branch_name_failed": {
|
|
1520
|
+
"en": "Unable to get current branch name, skipping PR creation",
|
|
1521
|
+
"zh": "无法获取当前分支名,跳过 PR 创建",
|
|
1522
|
+
"ja": "現在のブランチ名を取得できません、PR作成をスキップします",
|
|
1523
|
+
"ar": "غير قادر على الحصول على اسم الفرع الحالي، تخطي إنشاء PR",
|
|
1524
|
+
"ru": "Невозможно получить имя текущей ветки, пропускаем создание PR",
|
|
1525
|
+
},
|
|
1526
|
+
"/agent/edit/pull_request/title": {
|
|
1527
|
+
"en": "AutoCoder: {{query}}",
|
|
1528
|
+
"zh": "AutoCoder: {{query}}",
|
|
1529
|
+
"ja": "AutoCoder: {{query}}",
|
|
1530
|
+
"ar": "AutoCoder: {{query}}",
|
|
1531
|
+
"ru": "AutoCoder: {{query}}",
|
|
1532
|
+
},
|
|
1533
|
+
"/agent/edit/pull_request/default_query": {
|
|
1534
|
+
"en": "Code auto generation",
|
|
1535
|
+
"zh": "代码自动生成",
|
|
1536
|
+
"ja": "コード自動生成",
|
|
1537
|
+
"ar": "توليد الكود التلقائي",
|
|
1538
|
+
"ru": "Автоматическая генерация кода",
|
|
1539
|
+
},
|
|
1540
|
+
"/agent/edit/pull_request/description": {
|
|
1541
|
+
"en": """## 🤖 AutoCoder Generated Pull Request
|
|
1542
|
+
|
|
1543
|
+
**Task Description**: {{query}}
|
|
1544
|
+
|
|
1545
|
+
### 📝 Change Summary
|
|
1546
|
+
- Modified {{file_count}} files
|
|
1547
|
+
- Commit Hash: `{{commit_hash}}`
|
|
1548
|
+
|
|
1549
|
+
### 📂 Changed Files List
|
|
1550
|
+
{{file_list}}
|
|
1551
|
+
|
|
1552
|
+
### ⚙️ Generation Configuration
|
|
1553
|
+
- Source Branch: `{{source_branch}}`
|
|
1554
|
+
- Target Branch: `{{target_branch}}`
|
|
1555
|
+
- Auto-generated Time: {{timestamp}}
|
|
1556
|
+
|
|
1557
|
+
### 🔍 Next Steps
|
|
1558
|
+
- [ ] Code Review
|
|
1559
|
+
- [ ] Test Verification
|
|
1560
|
+
- [ ] Merge to Main Branch
|
|
1561
|
+
|
|
1562
|
+
---
|
|
1563
|
+
*This PR was automatically created by AutoCoder*
|
|
1564
|
+
""",
|
|
1565
|
+
"zh": """## 🤖 AutoCoder 自动生成的 Pull Request
|
|
1566
|
+
|
|
1567
|
+
**任务描述**: {{query}}
|
|
1568
|
+
|
|
1569
|
+
### 📝 变更摘要
|
|
1570
|
+
- 共修改 {{file_count}} 个文件
|
|
1571
|
+
- 提交哈希: `{{commit_hash}}`
|
|
1572
|
+
|
|
1573
|
+
### 📂 变更文件列表
|
|
1574
|
+
{{file_list}}
|
|
1575
|
+
|
|
1576
|
+
### ⚙️ 生成配置
|
|
1577
|
+
- 源分支: `{{source_branch}}`
|
|
1578
|
+
- 目标分支: `{{target_branch}}`
|
|
1579
|
+
- 自动生成时间: {{timestamp}}
|
|
1580
|
+
|
|
1581
|
+
### 🔍 下一步
|
|
1582
|
+
- [ ] 代码审查
|
|
1583
|
+
- [ ] 测试验证
|
|
1584
|
+
- [ ] 合并到主分支
|
|
1585
|
+
|
|
1586
|
+
---
|
|
1587
|
+
*此 PR 由 AutoCoder 自动创建*
|
|
1588
|
+
""",
|
|
1589
|
+
"ja": """## 🤖 AutoCoder 生成プルリクエスト
|
|
1590
|
+
|
|
1591
|
+
**タスク説明**: {{query}}
|
|
1592
|
+
|
|
1593
|
+
### 📝 変更概要
|
|
1594
|
+
- {{file_count}} ファイルを変更
|
|
1595
|
+
- コミットハッシュ: `{{commit_hash}}`
|
|
1596
|
+
|
|
1597
|
+
### 📂 変更ファイルリスト
|
|
1598
|
+
{{file_list}}
|
|
1599
|
+
|
|
1600
|
+
### ⚙️ 生成設定
|
|
1601
|
+
- ソースブランチ: `{{source_branch}}`
|
|
1602
|
+
- ターゲットブランチ: `{{target_branch}}`
|
|
1603
|
+
- 自動生成時間: {{timestamp}}
|
|
1604
|
+
|
|
1605
|
+
### 🔍 次のステップ
|
|
1606
|
+
- [ ] コードレビュー
|
|
1607
|
+
- [ ] テスト検証
|
|
1608
|
+
- [ ] メインブランチにマージ
|
|
1609
|
+
|
|
1610
|
+
---
|
|
1611
|
+
*このPRはAutoCoderによって自動作成されました*
|
|
1612
|
+
""",
|
|
1613
|
+
"ar": """## 🤖 طلب سحب تم إنشاؤه بواسطة AutoCoder
|
|
1614
|
+
|
|
1615
|
+
**وصف المهمة**: {{query}}
|
|
1616
|
+
|
|
1617
|
+
### 📝 ملخص التغييرات
|
|
1618
|
+
- تم تعديل {{file_count}} ملف
|
|
1619
|
+
- هاش الكوميت: `{{commit_hash}}`
|
|
1620
|
+
|
|
1621
|
+
### 📂 قائمة الملفات المتغيرة
|
|
1622
|
+
{{file_list}}
|
|
1623
|
+
|
|
1624
|
+
### ⚙️ تكوين التوليد
|
|
1625
|
+
- الفرع المصدر: `{{source_branch}}`
|
|
1626
|
+
- الفرع الهدف: `{{target_branch}}`
|
|
1627
|
+
- وقت التوليد التلقائي: {{timestamp}}
|
|
1628
|
+
|
|
1629
|
+
### 🔍 الخطوات التالية
|
|
1630
|
+
- [ ] مراجعة الكود
|
|
1631
|
+
- [ ] التحقق من الاختبار
|
|
1632
|
+
- [ ] الدمج في الفرع الرئيسي
|
|
1633
|
+
|
|
1634
|
+
---
|
|
1635
|
+
*تم إنشاء هذا PR تلقائياً بواسطة AutoCoder*
|
|
1636
|
+
""",
|
|
1637
|
+
"ru": """## 🤖 Pull Request, созданный AutoCoder
|
|
1638
|
+
|
|
1639
|
+
**Описание задачи**: {{query}}
|
|
1640
|
+
|
|
1641
|
+
### 📝 Сводка изменений
|
|
1642
|
+
- Изменено {{file_count}} файлов
|
|
1643
|
+
- Хеш коммита: `{{commit_hash}}`
|
|
1644
|
+
|
|
1645
|
+
### 📂 Список измененных файлов
|
|
1646
|
+
{{file_list}}
|
|
1647
|
+
|
|
1648
|
+
### ⚙️ Конфигурация генерации
|
|
1649
|
+
- Исходная ветка: `{{source_branch}}`
|
|
1650
|
+
- Целевая ветка: `{{target_branch}}`
|
|
1651
|
+
- Время автогенерации: {{timestamp}}
|
|
1652
|
+
|
|
1653
|
+
### 🔍 Следующие шаги
|
|
1654
|
+
- [ ] Ревью кода
|
|
1655
|
+
- [ ] Проверка тестов
|
|
1656
|
+
- [ ] Слияние в основную ветку
|
|
1657
|
+
|
|
1658
|
+
---
|
|
1659
|
+
*Этот PR был автоматически создан AutoCoder*
|
|
1660
|
+
""",
|
|
1661
|
+
},
|
|
1662
|
+
"/agent/edit/pull_request/creating": {
|
|
1663
|
+
"en": "Creating Pull Request: {{title}}",
|
|
1664
|
+
"zh": "正在创建 Pull Request: {{title}}",
|
|
1665
|
+
"ja": "プルリクエストを作成中: {{title}}",
|
|
1666
|
+
"ar": "إنشاء طلب السحب: {{title}}",
|
|
1667
|
+
"ru": "Создание Pull Request: {{title}}",
|
|
1668
|
+
},
|
|
1669
|
+
"/agent/edit/pull_request/success": {
|
|
1670
|
+
"en": "✅ Pull Request created successfully",
|
|
1671
|
+
"zh": "✅ Pull Request 创建成功",
|
|
1672
|
+
"ja": "✅ プルリクエストが正常に作成されました",
|
|
1673
|
+
"ar": "✅ تم إنشاء طلب السحب بنجاح",
|
|
1674
|
+
"ru": "✅ Pull Request успешно создан",
|
|
1675
|
+
},
|
|
1676
|
+
"/agent/edit/pull_request/failed": {
|
|
1677
|
+
"en": "❌ Pull Request creation failed: {{error}}",
|
|
1678
|
+
"zh": "❌ Pull Request 创建失败: {{error}}",
|
|
1679
|
+
"ja": "❌ プルリクエストの作成に失敗しました: {{error}}",
|
|
1680
|
+
"ar": "❌ فشل إنشاء طلب السحب: {{error}}",
|
|
1681
|
+
"ru": "❌ Создание Pull Request не удалось: {{error}}",
|
|
1682
|
+
},
|
|
1683
|
+
"/agent/edit/pull_request/exception": {
|
|
1684
|
+
"en": "❌ Exception occurred while creating Pull Request: {{error}}",
|
|
1685
|
+
"zh": "❌ 创建 Pull Request 时发生异常: {{error}}",
|
|
1686
|
+
"ja": "❌ プルリクエスト作成中に例外が発生しました: {{error}}",
|
|
1687
|
+
"ar": "❌ حدث استثناء أثناء إنشاء طلب السحب: {{error}}",
|
|
1688
|
+
"ru": "❌ Исключение при создании Pull Request: {{error}}",
|
|
1689
|
+
},
|
|
1690
|
+
"replace_in_file.access_denied": {
|
|
1691
|
+
"en": "Error: Access denied. Attempted to modify file outside the project directory: {{file_path}}",
|
|
1692
|
+
"zh": "错误:拒绝访问。尝试修改项目目录之外的文件:{{file_path}}",
|
|
1693
|
+
"ja": "エラー:アクセス拒否。プロジェクトディレクトリ外のファイルを変更しようとしました:{{file_path}}",
|
|
1694
|
+
"ar": "خطأ: تم رفض الوصول. محاولة تعديل ملف خارج مجلد المشروع: {{file_path}}",
|
|
1695
|
+
"ru": "Ошибка: Доступ запрещен. Попытка изменить файл вне директории проекта: {{file_path}}",
|
|
1696
|
+
},
|
|
1697
|
+
"replace_in_file.file_not_found": {
|
|
1698
|
+
"en": "Error: File not found at path: {{file_path}}",
|
|
1699
|
+
"zh": "错误:未找到文件路径:{{file_path}}",
|
|
1700
|
+
"ja": "エラー:パス {{file_path}} でファイルが見つかりません",
|
|
1701
|
+
"ar": "خطأ: لم يتم العثور على الملف في المسار: {{file_path}}",
|
|
1702
|
+
"ru": "Ошибка: Файл не найден по пути: {{file_path}}",
|
|
1703
|
+
},
|
|
1704
|
+
"replace_in_file.read_error": {
|
|
1705
|
+
"en": "An error occurred while reading the file for replacement: {{error}}",
|
|
1706
|
+
"zh": "读取待替换文件时发生错误:{{error}}",
|
|
1707
|
+
"ja": "置換用ファイルの読み取り中にエラーが発生しました:{{error}}",
|
|
1708
|
+
"ar": "حدث خطأ أثناء قراءة الملف للاستبدال: {{error}}",
|
|
1709
|
+
"ru": "Ошибка при чтении файла для замены: {{error}}",
|
|
1710
|
+
},
|
|
1711
|
+
"replace_in_file.no_valid_blocks": {
|
|
1712
|
+
"en": "Error: No valid SEARCH/REPLACE blocks found in the provided diff.",
|
|
1713
|
+
"zh": "错误:在提供的diff中未找到有效的SEARCH/REPLACE代码块。",
|
|
1714
|
+
"ja": "エラー:提供されたdiffで有効なSEARCH/REPLACEブロックが見つかりません。",
|
|
1715
|
+
"ar": "خطأ: لم يتم العثور على كتل SEARCH/REPLACE صالحة في الفرق المقدم.",
|
|
1716
|
+
"ru": "Ошибка: В предоставленном diff не найдены действительные блоки SEARCH/REPLACE.",
|
|
1717
|
+
},
|
|
1718
|
+
"replace_in_file.apply_failed": {
|
|
1719
|
+
"en": "Failed to apply any changes. Errors:\n{{errors}}",
|
|
1720
|
+
"zh": "未能应用任何更改。错误信息:\n{{errors}}",
|
|
1721
|
+
"ja": "変更の適用に失敗しました。エラー:\n{{errors}}",
|
|
1722
|
+
"ar": "فشل في تطبيق أي تغييرات. الأخطاء:\n{{errors}}",
|
|
1723
|
+
"ru": "Не удалось применить изменения. Ошибки:\n{{errors}}",
|
|
1724
|
+
},
|
|
1725
|
+
"replace_in_file.apply_success": {
|
|
1726
|
+
"en": "Successfully applied {{applied}}/{{total}} changes to file: {{file_path}}.",
|
|
1727
|
+
"zh": "成功应用了 {{applied}}/{{total}} 个更改到文件:{{file_path}}。",
|
|
1728
|
+
"ja": "ファイル {{file_path}} に {{applied}}/{{total}} 個の変更を正常に適用しました。",
|
|
1729
|
+
"ar": "تم تطبيق {{applied}}/{{total}} تغييرات بنجاح على الملف: {{file_path}}。",
|
|
1730
|
+
"ru": "Успешно применено {{applied}}/{{total}} изменений к файлу: {{file_path}}.",
|
|
1731
|
+
},
|
|
1732
|
+
"replace_in_file.apply_success_with_warnings": {
|
|
1733
|
+
"en": "Successfully applied {{applied}}/{{total}} changes to file: {{file_path}}.\nWarnings:\n{{errors}}",
|
|
1734
|
+
"zh": "成功应用了 {{applied}}/{{total}} 个更改到文件:{{file_path}}。\n警告信息:\n{{errors}}",
|
|
1735
|
+
"ja": "ファイル {{file_path}} に {{applied}}/{{total}} 個の変更を正常に適用しました。\n警告:\n{{errors}}",
|
|
1736
|
+
"ar": "تم تطبيق {{applied}}/{{total}} تغييرات بنجاح على الملف: {{file_path}}。\nتحذيرات:\n{{errors}}",
|
|
1737
|
+
"ru": "Успешно применено {{applied}}/{{total}} изменений к файлу: {{file_path}}.\nПредупреждения:\n{{errors}}",
|
|
1738
|
+
},
|
|
1739
|
+
"replace_in_file.write_error": {
|
|
1740
|
+
"en": "An error occurred while writing the modified file: {{error}}",
|
|
1741
|
+
"zh": "写入修改后的文件时发生错误:{{error}}",
|
|
1742
|
+
"ja": "変更されたファイルの書き込み中にエラーが発生しました:{{error}}",
|
|
1743
|
+
"ar": "حدث خطأ أثناء كتابة الملف المعدل: {{error}}",
|
|
1744
|
+
"ru": "Ошибка при записи измененного файла: {{error}}",
|
|
1745
|
+
},
|
|
1746
|
+
"mcp_install_success": {
|
|
1747
|
+
"en": "✅ MCP server installed successfully: {{result}}",
|
|
1748
|
+
"zh": "✅ MCP 服务器安装成功: {{result}}",
|
|
1749
|
+
"ja": "✅ MCPサーバーのインストールが成功しました: {{result}}",
|
|
1750
|
+
"ar": "✅ تم تثبيت خادم MCP بنجاح: {{result}}",
|
|
1751
|
+
"ru": "✅ MCP сервер успешно установлен: {{result}}",
|
|
1752
|
+
},
|
|
1753
|
+
"mcp_install_error": {
|
|
1754
|
+
"en": "❌ MCP server installation failed: {{error}}",
|
|
1755
|
+
"zh": "❌ MCP 服务器安装失败: {{error}}",
|
|
1756
|
+
"ja": "❌ MCPサーバーのインストールに失敗しました: {{error}}",
|
|
1757
|
+
"ar": "❌ فشل تثبيت خادم MCP: {{error}}",
|
|
1758
|
+
"ru": "❌ Установка MCP сервера не удалась: {{error}}",
|
|
1759
|
+
},
|
|
1760
|
+
"mcp_remove_success": {
|
|
1761
|
+
"en": "✅ MCP server removed successfully: {{result}}",
|
|
1762
|
+
"zh": "✅ MCP 服务器移除成功: {{result}}",
|
|
1763
|
+
"ja": "✅ MCPサーバーの削除が成功しました: {{result}}",
|
|
1764
|
+
"ar": "✅ تم إزالة خادم MCP بنجاح: {{result}}",
|
|
1765
|
+
"ru": "✅ MCP сервер успешно удален: {{result}}",
|
|
1766
|
+
},
|
|
1767
|
+
"mcp_remove_error": {
|
|
1768
|
+
"en": "❌ MCP server removal failed: {{error}}",
|
|
1769
|
+
"zh": "❌ MCP 服务器移除失败: {{error}}",
|
|
1770
|
+
"ja": "❌ MCPサーバーの削除に失敗しました: {{error}}",
|
|
1771
|
+
"ar": "❌ فشل إزالة خادم MCP: {{error}}",
|
|
1772
|
+
"ru": "❌ Удаление MCP сервера не удалось: {{error}}",
|
|
1773
|
+
},
|
|
1774
|
+
"mcp_list_builtin_title": {
|
|
1775
|
+
"en": "📦 Built-in MCP Servers:",
|
|
1776
|
+
"zh": "📦 内置 MCP 服务器:",
|
|
1777
|
+
"ja": "📦 内蔵MCPサーバー:",
|
|
1778
|
+
"ar": "📦 خوادم MCP المدمجة:",
|
|
1779
|
+
"ru": "📦 Встроенные MCP серверы:",
|
|
1780
|
+
},
|
|
1781
|
+
"mcp_list_external_title": {
|
|
1782
|
+
"en": "🌐 External MCP Servers:",
|
|
1783
|
+
"zh": "🌐 外部 MCP 服务器:",
|
|
1784
|
+
"ja": "🌐 外部MCPサーバー:",
|
|
1785
|
+
"ar": "🌐 خوادم MCP الخارجية:",
|
|
1786
|
+
"ru": "🌐 Внешние MCP серверы:",
|
|
1787
|
+
},
|
|
1788
|
+
"mcp_list_marketplace_title": {
|
|
1789
|
+
"en": "🛍️ Marketplace MCP Servers:",
|
|
1790
|
+
"zh": "🛍️ 市场 MCP 服务器:",
|
|
1791
|
+
"ja": "🛍️ マーケットプレイスMCPサーバー:",
|
|
1792
|
+
"ar": "🛍️ خوادم MCP في السوق:",
|
|
1793
|
+
"ru": "🛍️ MCP серверы из маркетплейса:",
|
|
1794
|
+
},
|
|
1795
|
+
"mcp_list_builtin_error": {
|
|
1796
|
+
"en": "❌ Failed to list MCP servers: {{error}}",
|
|
1797
|
+
"zh": "❌ 获取 MCP 服务器列表失败: {{error}}",
|
|
1798
|
+
"ja": "❌ MCPサーバーのリスト取得に失敗しました: {{error}}",
|
|
1799
|
+
"ar": "❌ فشل في إدراج خوادم MCP: {{error}}",
|
|
1800
|
+
"ru": "❌ Не удалось получить список MCP серверов: {{error}}",
|
|
1801
|
+
},
|
|
1802
|
+
"mcp_list_running_error": {
|
|
1803
|
+
"en": "❌ Failed to list running MCP servers: {{error}}",
|
|
1804
|
+
"zh": "❌ 获取运行中的 MCP 服务器列表失败: {{error}}",
|
|
1805
|
+
"ja": "❌ 実行中のMCPサーバーのリスト取得に失敗しました: {{error}}",
|
|
1806
|
+
"ar": "❌ فشل في إدراج خوادم MCP قيد التشغيل: {{error}}",
|
|
1807
|
+
"ru": "❌ Не удалось получить список работающих MCP серверов: {{error}}",
|
|
1808
|
+
},
|
|
1809
|
+
"mcp_refresh_success": {
|
|
1810
|
+
"en": "✅ MCP servers refreshed successfully",
|
|
1811
|
+
"zh": "✅ MCP 服务器刷新成功",
|
|
1812
|
+
"ja": "✅ MCPサーバーの更新が成功しました",
|
|
1813
|
+
"ar": "✅ تم تحديث خوادم MCP بنجاح",
|
|
1814
|
+
"ru": "✅ MCP серверы успешно обновлены",
|
|
1815
|
+
},
|
|
1816
|
+
"mcp_refresh_error": {
|
|
1817
|
+
"en": "❌ MCP servers refresh failed: {{error}}",
|
|
1818
|
+
"zh": "❌ MCP 服务器刷新失败: {{error}}",
|
|
1819
|
+
"ja": "❌ MCPサーバーの更新に失敗しました: {{error}}",
|
|
1820
|
+
"ar": "❌ فشل تحديث خوادم MCP: {{error}}",
|
|
1821
|
+
"ru": "❌ Обновление MCP серверов не удалось: {{error}}",
|
|
1822
|
+
},
|
|
1823
|
+
"mcp_query_empty": {
|
|
1824
|
+
"en": "⚠️ Query cannot be empty",
|
|
1825
|
+
"zh": "⚠️ 查询不能为空",
|
|
1826
|
+
"ja": "⚠️ クエリは空にできません",
|
|
1827
|
+
"ar": "⚠️ لا يمكن أن يكون الاستعلام فارغاً",
|
|
1828
|
+
"ru": "⚠️ Запрос не может быть пустым",
|
|
1829
|
+
},
|
|
1830
|
+
"mcp_error_title": {
|
|
1831
|
+
"en": "❌ MCP Error",
|
|
1832
|
+
"zh": "❌ MCP 错误",
|
|
1833
|
+
"ja": "❌ MCPエラー",
|
|
1834
|
+
"ar": "❌ خطأ MCP",
|
|
1835
|
+
"ru": "❌ Ошибка MCP",
|
|
1836
|
+
},
|
|
1837
|
+
"mcp_response_title": {
|
|
1838
|
+
"en": "✅ MCP Response:",
|
|
1839
|
+
"zh": "✅ MCP 响应:",
|
|
1840
|
+
"ja": "✅ MCP レスポンス:",
|
|
1841
|
+
"ar": "✅ استجابة MCP:",
|
|
1842
|
+
"ru": "✅ Ответ MCP:",
|
|
1843
|
+
},
|
|
1844
|
+
"marketplace_add_success": {
|
|
1845
|
+
"en": "✅ Marketplace item added successfully: {{name}}",
|
|
1846
|
+
"zh": "✅ 市场项目添加成功: {{name}}",
|
|
1847
|
+
"ja": "✅ マーケットプレイスアイテムが正常に追加されました: {{name}}",
|
|
1848
|
+
"ar": "✅ تم إضافة عنصر السوق بنجاح: {{name}}",
|
|
1849
|
+
"ru": "✅ Элемент маркетплейса успешно добавлен: {{name}}",
|
|
1850
|
+
},
|
|
1851
|
+
"marketplace_add_error": {
|
|
1852
|
+
"en": "❌ Failed to add marketplace item {{name}}: {{error}}",
|
|
1853
|
+
"zh": "❌ 添加市场项目 {{name}} 失败: {{error}}",
|
|
1854
|
+
"ja": "❌ マーケットプレイスアイテム {{name}} の追加に失敗しました: {{error}}",
|
|
1855
|
+
"ar": "❌ فشل في إضافة عنصر السوق {{name}}: {{error}}",
|
|
1856
|
+
"ru": "❌ Не удалось добавить элемент маркетплейса {{name}}: {{error}}",
|
|
1857
|
+
},
|
|
1858
|
+
"marketplace_update_success": {
|
|
1859
|
+
"en": "✅ Marketplace item updated successfully: {{name}}",
|
|
1860
|
+
"zh": "✅ 市场项目更新成功: {{name}}",
|
|
1861
|
+
"ja": "✅ マーケットプレイスアイテムが正常に更新されました: {{name}}",
|
|
1862
|
+
"ar": "✅ تم تحديث عنصر السوق بنجاح: {{name}}",
|
|
1863
|
+
"ru": "✅ Элемент маркетплейса успешно обновлен: {{name}}",
|
|
1864
|
+
},
|
|
1865
|
+
"marketplace_update_error": {
|
|
1866
|
+
"en": "❌ Failed to update marketplace item {{name}}: {{error}}",
|
|
1867
|
+
"zh": "❌ 更新市场项目 {{name}} 失败: {{error}}",
|
|
1868
|
+
"ja": "❌ マーケットプレイスアイテム {{name}} の更新に失敗しました: {{error}}",
|
|
1869
|
+
"ar": "❌ فشل في تحديث عنصر السوق {{name}}: {{error}}",
|
|
1870
|
+
"ru": "❌ Не удалось обновить элемент маркетплейса {{name}}: {{error}}",
|
|
1871
|
+
},
|
|
1872
|
+
"conversation_message_ids_invalid_action": {
|
|
1873
|
+
"en": "Invalid action type: {{action}}",
|
|
1874
|
+
"zh": "无效的操作类型: {{action}}",
|
|
1875
|
+
"ja": "無効なアクションタイプ: {{action}}",
|
|
1876
|
+
"ar": "نوع إجراء غير صحيح: {{action}}",
|
|
1877
|
+
"ru": "Неверный тип действия: {{action}}",
|
|
1878
|
+
},
|
|
1879
|
+
"conversation_message_ids_no_conversation": {
|
|
1880
|
+
"en": "Unable to get current conversation ID",
|
|
1881
|
+
"zh": "无法获取当前会话ID",
|
|
1882
|
+
"ja": "現在の会話IDを取得できません",
|
|
1883
|
+
"ar": "غير قادر على الحصول على معرف المحادثة الحالي",
|
|
1884
|
+
"ru": "Невозможно получить ID текущего разговора",
|
|
1885
|
+
},
|
|
1886
|
+
"conversation_message_ids_create_success": {
|
|
1887
|
+
"en": "Conversation message IDs configuration has been created",
|
|
1888
|
+
"zh": "会话消息ID配置已创建",
|
|
1889
|
+
"ja": "会話メッセージID設定が作成されました",
|
|
1890
|
+
"ar": "تم إنشاء تكوين معرفات رسائل المحادثة",
|
|
1891
|
+
"ru": "Конфигурация ID сообщений разговора создана",
|
|
1892
|
+
},
|
|
1893
|
+
"conversation_message_ids_create_failed": {
|
|
1894
|
+
"en": "Failed to create conversation message IDs configuration: {{error}}",
|
|
1895
|
+
"zh": "创建会话消息ID配置失败: {{error}}",
|
|
1896
|
+
"ja": "会話メッセージID設定の作成に失敗しました: {{error}}",
|
|
1897
|
+
"ar": "فشل في إنشاء تكوين معرفات رسائل المحادثة: {{error}}",
|
|
1898
|
+
"ru": "Не удалось создать конфигурацию ID сообщений разговора: {{error}}",
|
|
1899
|
+
},
|
|
1900
|
+
"conversation_message_ids_append_success": {
|
|
1901
|
+
"en": "Conversation message IDs configuration has been appended",
|
|
1902
|
+
"zh": "会话消息ID配置已追加",
|
|
1903
|
+
"ja": "会話メッセージID設定が追加されました",
|
|
1904
|
+
"ar": "تم إلحاق تكوين معرفات رسائل المحادثة",
|
|
1905
|
+
"ru": "Конфигурация ID сообщений разговора добавлена",
|
|
1906
|
+
},
|
|
1907
|
+
"conversation_message_ids_append_failed": {
|
|
1908
|
+
"en": "Failed to append conversation message IDs configuration: {{error}}",
|
|
1909
|
+
"zh": "追加会话消息ID配置失败: {{error}}",
|
|
1910
|
+
"ja": "会話メッセージID設定の追加に失敗しました: {{error}}",
|
|
1911
|
+
"ar": "فشل في إلحاق تكوين معرفات رسائل المحادثة: {{error}}",
|
|
1912
|
+
"ru": "Не удалось добавить конфигурацию ID сообщений разговора: {{error}}",
|
|
1913
|
+
},
|
|
1914
|
+
"conversation_message_ids_no_existing_config": {
|
|
1915
|
+
"en": "No existing message IDs configuration found",
|
|
1916
|
+
"zh": "没有找到现有的消息ID配置",
|
|
1917
|
+
"ja": "既存のメッセージID設定が見つかりません",
|
|
1918
|
+
"ar": "لم يتم العثور على تكوين معرفات الرسائل الموجود",
|
|
1919
|
+
"ru": "Не найдена существующая конфигурация ID сообщений",
|
|
1920
|
+
},
|
|
1921
|
+
"conversation_message_ids_delete_success": {
|
|
1922
|
+
"en": "Conversation message IDs configuration has been completely deleted",
|
|
1923
|
+
"zh": "会话消息ID配置已完全删除",
|
|
1924
|
+
"ja": "会話メッセージID設定が完全に削除されました",
|
|
1925
|
+
"ar": "تم حذف تكوين معرفات رسائل المحادثة بالكامل",
|
|
1926
|
+
"ru": "Конфигурация ID сообщений разговора полностью удалена",
|
|
1927
|
+
},
|
|
1928
|
+
"conversation_message_ids_delete_failed": {
|
|
1929
|
+
"en": "Failed to delete conversation message IDs configuration: {{error}}",
|
|
1930
|
+
"zh": "删除会话消息ID配置失败: {{error}}",
|
|
1931
|
+
"ja": "会話メッセージID設定の削除に失敗しました: {{error}}",
|
|
1932
|
+
"ar": "فشل في حذف تكوين معرفات رسائل المحادثة: {{error}}",
|
|
1933
|
+
"ru": "Не удалось удалить конфигурацию ID сообщений разговора: {{error}}",
|
|
1934
|
+
},
|
|
1935
|
+
"conversation_message_ids_update_success": {
|
|
1936
|
+
"en": "Conversation message IDs configuration has been updated",
|
|
1937
|
+
"zh": "会话消息ID配置已更新",
|
|
1938
|
+
"ja": "会話メッセージID設定が更新されました",
|
|
1939
|
+
"ar": "تم تحديث تكوين معرفات رسائل المحادثة",
|
|
1940
|
+
"ru": "Конфигурация ID сообщений разговора обновлена",
|
|
1941
|
+
},
|
|
1942
|
+
"conversation_message_ids_update_failed": {
|
|
1943
|
+
"en": "Failed to update conversation message IDs configuration: {{error}}",
|
|
1944
|
+
"zh": "更新会话消息ID配置失败: {{error}}",
|
|
1945
|
+
"ja": "会話メッセージID設定の更新に失敗しました: {{error}}",
|
|
1946
|
+
"ar": "فشل في تحديث تكوين معرفات رسائل المحادثة: {{error}}",
|
|
1947
|
+
"ru": "Не удалось обновить конфигурацию ID сообщений разговора: {{error}}",
|
|
1948
|
+
},
|
|
1949
|
+
"conversation_message_ids_operation_exception": {
|
|
1950
|
+
"en": "Exception occurred while operating conversation message IDs configuration: {{error}}",
|
|
1951
|
+
"zh": "操作会话消息ID配置时发生异常: {{error}}",
|
|
1952
|
+
"ja": "会話メッセージID設定の操作中に例外が発生しました: {{error}}",
|
|
1953
|
+
"ar": "حدث استثناء أثناء تشغيل تكوين معرفات رسائل المحادثة: {{error}}",
|
|
1954
|
+
"ru": "Исключение при работе с конфигурацией ID сообщений разговора: {{error}}",
|
|
1955
|
+
},
|
|
1956
|
+
"conversation_message_ids_invalid_format": {
|
|
1957
|
+
"en": "Invalid message ID format: {{message_id}}",
|
|
1958
|
+
"zh": "消息ID格式无效: {{message_id}}",
|
|
1959
|
+
"ja": "無効なメッセージID形式: {{message_id}}",
|
|
1960
|
+
"ar": "تنسيق معرف الرسالة غير صحيح: {{message_id}}",
|
|
1961
|
+
"ru": "Неверный формат ID сообщения: {{message_id}}",
|
|
1962
|
+
},
|
|
1963
|
+
"conf_key": {
|
|
1964
|
+
"en": "Key",
|
|
1965
|
+
"zh": "配置项",
|
|
1966
|
+
"ja": "キー",
|
|
1967
|
+
"ar": "المفتاح",
|
|
1968
|
+
"ru": "Ключ",
|
|
1969
|
+
},
|
|
1970
|
+
"conf_value": {
|
|
1971
|
+
"en": "Value",
|
|
1972
|
+
"zh": "值",
|
|
1973
|
+
"ja": "値",
|
|
1974
|
+
"ar": "القيمة",
|
|
1975
|
+
"ru": "Значение",
|
|
1976
|
+
},
|
|
1977
|
+
"conf_subtitle": {
|
|
1978
|
+
"en": "Configuration Management",
|
|
1979
|
+
"zh": "配置管理",
|
|
1980
|
+
"ja": "設定管理",
|
|
1981
|
+
"ar": "إدارة التكوين",
|
|
1982
|
+
"ru": "Управление конфигурацией",
|
|
1983
|
+
},
|
|
1984
|
+
"conf_title": {
|
|
1985
|
+
"en": "Configuration Settings",
|
|
1986
|
+
"zh": "配置设置",
|
|
1987
|
+
"ja": "設定",
|
|
1988
|
+
"ar": "إعدادات التكوين",
|
|
1989
|
+
"ru": "Настройки конфигурации",
|
|
1990
|
+
},
|
|
1991
|
+
"conf_get_error_args": {
|
|
1992
|
+
"en": "Error: '/get' command requires exactly one argument (the key). Usage: /conf /get <key>",
|
|
1993
|
+
"zh": "错误:'/get' 命令需要一个参数(配置项名称)。用法:/conf /get <key>",
|
|
1994
|
+
"ja": "エラー:'/get' コマンドには引数が1つ必要です(キー)。使用法:/conf /get <key>",
|
|
1995
|
+
"ar": "خطأ: يتطلب أمر '/get' معاملاً واحداً بالضبط (المفتاح). الاستخدام: /conf /get <key>",
|
|
1996
|
+
"ru": "Ошибка: команда '/get' требует ровно один аргумент (ключ). Использование: /conf /get <key>",
|
|
1997
|
+
},
|
|
1998
|
+
"conf_get_error_not_found": {
|
|
1999
|
+
"en": "Error: Configuration key '{{key}}' not found.",
|
|
2000
|
+
"zh": "错误:未找到配置项 '{{key}}'。",
|
|
2001
|
+
"ja": "エラー:設定キー '{{key}}' が見つかりません。",
|
|
2002
|
+
"ar": "خطأ: لم يتم العثور على مفتاح التكوين '{{key}}'.",
|
|
2003
|
+
"ru": "Ошибка: Ключ конфигурации '{{key}}' не найден.",
|
|
2004
|
+
},
|
|
2005
|
+
"conf_set_error_args": {
|
|
2006
|
+
"en": "Error: '/set' command requires at least two arguments (key and value). Usage: /conf /set <key> <value>",
|
|
2007
|
+
"zh": "错误:'/set' 命令需要至少两个参数(配置项名称和值)。用法:/conf /set <key> <value>",
|
|
2008
|
+
"ja": "エラー:'/set' コマンドには少なくとも2つの引数が必要です(キーと値)。使用法:/conf /set <key> <value>",
|
|
2009
|
+
"ar": "خطأ: يتطلب أمر '/set' معاملين على الأقل (المفتاح والقيمة). الاستخدام: /conf /set <key> <value>",
|
|
2010
|
+
"ru": "Ошибка: команда '/set' требует по крайней мере два аргумента (ключ и значение). Использование: /conf /set <key> <value>",
|
|
2011
|
+
},
|
|
2012
|
+
"conf_set_success": {
|
|
2013
|
+
"en": "Configuration updated: {{key}} = {{value}}",
|
|
2014
|
+
"zh": "配置已更新:{{key}} = {{value}}",
|
|
2015
|
+
"ja": "設定が更新されました:{{key}} = {{value}}",
|
|
2016
|
+
"ar": "تم تحديث التكوين: {{key}} = {{value}}",
|
|
2017
|
+
"ru": "Конфигурация обновлена: {{key}} = {{value}}",
|
|
2018
|
+
},
|
|
2019
|
+
"conf_set_error": {
|
|
2020
|
+
"en": "Error setting configuration for key '{{key}}': {{error}}",
|
|
2021
|
+
"zh": "设置配置项 '{{key}}' 时出错:{{error}}",
|
|
2022
|
+
"ja": "キー '{{key}}' の設定エラー:{{error}}",
|
|
2023
|
+
"ar": "خطأ في تعيين التكوين للمفتاح '{{key}}': {{error}}",
|
|
2024
|
+
"ru": "Ошибка установки конфигурации для ключа '{{key}}': {{error}}",
|
|
2025
|
+
},
|
|
2026
|
+
"conf_delete_error_args": {
|
|
2027
|
+
"en": "Error: '/delete' command requires exactly one argument (the key). Usage: /conf /drop <key> or /conf /delete <key>",
|
|
2028
|
+
"zh": "错误:'/delete' 命令需要一个参数(配置项名称)。用法:/conf /drop <key> 或 /conf /delete <key>",
|
|
2029
|
+
"ja": "エラー:'/delete' コマンドには引数が1つ必要です(キー)。使用法:/conf /drop <key> または /conf /delete <key>",
|
|
2030
|
+
"ar": "خطأ: يتطلب أمر '/delete' معاملاً واحداً بالضبط (المفتاح). الاستخدام: /conf /drop <key> أو /conf /delete <key>",
|
|
2031
|
+
"ru": "Ошибка: команда '/delete' требует ровно один аргумент (ключ). Использование: /conf /drop <key> или /conf /delete <key>",
|
|
2032
|
+
},
|
|
2033
|
+
"conf_delete_success": {
|
|
2034
|
+
"en": "Configuration deleted: {{key}}",
|
|
2035
|
+
"zh": "配置已删除:{{key}}",
|
|
2036
|
+
"ja": "設定が削除されました:{{key}}",
|
|
2037
|
+
"ar": "تم حذف التكوين: {{key}}",
|
|
2038
|
+
"ru": "Конфигурация удалена: {{key}}",
|
|
2039
|
+
},
|
|
2040
|
+
"conf_delete_error": {
|
|
2041
|
+
"en": "Error deleting key '{{key}}': {{error}}",
|
|
2042
|
+
"zh": "删除配置项 '{{key}}' 时出错:{{error}}",
|
|
2043
|
+
"ja": "キー '{{key}}' の削除エラー:{{error}}",
|
|
2044
|
+
"ar": "خطأ في حذف المفتاح '{{key}}': {{error}}",
|
|
2045
|
+
"ru": "Ошибка удаления ключа '{{key}}': {{error}}",
|
|
2046
|
+
},
|
|
2047
|
+
"conf_delete_not_found": {
|
|
2048
|
+
"en": "Error: Configuration key '{{key}}' not found.",
|
|
2049
|
+
"zh": "错误:未找到配置项 '{{key}}'。",
|
|
2050
|
+
"ja": "エラー:設定キー '{{key}}' が見つかりません。",
|
|
2051
|
+
"ar": "خطأ: لم يتم العثور على مفتاح التكوين '{{key}}'.",
|
|
2052
|
+
"ru": "Ошибка: Ключ конфигурации '{{key}}' не найден.",
|
|
2053
|
+
},
|
|
2054
|
+
"conf_help_args_error": {
|
|
2055
|
+
"en": "Error: '/help' command takes no arguments. Usage: /conf /help",
|
|
2056
|
+
"zh": "错误:'/help' 命令不需要参数。用法:/conf /help",
|
|
2057
|
+
"ja": "エラー:'/help' コマンドには引数は不要です。使用法:/conf /help",
|
|
2058
|
+
"ar": "خطأ: أمر '/help' لا يأخذ معاملات. الاستخدام: /conf /help",
|
|
2059
|
+
"ru": "Ошибка: команда '/help' не принимает аргументы. Использование: /conf /help",
|
|
2060
|
+
},
|
|
2061
|
+
"conf_export_path_required": {
|
|
2062
|
+
"en": "Error: Please specify a path for export. Usage: /conf /export <path>",
|
|
2063
|
+
"zh": "错误:请指定导出路径。用法:/conf /export <path>",
|
|
2064
|
+
"ja": "エラー:エクスポートのパスを指定してください。使用法:/conf /export <path>",
|
|
2065
|
+
"ar": "خطأ: يرجى تحديد مسار للتصدير. الاستخدام: /conf /export <path>",
|
|
2066
|
+
"ru": "Ошибка: Пожалуйста, укажите путь для экспорта. Использование: /conf /export <path>",
|
|
2067
|
+
},
|
|
2068
|
+
"conf_export_success": {
|
|
2069
|
+
"en": "Configuration exported successfully to {{path}}",
|
|
2070
|
+
"zh": "配置已成功导出到 {{path}}",
|
|
2071
|
+
"ja": "設定が {{path}} に正常にエクスポートされました",
|
|
2072
|
+
"ar": "تم تصدير التكوين بنجاح إلى {{path}}",
|
|
2073
|
+
"ru": "Конфигурация успешно экспортирована в {{path}}",
|
|
2074
|
+
},
|
|
2075
|
+
"conf_export_error": {
|
|
2076
|
+
"en": "Error exporting configuration: {{error}}",
|
|
2077
|
+
"zh": "导出配置时出错:{{error}}",
|
|
2078
|
+
"ja": "設定のエクスポートエラー:{{error}}",
|
|
2079
|
+
"ar": "خطأ في تصدير التكوين: {{error}}",
|
|
2080
|
+
"ru": "Ошибка экспорта конфигурации: {{error}}",
|
|
2081
|
+
},
|
|
2082
|
+
"conf_import_path_required": {
|
|
2083
|
+
"en": "Error: Please specify a path for import. Usage: /conf /import <path>",
|
|
2084
|
+
"zh": "错误:请指定导入路径。用法:/conf /import <path>",
|
|
2085
|
+
"ja": "エラー:インポートのパスを指定してください。使用法:/conf /import <path>",
|
|
2086
|
+
"ar": "خطأ: يرجى تحديد مسار للاستيراد. الاستخدام: /conf /import <path>",
|
|
2087
|
+
"ru": "Ошибка: Пожалуйста, укажите путь для импорта. Использование: /conf /import <path>",
|
|
2088
|
+
},
|
|
2089
|
+
"conf_import_success": {
|
|
2090
|
+
"en": "Configuration imported successfully from {{path}}. Use '/conf' to see changes.",
|
|
2091
|
+
"zh": "配置已成功从 {{path}} 导入。使用 '/conf' 查看更改。",
|
|
2092
|
+
"ja": "設定が {{path}} から正常にインポートされました。'/conf' で変更を確認してください。",
|
|
2093
|
+
"ar": "تم استيراد التكوين بنجاح من {{path}}. استخدم '/conf' لرؤية التغييرات.",
|
|
2094
|
+
"ru": "Конфигурация успешно импортирована из {{path}}. Используйте '/conf' для просмотра изменений.",
|
|
2095
|
+
},
|
|
2096
|
+
"conf_import_error": {
|
|
2097
|
+
"en": "Error importing configuration: {{error}}",
|
|
2098
|
+
"zh": "导入配置时出错:{{error}}",
|
|
2099
|
+
"ja": "設定のインポートエラー:{{error}}",
|
|
2100
|
+
"ar": "خطأ في استيراد التكوين: {{error}}",
|
|
2101
|
+
"ru": "Ошибка импорта конфигурации: {{error}}",
|
|
2102
|
+
},
|
|
2103
|
+
"conf_no_configs_found": {
|
|
2104
|
+
"en": "No configurations set.",
|
|
2105
|
+
"zh": "未设置任何配置。",
|
|
2106
|
+
"ja": "設定されていません。",
|
|
2107
|
+
"ar": "لم يتم تعيين أي تكوينات.",
|
|
2108
|
+
"ru": "Конфигурации не заданы.",
|
|
2109
|
+
},
|
|
2110
|
+
"conf_no_pattern_matches": {
|
|
2111
|
+
"en": "No configuration keys found matching pattern: {{pattern}}",
|
|
2112
|
+
"zh": "未找到匹配模式的配置项:{{pattern}}",
|
|
2113
|
+
"ja": "パターンに一致する設定キーが見つかりません:{{pattern}}",
|
|
2114
|
+
"ar": "لم يتم العثور على مفاتيح تكوين تطابق النمط: {{pattern}}",
|
|
2115
|
+
"ru": "Не найдены ключи конфигурации, соответствующие шаблону: {{pattern}}",
|
|
2116
|
+
},
|
|
2117
|
+
"conf_filtered_title": {
|
|
2118
|
+
"en": "Filtered Configuration (Pattern: {{pattern}})",
|
|
2119
|
+
"zh": "过滤后的配置(模式:{{pattern}})",
|
|
2120
|
+
"ja": "フィルタされた設定(パターン:{{pattern}})",
|
|
2121
|
+
"ar": "التكوين المصفى (النمط: {{pattern}})",
|
|
2122
|
+
"ru": "Отфильтрованная конфигурация (Шаблон: {{pattern}})",
|
|
2123
|
+
},
|
|
2124
|
+
"conf_unknown_command": {
|
|
2125
|
+
"en": "Error: Unknown command '/conf {{command}}'. Type '/conf help' for available commands.",
|
|
2126
|
+
"zh": "错误:未知命令 '/conf {{command}}'。输入 '/conf help' 查看可用命令。",
|
|
2127
|
+
"ja": "エラー:不明なコマンド '/conf {{command}}'。利用可能なコマンドについては '/conf help' を入力してください。",
|
|
2128
|
+
"ar": "خطأ: أمر غير معروف '/conf {{command}}'. اكتب '/conf help' للأوامر المتاحة.",
|
|
2129
|
+
"ru": "Ошибка: Неизвестная команда '/conf {{command}}'. Введите '/conf help' для доступных команд.",
|
|
2130
|
+
},
|
|
2131
|
+
"conf_invalid_key_value_format": {
|
|
2132
|
+
"en": "Error: Invalid key:value format in '{{input}}'. Use '/conf set {{key}} {{value}}' or '/conf help'.",
|
|
2133
|
+
"zh": "错误:'{{input}}' 中的 key:value 格式无效。使用 '/conf set {{key}} {{value}}' 或 '/conf help'。",
|
|
2134
|
+
"ja": "エラー:'{{input}}' の key:value 形式が無効です。'/conf set {{key}} {{value}}' または '/conf help' を使用してください。",
|
|
2135
|
+
"ar": "خطأ: تنسيق key:value غير صحيح في '{{input}}'. استخدم '/conf set {{key}} {{value}}' أو '/conf help'.",
|
|
2136
|
+
"ru": "Ошибка: Неверный формат key:value в '{{input}}'. Используйте '/conf set {{key}} {{value}}' или '/conf help'.",
|
|
2137
|
+
},
|
|
2138
|
+
"conf_unknown_format": {
|
|
2139
|
+
"en": "Error: Unknown command or invalid format '{{input}}'. Type '/conf help' for available commands.",
|
|
2140
|
+
"zh": "错误:未知命令或无效格式 '{{input}}'。输入 '/conf help' 查看可用命令。",
|
|
2141
|
+
"ja": "エラー:不明なコマンドまたは無効な形式 '{{input}}'。利用可能なコマンドについては '/conf help' を入力してください。",
|
|
2142
|
+
"ar": "خطأ: أمر غير معروف أو تنسيق غير صحيح '{{input}}'. اكتب '/conf help' للأوامر المتاحة.",
|
|
2143
|
+
"ru": "Ошибка: Неизвестная команда или неверный формат '{{input}}'. Введите '/conf help' для доступных команд.",
|
|
2144
|
+
},
|
|
2145
|
+
"conf_unexpected_error": {
|
|
2146
|
+
"en": "An unexpected error occurred while executing '/conf {{command}}': {{error}}",
|
|
2147
|
+
"zh": "执行 '/conf {{command}}' 时发生意外错误:{{error}}",
|
|
2148
|
+
"ja": "'/conf {{command}}' の実行中に予期しないエラーが発生しました:{{error}}",
|
|
2149
|
+
"ar": "حدث خطأ غير متوقع أثناء تنفيذ '/conf {{command}}': {{error}}",
|
|
2150
|
+
"ru": "Произошла неожиданная ошибка при выполнении '/conf {{command}}': {{error}}",
|
|
2151
|
+
},
|
|
2152
|
+
"async_task_started": {
|
|
2153
|
+
"en": "Async task started!",
|
|
2154
|
+
"zh": "异步任务已启动!",
|
|
2155
|
+
"ja": "非同期タスクが開始されました!",
|
|
2156
|
+
"ar": "تم بدء المهمة غير المتزامنة!",
|
|
2157
|
+
"ru": "Асинхронная задача запущена!",
|
|
2158
|
+
},
|
|
2159
|
+
"async_task_model": {
|
|
2160
|
+
"en": "Model:",
|
|
2161
|
+
"zh": "模型:",
|
|
2162
|
+
"ja": "モデル:",
|
|
2163
|
+
"ar": "النموذج:",
|
|
2164
|
+
"ru": "Модель:",
|
|
2165
|
+
},
|
|
2166
|
+
"async_task_query": {
|
|
2167
|
+
"en": "Query:",
|
|
2168
|
+
"zh": "查询:",
|
|
2169
|
+
"ja": "クエリ:",
|
|
2170
|
+
"ar": "الاستعلام:",
|
|
2171
|
+
"ru": "Запрос:",
|
|
2172
|
+
},
|
|
2173
|
+
"async_task_details_location": {
|
|
2174
|
+
"en": "View task details at:",
|
|
2175
|
+
"zh": "任务详情请查看:",
|
|
2176
|
+
"ja": "タスクの詳細はこちらで確認:",
|
|
2177
|
+
"ar": "عرض تفاصيل المهمة في:",
|
|
2178
|
+
"ru": "Подробности задачи смотрите в:",
|
|
2179
|
+
},
|
|
2180
|
+
"async_task_background_tip": {
|
|
2181
|
+
"en": "Tip: Task is running in the background, you can continue using other features",
|
|
2182
|
+
"zh": "提示: 任务正在后台执行,您可以继续使用其他功能",
|
|
2183
|
+
"ja": "ヒント: タスクはバックグラウンドで実行中です。他の機能も引き続き使用できます",
|
|
2184
|
+
"ar": "تلميح: المهمة تعمل في الخلفية، يمكنك الاستمرار في استخدام الميزات الأخرى",
|
|
2185
|
+
"ru": "Подсказка: Задача выполняется в фоне, вы можете продолжать использовать другие функции",
|
|
2186
|
+
},
|
|
2187
|
+
"async_task_title": {
|
|
2188
|
+
"en": "🚀 Async Task",
|
|
2189
|
+
"zh": "🚀 异步任务",
|
|
2190
|
+
"ja": "🚀 非同期タスク",
|
|
2191
|
+
"ar": "🚀 مهمة غير متزامنة",
|
|
2192
|
+
"ru": "🚀 Асинхронная задача",
|
|
2193
|
+
},
|
|
2194
|
+
"agentic_mode_plan": {
|
|
2195
|
+
"en": "plan",
|
|
2196
|
+
"zh": "规划",
|
|
2197
|
+
"ja": "計画",
|
|
2198
|
+
"ar": "خطة",
|
|
2199
|
+
"ru": "план",
|
|
2200
|
+
},
|
|
2201
|
+
"agentic_mode_act": {
|
|
2202
|
+
"en": "act",
|
|
2203
|
+
"zh": "执行",
|
|
2204
|
+
"ja": "実行",
|
|
2205
|
+
"ar": "تنفيذ",
|
|
2206
|
+
"ru": "действие",
|
|
2207
|
+
},
|
|
2208
|
+
}
|