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/omBrowser/cacheManager.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/omBrowser/cacheManager.h')
-rw-r--r-- | Src/omBrowser/cacheManager.h | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/Src/omBrowser/cacheManager.h b/Src/omBrowser/cacheManager.h new file mode 100644 index 00000000..2ba3c94b --- /dev/null +++ b/Src/omBrowser/cacheManager.h @@ -0,0 +1,47 @@ +#ifndef NULLSOFT_WINAMP_CACHE_MANAGER_HEADER +#define NULLSOFT_WINAMP_CACHE_MANAGER_HEADER + +#if defined(_MSC_VER) && (_MSC_VER >= 1020) +#pragma once +#endif + +#include <wtypes.h> +#include "./ifc_omcachemanager.h" +#include <vector> + +class CacheGroup; + +class CacheManager : public ifc_omcachemanager +{ +protected: + CacheManager(); + ~CacheManager(); + +public: + static HRESULT CreateInstance(CacheManager **instace); + +public: + /* Dispatchable */ + size_t AddRef(); + size_t Release(); + int QueryInterface(GUID interface_guid, void **object); + + HRESULT Load(); + + /* group managment */ + HRESULT Find(LPCWSTR pszGroup, BOOL fInsertMissing, CacheGroup **groupOut, BOOL *created); + HRESULT Delete(LPCWSTR pszGroup); + HRESULT Clear(); + + HRESULT GetPath(LPWSTR pszBuffer, UINT cchBufferMax); + +protected: + RECVS_DISPATCH; + typedef std::vector<CacheGroup*> GroupList; + +protected: + size_t ref; + GroupList groupList; +}; + +#endif //NULLSOFT_WINAMP_CACHE_MANAGER_HEADER
\ No newline at end of file |