mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-14 05:44:20 +00:00
165 lines
5.0 KiB
C++
165 lines
5.0 KiB
C++
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef CacheFileChunk__h__
|
|
#define CacheFileChunk__h__
|
|
|
|
#include "CacheFileIOManager.h"
|
|
#include "CacheStorageService.h"
|
|
#include "CacheHashUtils.h"
|
|
#include "CacheFileUtils.h"
|
|
#include "nsAutoPtr.h"
|
|
#include "mozilla/Mutex.h"
|
|
|
|
namespace mozilla {
|
|
namespace net {
|
|
|
|
#define kChunkSize (256 * 1024)
|
|
#define kEmptyChunkHash 0x1826
|
|
|
|
class CacheFileChunk;
|
|
class CacheFile;
|
|
|
|
|
|
#define CACHEFILECHUNKLISTENER_IID \
|
|
{ /* baf16149-2ab5-499c-a9c2-5904eb95c288 */ \
|
|
0xbaf16149, \
|
|
0x2ab5, \
|
|
0x499c, \
|
|
{0xa9, 0xc2, 0x59, 0x04, 0xeb, 0x95, 0xc2, 0x88} \
|
|
}
|
|
|
|
class CacheFileChunkListener : public nsISupports
|
|
{
|
|
public:
|
|
NS_DECLARE_STATIC_IID_ACCESSOR(CACHEFILECHUNKLISTENER_IID)
|
|
|
|
NS_IMETHOD OnChunkRead(nsresult aResult, CacheFileChunk *aChunk) = 0;
|
|
NS_IMETHOD OnChunkWritten(nsresult aResult, CacheFileChunk *aChunk) = 0;
|
|
NS_IMETHOD OnChunkAvailable(nsresult aResult, uint32_t aChunkIdx,
|
|
CacheFileChunk *aChunk) = 0;
|
|
NS_IMETHOD OnChunkUpdated(CacheFileChunk *aChunk) = 0;
|
|
};
|
|
|
|
NS_DEFINE_STATIC_IID_ACCESSOR(CacheFileChunkListener,
|
|
CACHEFILECHUNKLISTENER_IID)
|
|
|
|
|
|
class ChunkListenerItem {
|
|
public:
|
|
ChunkListenerItem() { MOZ_COUNT_CTOR(ChunkListenerItem); }
|
|
~ChunkListenerItem() { MOZ_COUNT_DTOR(ChunkListenerItem); }
|
|
|
|
nsCOMPtr<nsIEventTarget> mTarget;
|
|
nsCOMPtr<CacheFileChunkListener> mCallback;
|
|
};
|
|
|
|
class ChunkListeners {
|
|
public:
|
|
ChunkListeners() { MOZ_COUNT_CTOR(ChunkListeners); }
|
|
~ChunkListeners() { MOZ_COUNT_DTOR(ChunkListeners); }
|
|
|
|
nsTArray<ChunkListenerItem *> mItems;
|
|
};
|
|
|
|
class CacheFileChunk : public CacheFileIOListener
|
|
, public CacheMemoryConsumer
|
|
{
|
|
public:
|
|
NS_DECL_THREADSAFE_ISUPPORTS
|
|
bool DispatchRelease();
|
|
|
|
CacheFileChunk(CacheFile *aFile, uint32_t aIndex, bool aInitByWriter);
|
|
|
|
void InitNew();
|
|
nsresult Read(CacheFileHandle *aHandle, uint32_t aLen,
|
|
CacheHash::Hash16_t aHash,
|
|
CacheFileChunkListener *aCallback);
|
|
nsresult Write(CacheFileHandle *aHandle, CacheFileChunkListener *aCallback);
|
|
void WaitForUpdate(CacheFileChunkListener *aCallback);
|
|
nsresult CancelWait(CacheFileChunkListener *aCallback);
|
|
nsresult NotifyUpdateListeners();
|
|
|
|
uint32_t Index();
|
|
CacheHash::Hash16_t Hash();
|
|
uint32_t DataSize();
|
|
void UpdateDataSize(uint32_t aOffset, uint32_t aLen,
|
|
bool aEOF);
|
|
|
|
NS_IMETHOD OnFileOpened(CacheFileHandle *aHandle, nsresult aResult);
|
|
NS_IMETHOD OnDataWritten(CacheFileHandle *aHandle, const char *aBuf,
|
|
nsresult aResult);
|
|
NS_IMETHOD OnDataRead(CacheFileHandle *aHandle, char *aBuf, nsresult aResult);
|
|
NS_IMETHOD OnFileDoomed(CacheFileHandle *aHandle, nsresult aResult);
|
|
NS_IMETHOD OnEOFSet(CacheFileHandle *aHandle, nsresult aResult);
|
|
NS_IMETHOD OnFileRenamed(CacheFileHandle *aHandle, nsresult aResult);
|
|
|
|
bool IsReady() const;
|
|
bool IsDirty() const;
|
|
|
|
nsresult GetStatus();
|
|
void SetError(nsresult aStatus);
|
|
|
|
char * BufForWriting() const;
|
|
const char * BufForReading() const;
|
|
nsresult EnsureBufSize(uint32_t aBufSize);
|
|
uint32_t MemorySize() const { return sizeof(CacheFileChunk) + mRWBufSize + mBufSize; }
|
|
|
|
// Memory reporting
|
|
size_t SizeOfExcludingThis(mozilla::MallocSizeOf mallocSizeOf) const;
|
|
size_t SizeOfIncludingThis(mozilla::MallocSizeOf mallocSizeOf) const;
|
|
|
|
private:
|
|
friend class CacheFileInputStream;
|
|
friend class CacheFileOutputStream;
|
|
friend class CacheFile;
|
|
|
|
virtual ~CacheFileChunk();
|
|
|
|
bool CanAllocate(uint32_t aSize);
|
|
void ChunkAllocationChanged();
|
|
mozilla::Atomic<uint32_t>& ChunksMemoryUsage();
|
|
|
|
enum EState {
|
|
INITIAL = 0,
|
|
READING = 1,
|
|
WRITING = 2,
|
|
READY = 3
|
|
};
|
|
|
|
uint32_t mIndex;
|
|
EState mState;
|
|
nsresult mStatus;
|
|
bool mIsDirty;
|
|
bool mActiveChunk; // Is true iff the chunk is in CacheFile::mChunks.
|
|
// Adding/removing chunk to/from mChunks as well as
|
|
// changing this member happens under the CacheFile's
|
|
// lock.
|
|
uint32_t mDataSize;
|
|
|
|
uint32_t mReportedAllocation;
|
|
bool const mLimitAllocation : 1; // Whether this chunk respects limit for disk
|
|
// chunks memory usage.
|
|
bool const mIsPriority : 1;
|
|
|
|
char *mBuf;
|
|
uint32_t mBufSize;
|
|
|
|
char *mRWBuf;
|
|
uint32_t mRWBufSize;
|
|
CacheHash::Hash16_t mReadHash;
|
|
|
|
nsRefPtr<CacheFile> mFile; // is null if chunk is cached to
|
|
// prevent reference cycles
|
|
nsCOMPtr<CacheFileChunkListener> mListener;
|
|
nsTArray<ChunkListenerItem *> mUpdateListeners;
|
|
CacheFileUtils::ValidityMap mValidityMap;
|
|
};
|
|
|
|
|
|
} // net
|
|
} // mozilla
|
|
|
|
#endif
|