| Index: mojo/services/public/cpp/network/web_socket_read_queue.h
|
| diff --git a/mojo/services/public/cpp/network/web_socket_read_queue.h b/mojo/services/public/cpp/network/web_socket_read_queue.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..6108e49f9a40f528c2cde3b206cb52e5b78e8f4d
|
| --- /dev/null
|
| +++ b/mojo/services/public/cpp/network/web_socket_read_queue.h
|
| @@ -0,0 +1,42 @@
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef MOJO_SERVICES_PUBLIC_CPP_NETWORK_WEB_SOCKET_READ_QUEUE_H_
|
| +#define MOJO_SERVICES_PUBLIC_CPP_NETWORK_WEB_SOCKET_READ_QUEUE_H_
|
| +
|
| +#include "base/callback.h"
|
| +#include "base/memory/scoped_vector.h"
|
| +#include "mojo/common/handle_watcher.h"
|
| +#include "mojo/public/cpp/system/data_pipe.h"
|
| +
|
| +namespace mojo {
|
| +
|
| +// This class simplifies the handling of multiple Reads on a DataPipe. It reads
|
| +// the data in the expected chunk size, calling the callback once a full chunk
|
| +// is ready. Callbacks are owned by this class, and are guaranteed not to be
|
| +// called after this class is destroyed.
|
| +// See also: WebSocketWriteQueue
|
| +class WebSocketReadQueue {
|
| + public:
|
| + WebSocketReadQueue(DataPipeConsumerHandle handle);
|
| + ~WebSocketReadQueue();
|
| +
|
| + void Read(uint32_t num_bytes, base::Callback<void(const char*)> callback);
|
| +
|
| + private:
|
| + struct Operation;
|
| +
|
| + void TryToRead();
|
| + void Wait();
|
| + void OnHandleReady(MojoResult result);
|
| +
|
| + DataPipeConsumerHandle handle_;
|
| + common::HandleWatcher handle_watcher_;
|
| + ScopedVector<Operation> queue_;
|
| + bool is_waiting_;
|
| +};
|
| +
|
| +} // namespace mojo
|
| +
|
| +#endif // MOJO_SERVICES_PUBLIC_CPP_NETWORK_WEB_SOCKET_READ_QUEUE_H_
|
|
|