aboutsummaryrefslogtreecommitdiff
path: root/Src/Wasabi/api/xml/xmlparamsi.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/Wasabi/api/xml/xmlparamsi.h
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Wasabi/api/xml/xmlparamsi.h')
-rw-r--r--Src/Wasabi/api/xml/xmlparamsi.h52
1 files changed, 52 insertions, 0 deletions
diff --git a/Src/Wasabi/api/xml/xmlparamsi.h b/Src/Wasabi/api/xml/xmlparamsi.h
new file mode 100644
index 00000000..606c462c
--- /dev/null
+++ b/Src/Wasabi/api/xml/xmlparamsi.h
@@ -0,0 +1,52 @@
+#ifndef __XMLPARAMSI_H
+#define __XMLPARAMSI_H
+
+#include <bfc/dispatch.h>
+#include <bfc/string/bfcstring.h>
+#include <bfc/ptrlist.h>
+#include <bfc/string/StringW.h>
+
+/*<?<autoheader/>*/
+#include <api/xml/xmlparams.h>
+#include <api/xml/xmlparamsx.h>
+/*?>*/
+
+
+class XmlReaderParamsI : public XmlReaderParamsX
+{
+public:
+ XmlReaderParamsI() {}
+ virtual ~XmlReaderParamsI();
+
+ DISPATCH(100) const wchar_t *getItemName(int i);
+ DISPATCH(200) const wchar_t *getItemValue(int i);
+ DISPATCH(201) const wchar_t *getItemValue(const wchar_t *name);
+ DISPATCH(202) const wchar_t *enumItemValues(const wchar_t *name, int nb);
+ DISPATCH(300) int getItemValueInt(const wchar_t *name, int def = 0);
+ DISPATCH(400) int getNbItems();
+
+ DISPATCH(500) void addItem(const wchar_t *parm, const wchar_t *value);
+ DISPATCH(600) void removeItem(const wchar_t *parm);
+ DISPATCH(700) void replaceItem(const wchar_t *parm, const wchar_t *value);
+ DISPATCH(800) int findItem(const wchar_t *parm);
+
+ NODISPATCH void addItemSwapValue(const wchar_t *parm, StringW &value); // calling this will destroy your String... here for optimization ...
+private:
+ struct parms_struct
+ {
+ parms_struct() : parm(0), ownValue(false)
+ {}
+ ~parms_struct()
+ {
+ if (ownValue)
+ FREE((wchar_t *)parm);
+ }
+ const wchar_t *parm;
+ StringW value;
+ bool ownValue;
+ };
+ PtrList<parms_struct> parms_list;
+};
+
+
+#endif