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/wndmgr/appcmds.cpp | |
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/wndmgr/appcmds.cpp')
-rw-r--r-- | Src/Wasabi/api/wndmgr/appcmds.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/Src/Wasabi/api/wndmgr/appcmds.cpp b/Src/Wasabi/api/wndmgr/appcmds.cpp new file mode 100644 index 00000000..93b6ab6d --- /dev/null +++ b/Src/Wasabi/api/wndmgr/appcmds.cpp @@ -0,0 +1,61 @@ +#include <precomp.h> +#include "appcmds.h" + +#define CBCLASS AppCmdsI +START_DISPATCH; +CB(APPCMDS_GETNUMCMDS, appcmds_getNumCmds); +CB(APPCMDS_ENUMCMD, appcmds_enumCmd); +VCB(APPCMDS_ONCOMMAND, appcmds_onCommand); +END_DISPATCH; +#undef CBCLASS + +AppCmdsI::~AppCmdsI() +{ + foreach(cmds) + if (cmds.getfor()->autodelete) + delete cmds.getfor(); + endfor +} + +void AppCmdsI::appcmds_addCmd(CmdRec *cmdrec) +{ + cmds.addItem(cmdrec); +} + +void AppCmdsI::appcmds_addCmd(const wchar_t *name, int id, int side) +{ + cmds.addItem(new CmdRec(name, id, side, TRUE)); +} + +void AppCmdsI::appcmds_deleteAll() +{ + foreach(cmds) + if (cmds.getfor()->autodelete) delete cmds.getfor(); + endfor + cmds.removeAll(); +} + +int AppCmdsI::appcmds_getNumCmds() +{ + return cmds.getNumItems(); +} + +const wchar_t *AppCmdsI::appcmds_enumCmd(int n, int *side, int *id) +{ + CmdRec *cr = cmds[n]; + if (cr == NULL) return NULL; + if (side != NULL) *side = cr->side; + if (id != NULL) *id = cr->id; + return cr->cmdname; +} + +void AppCmdsI::appcmds_onCommand(int id, const RECT *buttonRect, int which_button) +{ + foreach(cmds) + if (cmds.getfor()->id == id) + { + cmds.getfor()->onCommand(buttonRect, which_button); + break; + } + endfor +} |