From bf4e43c1fd1a361029e7cb51daac378fa5ee3617 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 20 三月 2026 18:44:13 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/utils/StationOperateProcessUtils.java |   45 +++++++++++++++++++++++++++++----------------
 1 files changed, 29 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/zy/core/utils/StationOperateProcessUtils.java b/src/main/java/com/zy/core/utils/StationOperateProcessUtils.java
index 1224d5d..05e0599 100644
--- a/src/main/java/com/zy/core/utils/StationOperateProcessUtils.java
+++ b/src/main/java/com/zy/core/utils/StationOperateProcessUtils.java
@@ -7,6 +7,7 @@
 import com.core.common.Cools;
 import com.core.exception.CoolException;
 import com.zy.asrs.domain.enums.NotifyMsgType;
+import com.zy.asrs.domain.path.StationPathResolvedPolicy;
 import com.zy.asrs.domain.vo.StationCycleCapacityVo;
 import com.zy.asrs.domain.vo.StationCycleLoopVo;
 import com.zy.asrs.entity.*;
@@ -57,13 +58,15 @@
     private BasStationService basStationService;
     @Autowired
     private StationCycleCapacityService stationCycleCapacityService;
+    @Autowired
+    private StationPathPolicyService stationPathPolicyService;
 
     //鎵ц杈撻�佺珯鐐瑰叆搴撲换鍔�
     public synchronized void stationInExecute() {
         try {
-            DispatchLimitConfig limitConfig = getDispatchLimitConfig();
+            DispatchLimitConfig baseLimitConfig = getDispatchLimitConfig(null, null);
             int[] currentStationTaskCountRef = new int[]{countCurrentStationTask()};
-            LoadGuardState loadGuardState = buildLoadGuardState(limitConfig);
+            LoadGuardState loadGuardState = buildLoadGuardState(baseLimitConfig);
 
             List<BasDevp> basDevps = basDevpService.list(new QueryWrapper<>());
             for (BasDevp basDevp : basDevps) {
@@ -119,6 +122,7 @@
                             continue;
                         }
 
+                        DispatchLimitConfig limitConfig = getDispatchLimitConfig(stationProtocol.getStationId(), targetStationId);
                         LoopHitResult loopHitResult = findPathLoopHit(limitConfig, stationProtocol.getStationId(), targetStationId, loadGuardState);
 
                         if (isDispatchBlocked(limitConfig, currentStationTaskCountRef[0], loadGuardState, loopHitResult.isThroughLoop())) {
@@ -154,9 +158,9 @@
     //鎵ц鍫嗗灈鏈鸿緭閫佺珯鐐瑰嚭搴撲换鍔�
     public synchronized void crnStationOutExecute() {
         try {
-            DispatchLimitConfig limitConfig = getDispatchLimitConfig();
+            DispatchLimitConfig baseLimitConfig = getDispatchLimitConfig(null, null);
             int[] currentStationTaskCountRef = new int[]{countCurrentStationTask()};
-            LoadGuardState loadGuardState = buildLoadGuardState(limitConfig);
+            LoadGuardState loadGuardState = buildLoadGuardState(baseLimitConfig);
 
             List<WrkMast> wrkMasts = wrkMastService.list(new QueryWrapper<WrkMast>()
                     .eq("wrk_sts", WrkStsType.OUTBOUND_RUN_COMPLETE.sts)
@@ -200,6 +204,7 @@
                             true
                     );
 
+                    DispatchLimitConfig limitConfig = getDispatchLimitConfig(stationProtocol.getStationId(), moveStaNo);
                     LoopHitResult loopHitResult = findPathLoopHit(limitConfig, stationProtocol.getStationId(), moveStaNo, loadGuardState);
 
                     if (isDispatchBlocked(limitConfig, currentStationTaskCountRef[0], loadGuardState, loopHitResult.isThroughLoop())) {
@@ -1000,23 +1005,31 @@
         redisUtil.expire(RedisKeyType.STATION_CYCLE_LOAD_RESERVE.key, LOOP_LOAD_RESERVE_EXPIRE_SECONDS);
     }
 
-    private DispatchLimitConfig getDispatchLimitConfig() {
+    private DispatchLimitConfig getDispatchLimitConfig(Integer startStationId, Integer endStationId) {
         DispatchLimitConfig config = new DispatchLimitConfig();
         Object systemConfigMapObj = redisUtil.get(RedisKeyType.SYSTEM_CONFIG_MAP.key);
-        if (!(systemConfigMapObj instanceof Map)) {
-            return config;
+        if (systemConfigMapObj instanceof Map) {
+            Map<?, ?> systemConfigMap = (Map<?, ?>) systemConfigMapObj;
+            config.circleMaxLoadLimit = parseLoadLimit(getConfigValue(systemConfigMap, "circleMaxLoadLimit"), config.circleMaxLoadLimit);
+            String loopModeValue = getConfigValue(systemConfigMap, "circleLoopModeEnable");
+            if (isBlank(loopModeValue)) {
+                loopModeValue = getConfigValue(systemConfigMap, "circleModeEnable");
+            }
+            if (isBlank(loopModeValue)) {
+                loopModeValue = getConfigValue(systemConfigMap, "isCircleMode");
+            }
+            config.loopModeEnable = parseBoolean(loopModeValue, config.loopModeEnable);
         }
-        Map<?, ?> systemConfigMap = (Map<?, ?>) systemConfigMapObj;
 
-        config.circleMaxLoadLimit = parseLoadLimit(getConfigValue(systemConfigMap, "circleMaxLoadLimit"), config.circleMaxLoadLimit);
-        String loopModeValue = getConfigValue(systemConfigMap, "circleLoopModeEnable");
-        if (isBlank(loopModeValue)) {
-            loopModeValue = getConfigValue(systemConfigMap, "circleModeEnable");
+        if (stationPathPolicyService != null && startStationId != null && endStationId != null) {
+            try {
+                StationPathResolvedPolicy resolvedPolicy = stationPathPolicyService.resolvePolicy(startStationId, endStationId);
+                if (resolvedPolicy != null && resolvedPolicy.getProfileConfig() != null) {
+                    config.circleMaxLoadLimit = parseLoadLimit(String.valueOf(resolvedPolicy.getProfileConfig().getCircleMaxLoadLimit()), config.circleMaxLoadLimit);
+                }
+            } catch (Exception ignore) {
+            }
         }
-        if (isBlank(loopModeValue)) {
-            loopModeValue = getConfigValue(systemConfigMap, "isCircleMode");
-        }
-        config.loopModeEnable = parseBoolean(loopModeValue, config.loopModeEnable);
 
         return config;
     }

--
Gitblit v1.9.1