Todo: 集成多平台 解决因SaiNiu线程抢占资源问题 本地提交测试环境打包 和 正式打包脚本与正式环境打包bat 提交Python32环境包 改进多日志文件生成情况修改打包日志细节

This commit is contained in:
2025-09-18 15:52:03 +08:00
parent 8b9fc925fa
commit 7cfc0c22b7
7608 changed files with 2424791 additions and 25 deletions

View File

@@ -0,0 +1,66 @@
# MFC base classes.
import win32ui
class Object:
def __init__(self, initObj=None):
self.__dict__["_obj_"] = initObj
# self._obj_ = initObj
if initObj is not None:
initObj.AttachObject(self)
def __del__(self):
self.close()
def __getattr__(
self, attr
): # Make this object look like the underlying win32ui one.
# During cleanup __dict__ is not available, causing recursive death.
if not attr.startswith("__"):
try:
o = self.__dict__["_obj_"]
if o is not None:
return getattr(o, attr)
# Only raise this error for non "internal" names -
# Python may be calling __len__, __bool__, etc, so
# we don't want this exception
if attr[0] != "_" and attr[-1] != "_":
raise win32ui.error("The MFC object has died.")
except KeyError:
# No _obj_ at all - don't report MFC object died when there isn't one!
pass
raise AttributeError(attr)
def OnAttachedObjectDeath(self):
# print("object", self.__class__.__name__, "dieing")
self._obj_ = None
def close(self):
if "_obj_" in self.__dict__:
if self._obj_ is not None:
self._obj_.AttachObject(None)
self._obj_ = None
class CmdTarget(Object):
def __init__(self, initObj):
Object.__init__(self, initObj)
def HookNotifyRange(self, handler, firstID, lastID):
oldhandlers = []
for i in range(firstID, lastID + 1):
oldhandlers.append(self.HookNotify(handler, i))
return oldhandlers
def HookCommandRange(self, handler, firstID, lastID):
oldhandlers = []
for i in range(firstID, lastID + 1):
oldhandlers.append(self.HookCommand(handler, i))
return oldhandlers
def HookCommandUpdateRange(self, handler, firstID, lastID):
oldhandlers = []
for i in range(firstID, lastID + 1):
oldhandlers.append(self.HookCommandUpdate(handler, i))
return oldhandlers