From ca7bfcdac21b765d29d0045308d434dfd038b10c Mon Sep 17 00:00:00 2001
From: xj qian <qianxj15@sina.com>
Date: 星期三, 04 九月 2024 16:16:56 +0800
Subject: [PATCH] update jarch
---
jrj/xframe/wobject/xaserverarg.hpp | 71 +++++++++++++++++++++++++++++++++--
1 files changed, 66 insertions(+), 5 deletions(-)
diff --git a/jrj/xframe/wobject/xaserverarg.hpp b/jrj/xframe/wobject/xaserverarg.hpp
index 5eb0ce1..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
@@ -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,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)
@@ -110,6 +162,15 @@
LPARAM GetParam(LPCTSTR pArgName)
{
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>
@@ -133,7 +194,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