From e3488c13f1bcbcd39f8b9b267a3897fcc0d838aa Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期三, 21 八月 2024 14:56:53 +0800
Subject: [PATCH] update sign

---
 jrj/xframe/wobject/xaserverarg.hpp |   37 +++++++++++++++++++++++++++++++++----
 1 files changed, 33 insertions(+), 4 deletions(-)

diff --git a/jrj/xframe/wobject/xaserverarg.hpp b/jrj/xframe/wobject/xaserverarg.hpp
index fa73996..a54aeb1 100644
--- a/jrj/xframe/wobject/xaserverarg.hpp
+++ b/jrj/xframe/wobject/xaserverarg.hpp
@@ -1,6 +1,6 @@
 #pragma once
 #include "xnative.hpp"
-
+#include "xcontrol.hpp"
 namespace Hxsoft{ namespace XFrame
 {
 	class IXAServerArg
@@ -39,7 +39,7 @@
 	xaserverarg(kxaserverarg* impl) :xnative(impl) {}
 	xaserverarg():xnative(Hxsoft::XFrame::IXAServerArg::CreateInstance()){}
 	xaserverarg(xaserverarg& rhs) {
-		((kxaserverarg*)rhs.getNativePointer())->AddRef_();
+		if(rhs.GetKXAServerArg()) rhs.GetKXAServerArg()->AddRef_();
 		this->setNativePointer(rhs.GetNativePtr());
 	}
 	xaserverarg(xaserverarg&& rhs) {
@@ -67,6 +67,11 @@
 		if (rhs)rhs->AddRef_();
 		SetNativePtr(rhs);
 		return *this;
+	}
+
+	operator LPARAM()
+	{
+		return (LPARAM)this;
 	}
 
 public:
@@ -104,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();
 	}
@@ -129,9 +134,24 @@
 	{
 		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);
+	}
+
+	int SetParam(LPCTSTR pArgName, xcontrol& xc)
+	{
+		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->SetParam(pArgName,(LPARAM)xc.getNativePointer());
+	}
+
+	int SetParam(LPCTSTR pArgName, HWND hWnd)
+	{
+		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->SetParam(pArgName, (LPARAM)hWnd);
+	}
+
+	int SetParam(LPCTSTR pArgName, KXMLDOMElement ele)
+	{
+		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->SetParam(pArgName, ele.ptr());
 	}
 
 	int SetParam(LPCTSTR pArgName, LPARAM pValue)
@@ -144,6 +164,15 @@
 		return ((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetParam(pArgName);
 	}
 
+	void* GetControl(LPCTSTR pArgName)
+	{
+		return (void*)((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetParam(pArgName);
+	}
+	HWND GetHWND(LPCTSTR pArgName)
+	{
+		return (HWND)((Hxsoft::XFrame::IXAServerArg*)getNativePointer())->GetParam(pArgName);
+	}
+
 	template<class T>
 	int SetParam(LPCTSTR pArgName, T pValue)
 	{

--
Gitblit v1.9.3