From 481a092c7fa72a127a259e040ee0a44508873060 Mon Sep 17 00:00:00 2001 From: James Date: Thu, 14 Nov 2024 22:52:02 +0700 Subject: [PATCH] fix: support user defined engine path --- engine/services/engine_service.cc | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/engine/services/engine_service.cc b/engine/services/engine_service.cc index cd874f89a..d793989af 100644 --- a/engine/services/engine_service.cc +++ b/engine/services/engine_service.cc @@ -773,7 +773,6 @@ cpp::result EngineService::LoadEngine( auto selected_engine_variant = GetDefaultEngineVariant(ne); if (selected_engine_variant.has_error()) { - // TODO: namh need to fallback return cpp::fail(selected_engine_variant.error()); } @@ -781,11 +780,13 @@ cpp::result EngineService::LoadEngine( << json_helper::DumpJsonString(selected_engine_variant->ToJson())); auto user_defined_engine_path = getenv("ENGINE_PATH"); + CTL_DBG("user defined engine path: " << user_defined_engine_path); const std::filesystem::path engine_dir_path = [&] { if (user_defined_engine_path != nullptr) { - // for backward compatible return std::filesystem::path(user_defined_engine_path + - GetEnginePath(ne)); + GetEnginePath(ne)) / + selected_engine_variant->variant / + selected_engine_variant->version; } else { return file_manager_utils::GetEnginesContainerPath() / ne / selected_engine_variant->variant / @@ -793,6 +794,8 @@ cpp::result EngineService::LoadEngine( } }(); + CTL_DBG("Engine path: " << engine_dir_path.string()); + if (!std::filesystem::exists(engine_dir_path)) { CTL_ERR("Directory " + engine_dir_path.string() + " is not exist!"); return cpp::fail("Directory " + engine_dir_path.string() +