From c9d85bde9ec46becb60b4434ec74fd7e527b885e Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期五, 15 十一月 2024 17:17:01 +0800
Subject: [PATCH] 10302 【越南】【英语】【砍树】【tqxbqy】【btgotq】仙缘-服务端

---
 ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py |   87 +++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 83 insertions(+), 4 deletions(-)

diff --git a/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py b/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
index cc413cf..538ec46 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
@@ -457,8 +457,8 @@
 ##获取玩家所属区服ID
 # @param curPlayer
 # @return
-def GetPlayerServerID(curPlayer):
-    accID = curPlayer.GetAccID()
+def GetPlayerServerID(curPlayer): return GetAccIDServerID(curPlayer.GetAccID())
+def GetAccIDServerID(accID):
     infoList = accID.split(Def_AccID_Split_Sign)
     return 0 if len(infoList) < 3 else int(infoList[-1][1:])
 
@@ -476,6 +476,17 @@
         return mainServerID
     return 0
 
+def CheckServerIDInList(serverID, serverIDList):
+    if serverIDList == None:
+        return False
+    if not serverIDList:
+        return True
+    for serverIDInfo in serverIDList:
+        if (isinstance(serverIDInfo, tuple) and serverIDInfo[0] <= serverID <= serverIDInfo[1]) \
+            or (isinstance(serverIDInfo, list) and serverIDInfo[0] <= serverID <= serverIDInfo[1]) \
+            or (isinstance(serverIDInfo, int) and serverIDInfo == serverID):
+            return True
+    return False
 
 #===============================================================================
 # 平台ID = appid
@@ -550,8 +561,42 @@
     if cfgID == None or dayIndex == None or not ipyData:
         return 0
     templateIDList = ipyData.GetTemplateIDList()
+    if not templateIDList:
+        return 0
     templateID = templateIDList[-1] if dayIndex >= len(templateIDList) else templateIDList[dayIndex]
     return templateID
+
+def GetTemplateIDByList(templateIDList, dayIndex):
+    if dayIndex == None:
+        return 0
+    if not templateIDList:
+        return 0
+    templateID = templateIDList[-1] if dayIndex >= len(templateIDList) else templateIDList[dayIndex]
+    return templateID
+
+def GetOperationActionLoopDate(startDateStr, endDateStr, curDateTime):
+    ## 获取运营活动配置日期循环的具体活动时间
+    # @return: 开始日期, 结束日期, 返回的日期是第x次循环
+    startSplitList = startDateStr.split("_")
+    loopDays = int(startSplitList[0][1:])
+    startLoopDateStr = startSplitList[1]
+    startLoopDateTime = ChangeStrToDatetime(startLoopDateStr, ChConfig.TYPE_Time_YmdFormat)
+    
+    endSplitList = endDateStr.split("_") # 可不配Lx_开头,防误配,做兼容
+    endLoopDateStr = endSplitList[0] if len(endSplitList) == 1 else endSplitList[1]
+    endLoopDateTime = ChangeStrToDatetime(endLoopDateStr, ChConfig.TYPE_Time_YmdFormat)
+    
+    if curDateTime >= startLoopDateTime:
+        passDays = (curDateTime - startLoopDateTime).days
+        loopTimes = passDays / loopDays + 1 # 第x次循环
+        loopTimeMax = (endLoopDateTime - startLoopDateTime).days / loopDays + 1 # 最大循环次数
+        loopTimes = min(loopTimes, loopTimeMax)
+    else:
+        loopTimes = 1 # 还未开始取第一次
+        
+    startDateTime = startLoopDateTime + datetime.timedelta((loopTimes - 1)*loopDays)
+    endDateTime = startDateTime + datetime.timedelta(days=(loopDays - 1))
+    return startDateTime, endDateTime, loopTimes
 
 def GetOperationActionDateStr(ipyData):
     ## 获取运营活动对应日期,存数字代表开服天配置,需要转化为对应的日期
@@ -564,7 +609,7 @@
         endDateStr = "%d-%d-%d" % (curDateTime.year, curDateTime.month, curDateTime.day)
         
     # 日期直接返回
-    if startDateStr.count("-") == 2 and "W" not in startDateStr:
+    if startDateStr.count("-") == 2 and "W" not in startDateStr and not startDateStr.startswith("L"):
         return startDateStr, endDateStr
     
     # 开服天
@@ -611,7 +656,10 @@
             # 只配置结束日期的时候可能导致开始日期计算出来比结束日期还大,即当前时间超过结束日期,且 配置还存在的情况
             if startDateTime > endDateTime:
                 startDateTime = endDateTime # 反正都无法开启,随便给个日期,不超过结束日期即可
-                
+    # 按日期循环
+    elif startDateStr.startswith("L"):
+        startDateTime, endDateTime, _ = GetOperationActionLoopDate(startDateStr, endDateStr, curDateTime)
+        
     # 默认
     else:
         startDateTime = curDateTime
@@ -690,6 +738,15 @@
     return pastTimeDelta.days * 24 * 60 * 60 + pastTimeDelta.seconds
 
 #---------------------------------------------------------------------
+
+def GetDiff_Day(timeA , timeB):
+    ## 获取 timeA - timeB 相差的日期天数
+    dateTimeA = ChangeTimeNumToDatetime(timeA)
+    dateTimeA = datetime.datetime(dateTimeA.year, dateTimeA.month, dateTimeA.day, 0, 0, 0)
+    dateTimeB = ChangeTimeNumToDatetime(timeB)
+    dateTimeB = datetime.datetime(dateTimeB.year, dateTimeB.month, dateTimeB.day, 0, 0, 0)
+    return (dateTimeA - dateTimeB).days
+
 ##设置世界服务器字典
 # @param key 字典值
 # @param tick 时间戳
@@ -985,6 +1042,28 @@
     
     return fullName
 
+def MergeItemList(itemList):
+    ## 合并物品列表,将相同物品数量合并
+    itemDict = {}
+    for itemInfo in itemList:
+        if len(itemInfo) == 3:
+            itemID, itemCount, isAuctionItem = itemInfo
+        elif len(itemInfo) == 2:
+            itemID, itemCount = itemInfo
+            isAuctionItem = None
+        else:
+            continue
+        key = (itemID, isAuctionItem)
+        itemDict[key] = itemDict.get(key, 0) + itemCount
+        
+    mItemList = []
+    for key, itemCount in itemDict.items():
+        itemID, isAuctionItem = key
+        if isAuctionItem == None:
+            mItemList.append([itemID, itemCount])
+        else:
+            mItemList.append([itemID, itemCount, isAuctionItem])
+    return mItemList
 
 ## 从列表中产生物品,[[几率,object], ....],万分率
 #  @param itemList 待选列表

--
Gitblit v1.8.0