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/albumart/ParamList.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/albumart/ParamList.h')
-rw-r--r-- | Src/albumart/ParamList.h | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Src/albumart/ParamList.h b/Src/albumart/ParamList.h new file mode 100644 index 00000000..971623a8 --- /dev/null +++ b/Src/albumart/ParamList.h @@ -0,0 +1,43 @@ +#pragma once +#include "../xml/ifc_xmlreaderparams.h" +#include <vector> + +class ParamList : public ifc_xmlreaderparams +{ +public: + ParamList() {} + ~ParamList(); + + const wchar_t *getItemName(int i); + const wchar_t *getItemValueIndex(int i); + const wchar_t *getItemValue(const wchar_t *name); + const wchar_t *enumItemValues(const wchar_t *name, int nb); + int getItemValueInt(const wchar_t *name, int def = 0); + size_t getNbItems(); + + void addItem(const wchar_t *parm, const wchar_t *value); + void removeItem(const wchar_t *parm); + int findItem(const wchar_t *parm); + +protected: + RECVS_DISPATCH; +private: + struct parms_struct + { + parms_struct() : parm(0), ownValue(false) + { + value=0; + } + + ~parms_struct() + { + if (ownValue) + free((wchar_t *)parm); + free(value); + } + const wchar_t *parm; + wchar_t *value; + bool ownValue; + }; + std::vector<parms_struct*> parms_list; +};
\ No newline at end of file |