aboutsummaryrefslogtreecommitdiff
path: root/Src/Winamp/FeedBase.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/Winamp/FeedBase.h
parent4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff)
parent20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff)
downloadwinamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Winamp/FeedBase.h')
-rw-r--r--Src/Winamp/FeedBase.h33
1 files changed, 33 insertions, 0 deletions
diff --git a/Src/Winamp/FeedBase.h b/Src/Winamp/FeedBase.h
new file mode 100644
index 00000000..6007a008
--- /dev/null
+++ b/Src/Winamp/FeedBase.h
@@ -0,0 +1,33 @@
+#ifndef NULLSOFT_WINAMP_FEEDBASE_H
+#define NULLSOFT_WINAMP_FEEDBASE_H
+
+#include <api/dependency/api_dependent.h>
+#include <api/skin/feeds/api_textfeed.h>
+#include <vector>
+#include <bfc/multipatch.h>
+
+enum {DependentPatch = 10, TextFeedPatch = 20 };
+
+class FeedBase
+ : public MultiPatch<DependentPatch, api_dependent>,
+ public MultiPatch<TextFeedPatch, svc_textFeed>
+{
+private:
+ void dependent_regViewer(api_dependentviewer *viewer, int add);
+ void *dependent_getInterface(const GUID *classguid);
+
+ virtual int hasFeed(const wchar_t *name)=0;
+ virtual const wchar_t *getFeedText(const wchar_t *name)=0;
+ virtual const wchar_t *getFeedDescription(const wchar_t *name)=0;
+ api_dependent *getDependencyPtr();
+protected:
+ void CallViewers(const wchar_t *feedid, const wchar_t *text, size_t length);
+
+protected:
+ std::vector<api_dependentviewer*> viewers;
+
+protected:
+ RECVS_MULTIPATCH;
+};
+
+#endif \ No newline at end of file