| Index: blimp/net/blob_channel/blob_channel_receiver.h
|
| diff --git a/blimp/net/blob_channel/blob_channel_receiver.h b/blimp/net/blob_channel/blob_channel_receiver.h
|
| index bdfcd236bd62e5a58da2c0d41f1fe0cc1592b75e..d9ae4a03db921ea921012de513570db91b9e7c5a 100644
|
| --- a/blimp/net/blob_channel/blob_channel_receiver.h
|
| +++ b/blimp/net/blob_channel/blob_channel_receiver.h
|
| @@ -16,52 +16,31 @@ namespace blimp {
|
|
|
| class BlobCache;
|
|
|
| -// Receives blobs from a remote sender.
|
| class BLIMP_NET_EXPORT BlobChannelReceiver {
|
| public:
|
| class Delegate {
|
| public:
|
| - Delegate();
|
| - virtual ~Delegate();
|
| -
|
| - protected:
|
| - // Forwards incoming blob data to |receiver_|.
|
| - void OnBlobReceived(const BlobId& id, BlobDataPtr data);
|
| -
|
| - private:
|
| - friend class BlobChannelReceiver;
|
| + virtual ~Delegate() {}
|
|
|
| // Sets the Receiver object which will take incoming blobs.
|
| - void SetReceiver(BlobChannelReceiver* receiver);
|
| -
|
| - BlobChannelReceiver* receiver_ = nullptr;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(Delegate);
|
| + virtual void SetReceiver(BlobChannelReceiver* receiver) = 0;
|
| };
|
|
|
| - BlobChannelReceiver(std::unique_ptr<BlobCache> cache,
|
| - std::unique_ptr<Delegate> delegate);
|
| - ~BlobChannelReceiver();
|
| + virtual ~BlobChannelReceiver() {}
|
| +
|
| + // Constructs a BlobChannelReceiverImpl object for use.
|
| + static std::unique_ptr<BlobChannelReceiver> Create(
|
| + std::unique_ptr<BlobCache> cache,
|
| + std::unique_ptr<Delegate> delegate);
|
|
|
| // Gets a blob from the BlobChannel.
|
| // Returns nullptr if the blob is not available in the channel.
|
| // Can be accessed concurrently from any thread. Calling code must ensure that
|
| // the object instance outlives all calls to Get().
|
| - BlobDataPtr Get(const BlobId& id);
|
| -
|
| - private:
|
| - friend class Delegate;
|
| + virtual BlobDataPtr Get(const BlobId& id) = 0;
|
|
|
| // Called by Delegate::OnBlobReceived() when a blob arrives over the channel.
|
| - void OnBlobReceived(const BlobId& id, BlobDataPtr data);
|
| -
|
| - std::unique_ptr<BlobCache> cache_;
|
| - std::unique_ptr<Delegate> delegate_;
|
| -
|
| - // Guards against concurrent access to |cache_|.
|
| - base::Lock cache_lock_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(BlobChannelReceiver);
|
| + virtual void OnBlobReceived(const BlobId& id, BlobDataPtr data) = 0;
|
| };
|
|
|
| } // namespace blimp
|
|
|