From 68b5f20342840110c78bea1badd46ffd1ce5ab0c Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期四, 11 七月 2024 16:28:29 +0800
Subject: [PATCH] update
---
jrj/xframe/wobject/xaserverarg.hpp | 45 +++++++++++++++++++++++++++++++++++++++++----
1 files changed, 41 insertions(+), 4 deletions(-)
diff --git a/jrj/xframe/wobject/xaserverarg.hpp b/jrj/xframe/wobject/xaserverarg.hpp
index 5eb0ce1..228c87a 100644
--- a/jrj/xframe/wobject/xaserverarg.hpp
+++ b/jrj/xframe/wobject/xaserverarg.hpp
@@ -26,17 +26,54 @@
static int ReleaseInstance(IXAServerArg * pArgs);
int SetXml(LPTSTR pStrXml);
+ public:
+ unsigned long AddRef_();
+ unsigned long Release_();
};
}};
+using kxaserverarg = Hxsoft::XFrame::IXAServerArg;
class xaserverarg : public xnative
{
public:
+ xaserverarg(kxaserverarg* impl) :xnative(impl) {}
xaserverarg():xnative(Hxsoft::XFrame::IXAServerArg::CreateInstance()){}
+ xaserverarg(xaserverarg& rhs) {
+ if(rhs.GetKXAServerArg()) rhs.GetKXAServerArg()->AddRef_();
+ this->setNativePointer(rhs.GetNativePtr());
+ }
+ xaserverarg(xaserverarg&& rhs) {
+ ((kxaserverarg*)rhs.getNativePointer())->AddRef_();
+ this->setNativePointer(rhs.GetNativePtr());
+ }
~xaserverarg()
{
- Hxsoft::XFrame::IXAServerArg::ReleaseInstance((Hxsoft::XFrame::IXAServerArg*)getNativePointer());
+ ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->Release_();
+ //Hxsoft::XFrame::IXAServerArg::ReleaseInstance((Hxsoft::XFrame::IXAServerArg*)getNativePointer());
}
+public:
+ kxaserverarg* GetKXAServerArg()
+ {
+ return (kxaserverarg*)this->GetNativePtr();
+ }
+public:
+ xaserverarg& operator =(xaserverarg& rhs)
+ {
+ return operator =(rhs.GetKXAServerArg());
+ }
+ xaserverarg& operator =(kxaserverarg* rhs)
+ {
+ if (GetKXAServerArg())GetKXAServerArg()->Release_();
+ if (rhs)rhs->AddRef_();
+ SetNativePtr(rhs);
+ return *this;
+ }
+
+ operator LPARAM()
+ {
+ return (LPARAM)this;
+ }
+
public:
/*int AddArg(string argname,double val,string typ=NULL)// alias "?AddArg@IXAServerArg@XFrame@Hxsoft@@QAEHPB_WNO@Z";
{
@@ -72,7 +109,7 @@
{
return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->SetArg(argname,val,typ);
}
- string GetString() //alias "?GetString@IXAServerArg@XFrame@Hxsoft@@QAEPB_WXZ" from "xframe.dll";
+ xstring GetString() //alias "?GetString@IXAServerArg@XFrame@Hxsoft@@QAEPB_WXZ" from "xframe.dll";
{
return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetString();
}
@@ -97,7 +134,7 @@
{
return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetArgInt((LPTSTR)argname);
}
- string GetArgString(string argname) //alias "?GetArgString@IXAServerArg@XFrame@Hxsoft@@QAEPA_WPA_W@Z";
+ xstring GetArgString(string argname) //alias "?GetArgString@IXAServerArg@XFrame@Hxsoft@@QAEPA_WPA_W@Z";
{
return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetArgString((LPTSTR)argname);
}
@@ -133,7 +170,7 @@
xaserverargPtr() :arg(new xaserverarg) {}
xaserverargPtr(LPARAM* val) :arg((xaserverarg*)val) {}
xaserverargPtr(xaserverarg* val) :arg(val) {}
- //xaserverargPtr(xaserverarg val) :arg(new xaserverarg(val)){}
+ xaserverargPtr(xaserverarg val) :arg(new xaserverarg(val)){}
public:
xaserverarg* value() { return arg; }
public:
--
Gitblit v1.9.3