aboutsummaryrefslogtreecommitdiff
path: root/Src/xml/ifc_xmlreaderparams.h
diff options
context:
space:
mode:
authorJean-Francois Mauguit <jfmauguit@mac.com>2024-09-24 09:03:25 -0400
committerGitHub <noreply@github.com>2024-09-24 09:03:25 -0400
commitbab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/xml/ifc_xmlreaderparams.h
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/xml/ifc_xmlreaderparams.h')
-rw-r--r--Src/xml/ifc_xmlreaderparams.h65
1 files changed, 65 insertions, 0 deletions
diff --git a/Src/xml/ifc_xmlreaderparams.h b/Src/xml/ifc_xmlreaderparams.h
new file mode 100644
index 00000000..cb10434d
--- /dev/null
+++ b/Src/xml/ifc_xmlreaderparams.h
@@ -0,0 +1,65 @@
+#ifndef NULLSOFT_XML_IFC_XMLREADERPARAMS_H
+#define NULLSOFT_XML_IFC_XMLREADERPARAMS_H
+
+#include <bfc/dispatch.h>
+#include <bfc/platform/types.h>
+// ----------------------------------------------------------------------------
+
+class NOVTABLE ifc_xmlreaderparams : public Dispatchable
+{
+ protected:
+ ifc_xmlreaderparams() {}
+ virtual ~ifc_xmlreaderparams() {}
+ public:
+ const wchar_t *getItemName(size_t i);
+ const wchar_t *getItemValue(size_t i);
+ const wchar_t *getItemValue(const wchar_t *name);
+ const wchar_t *enumItemValues(const wchar_t *name, size_t nb);
+ int getItemValueInt(const wchar_t *name, int def = 0);
+ size_t getNbItems();
+
+ protected:
+ DISPATCH_CODES
+ {
+ XMLREADERPARAMS_GETITEMNAME = 100,
+ XMLREADERPARAMS_GETITEMVALUE = 200,
+ XMLREADERPARAMS_GETITEMVALUE2 = 201,
+ XMLREADERPARAMS_ENUMITEMVALUES = 202,
+ XMLREADERPARAMS_GETITEMVALUEINT = 300,
+ XMLREADERPARAMS_GETNBITEMS = 400,
+ };
+};
+
+// ----------------------------------------------------------------------------
+
+inline const wchar_t *ifc_xmlreaderparams::getItemName(size_t i)
+{
+ return _call(XMLREADERPARAMS_GETITEMNAME, (const wchar_t *)0, i);
+}
+
+inline const wchar_t *ifc_xmlreaderparams::getItemValue(size_t i)
+{
+ return _call(XMLREADERPARAMS_GETITEMVALUE, (const wchar_t *)0, i);
+}
+
+inline const wchar_t *ifc_xmlreaderparams::getItemValue(const wchar_t *name)
+{
+ return _call(XMLREADERPARAMS_GETITEMVALUE2, (const wchar_t *)0, name);
+}
+
+inline const wchar_t *ifc_xmlreaderparams::enumItemValues(const wchar_t *name, size_t nb)
+{
+ return _call(XMLREADERPARAMS_ENUMITEMVALUES, (const wchar_t *)0, name, nb);
+ }
+
+inline int ifc_xmlreaderparams::getItemValueInt(const wchar_t *name, int def)
+{
+ return _call(XMLREADERPARAMS_GETITEMVALUEINT, (int)0, name, def);
+}
+
+inline size_t ifc_xmlreaderparams::getNbItems()
+{
+ return _call(XMLREADERPARAMS_GETNBITEMS, (size_t)0);
+}
+
+#endif \ No newline at end of file