diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Wasabi/api/skin/widgets/xuiwndholder.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/api/skin/widgets/xuiwndholder.h')
-rw-r--r-- | Src/Wasabi/api/skin/widgets/xuiwndholder.h | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/Src/Wasabi/api/skin/widgets/xuiwndholder.h b/Src/Wasabi/api/skin/widgets/xuiwndholder.h new file mode 100644 index 00000000..13edc05a --- /dev/null +++ b/Src/Wasabi/api/skin/widgets/xuiwndholder.h @@ -0,0 +1,80 @@ +#ifndef __XUIWNDHOLDER_H +#define __XUIWNDHOLDER_H + +#include <api/wnd/wndclass/wndholder.h> +#include <api/script/scriptguid.h> +#include <api/script/objcontroller.h> + +#define XUIWNDHOLDER_PARENT WindowHolderWnd + +// ----------------------------------------------------------------------- +class XuiWindowHolder : public XUIWNDHOLDER_PARENT +{ + + public: + + XuiWindowHolder(); + virtual ~XuiWindowHolder(); + + virtual int setXuiParam(int xuihandle, int xmlattributeid, const wchar_t *xmlattributename, const wchar_t *value); + + void setRegionFromMap(ScriptObject *map, int byte, int inverse); + void setRegion(ScriptObject *region); + static GUID *parseGUID(const wchar_t *id); + +protected: + /*static */void CreateXMLParameters(int master_handle); + private: + + enum { + XUIWNDHOLDER_ADDHOLD = 10, + XUIWNDHOLDER_SETNOSHOWCMDBAR = 20, + XUIWNDHOLDER_SETNOANIMRECTS = 30, + XUIWNDHOLDER_SETAUTOOPEN = 40, + XUIWNDHOLDER_SETAUTOCLOSE = 50, + XUIWNDHOLDER_SETAUTOFOCUS = 60, + XUIWNDHOLDER_SETAUTOAVAILABLE = 70, + }; + static XMLParamPair params[]; + int myxuihandle; +}; + +// ----------------------------------------------------------------------------------------------------- +class WindowHolderScriptController: public ScriptObjectControllerI { + public: + + virtual const wchar_t *getClassName() { return L"WindowHolder"; } + virtual const wchar_t *getAncestorClassName() { return L"GuiObject"; } + virtual ScriptObjectController *getAncestorController() { return WASABI_API_MAKI->maki_getController(guiObjectGuid); } + virtual int getNumFunctions(); + virtual const function_descriptor_struct *getExportedFunctions(); + virtual GUID getClassGuid() { return windowHolderGuid; } + virtual ScriptObject *instantiate(); + virtual void destroy(ScriptObject *o); + virtual void *encapsulate(ScriptObject *o); + virtual void deencapsulate(void *o); + + public: + static scriptVar script_getGUID(SCRIPT_FUNCTION_PARAMS, ScriptObject *o); + static scriptVar script_setRegionFromMap(SCRIPT_FUNCTION_PARAMS, ScriptObject *o, scriptVar map, scriptVar byte, scriptVar inv); + static scriptVar script_setRegion(SCRIPT_FUNCTION_PARAMS, ScriptObject *o, scriptVar reg); + static scriptVar script_getContent(SCRIPT_FUNCTION_PARAMS, ScriptObject *o); + static scriptVar script_getComponentName(SCRIPT_FUNCTION_PARAMS, ScriptObject *o); + + private: + + static function_descriptor_struct exportedFunction[]; +}; + +extern WindowHolderScriptController *windowHolderController; + + +// ----------------------------------------------------------------------- +extern const wchar_t WindowHolderXuiObjectStr[]; +extern const wchar_t WindowHolderXuiObjectStrCompat[]; +extern char WindowHolderXuiSvcName[]; +extern char WindowHolderXuiSvcNameCompat[]; +class WindowHolderXuiSvc : public XuiObjectSvc<XuiWindowHolder, WindowHolderXuiObjectStr, WindowHolderXuiSvcName> {}; +class WindowHolderXuiSvc2 : public XuiObjectSvc<XuiWindowHolder, WindowHolderXuiObjectStrCompat, WindowHolderXuiSvcNameCompat> {}; + +#endif |