From 951f0d76ed2d8702963b4b1a233a5a5b4b69b502 Mon Sep 17 00:00:00 2001
From: LiFan <2308045698@qq.com>
Date: 星期一, 08 七月 2024 16:39:43 +0800
Subject: [PATCH] update

---
 jrj/xframe/wobject/xaserverarg.hpp |   54 +++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 51 insertions(+), 3 deletions(-)

diff --git a/jrj/xframe/wobject/xaserverarg.hpp b/jrj/xframe/wobject/xaserverarg.hpp
index 0909ca6..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);
 	}
@@ -112,6 +149,17 @@
 		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetParam(pArgName);
 	}
 
+	template<class T>
+	int SetParam(LPCTSTR pArgName, T pValue)
+	{
+		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->SetParam(pArgName, (LPARAM)pValue);
+	}
+
+	template<class T>
+	T GetParam(LPCTSTR pArgName)
+	{
+		return (T)((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetParam(pArgName);
+	}
 };
 
 class xaserverargPtr

--
Gitblit v1.9.3