aboutsummaryrefslogtreecommitdiff
path: root/Src/Winamp/ParamList.cpp
diff options
context:
space:
mode:
authorJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
committerJef <jef@targetspot.com>2024-09-24 08:54:57 -0400
commit20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (patch)
tree12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Winamp/ParamList.cpp
parent537bcbc86291b32fc04ae4133ce4d7cac8ebe9a7 (diff)
downloadwinamp-20d28e80a5c861a9d5f449ea911ab75b4f37ad0d.tar.gz
Initial community commit
Diffstat (limited to 'Src/Winamp/ParamList.cpp')
-rw-r--r--Src/Winamp/ParamList.cpp124
1 files changed, 124 insertions, 0 deletions
diff --git a/Src/Winamp/ParamList.cpp b/Src/Winamp/ParamList.cpp
new file mode 100644
index 00000000..0118ecd0
--- /dev/null
+++ b/Src/Winamp/ParamList.cpp
@@ -0,0 +1,124 @@
+#include "ParamList.h"
+
+ParamList::~ParamList()
+{
+ //parms_list.deleteAll();
+ for (auto obj : parms_list)
+ {
+ delete obj;
+ }
+ parms_list.clear();
+}
+
+const wchar_t *ParamList::getItemName(int i)
+{
+ if(((size_t)i)>=getNbItems())
+ return L"";
+ return
+ parms_list[i]->parm;
+}
+
+
+const wchar_t *ParamList::getItemValueIndex(int i)
+{
+ if(((size_t)i)>=getNbItems())
+ return L"";
+ return
+ parms_list[i]->value;
+}
+
+const wchar_t *ParamList::getItemValue(const wchar_t *name)
+{
+ for(size_t i=0;i!=getNbItems();i++)
+ if(!WCSICMP(parms_list[i]->parm, name))
+ return parms_list[i]->value;
+ return NULL;
+}
+
+const wchar_t *ParamList::enumItemValues(const wchar_t *name, int nb)
+{
+ int f=0;
+ for(size_t i=0;i!=getNbItems();i++)
+ if(!WCSICMP(parms_list[i]->parm, name))
+ if(f==nb)
+ return parms_list[i]->value;
+ else f++;
+ return NULL;
+}
+
+int ParamList::getItemValueInt(const wchar_t *name, int def)
+{
+ for(size_t i=0;i!=getNbItems();i++)
+ if(!WCSICMP(parms_list[i]->parm, name))
+ {
+ // TODO: benski> do we want to return "def" when there's an empty value?
+ return WTOI(parms_list[i]->value);
+ }
+ return def;
+}
+
+
+size_t ParamList::getNbItems()
+{
+ return parms_list.size();
+}
+
+void ParamList::addItem(const wchar_t *parm, const wchar_t *value)
+{
+ parms_struct *p= new parms_struct;
+ p->parm = WCSDUP(parm);
+ p->ownValue = true;
+ p->value = value;
+ parms_list.push_back(p);
+}
+
+void ParamList::removeItem(const wchar_t *parm)
+{
+ for (size_t i=0; i!=parms_list.size(); i++)
+ {
+ parms_struct *s = parms_list[i];
+ if (!WCSICMP(parm, s->parm))
+ {
+ delete s;
+ parms_list.erase(parms_list.begin() + i);
+ i--;
+ }
+ }
+}
+
+void ParamList::replaceItem(const wchar_t *parm, const wchar_t *value)
+{
+ if (!value)
+ {
+ removeItem(parm);
+ return;
+ }
+
+ StringW s = value; // if we were passed our current value's pointer ...
+
+ const wchar_t *curval = getItemValue(parm);
+ if (s.isequal(value) && curval) return; // (hey, if we're replacing with same value, forget about it, but only if we did have that value, because isequal will return true if curval is NULL and we pass it ("") )
+
+ removeItem(parm); // ... then this call would make the value param invalid ...
+
+ addItem(parm, s); // ... so we're sending a saved buffer instead
+}
+
+int ParamList::findItem(const wchar_t *parm)
+{
+ for(size_t i=0;i!=getNbItems();i++)
+ if(!WCSICMP(parms_list[i]->parm, parm))
+ return (int)i;
+ return -1;
+}
+
+#define CBCLASS ParamList
+START_DISPATCH;
+CB(XMLREADERPARAMS_GETITEMNAME, getItemName)
+CB(XMLREADERPARAMS_GETITEMVALUE, getItemValueIndex)
+CB(XMLREADERPARAMS_GETITEMVALUE2, getItemValue)
+CB(XMLREADERPARAMS_ENUMITEMVALUES, enumItemValues)
+CB(XMLREADERPARAMS_GETITEMVALUEINT, getItemValueInt)
+CB(XMLREADERPARAMS_GETNBITEMS, getNbItems)
+END_DISPATCH;
+#undef CBCLASS \ No newline at end of file