Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(406)

Unified Diff: remoting/protocol/jingle_session.h

Issue 2453933008: Bugfixes in JingleSession (Closed)
Patch Set: Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: remoting/protocol/jingle_session.h
diff --git a/remoting/protocol/jingle_session.h b/remoting/protocol/jingle_session.h
index 5d53a4b6a303f95e3c4dbf62cff7f1b467ec203e..9efd42e21e5ec1527effb570c451df4f9c59b8a5 100644
--- a/remoting/protocol/jingle_session.h
+++ b/remoting/protocol/jingle_session.h
@@ -5,9 +5,8 @@
#ifndef REMOTING_PROTOCOL_JINGLE_SESSION_H_
#define REMOTING_PROTOCOL_JINGLE_SESSION_H_
-#include <list>
-#include <set>
#include <string>
+#include <vector>
#include "base/macros.h"
#include "base/memory/ref_counted.h"
@@ -97,6 +96,8 @@ class JingleSession : public Session {
const ReplyCallback& reply_callback);
void OnSessionInfo(std::unique_ptr<JingleMessage> message,
const ReplyCallback& reply_callback);
+ void OnTransportInfo(std::unique_ptr<JingleMessage> message,
+ const ReplyCallback& reply_callback);
void OnTerminate(std::unique_ptr<JingleMessage> message,
const ReplyCallback& reply_callback);
@@ -109,9 +110,6 @@ class JingleSession : public Session {
// Called after subsequent authenticator messages are processed.
void ProcessAuthenticationStep();
- // Called after the authenticating step is finished.
- void ContinueAuthenticationStep();
-
// Called when authentication is finished.
void OnAuthenticated();
@@ -142,17 +140,20 @@ class JingleSession : public Session {
Transport* transport_ = nullptr;
// Pending Iq requests. Used for all messages except transport-info.
- std::set<std::unique_ptr<IqRequest>> pending_requests_;
+ std::vector<std::unique_ptr<IqRequest>> pending_requests_;
// Pending transport-info requests.
- std::list<std::unique_ptr<IqRequest>> transport_info_requests_;
+ std::vector<std::unique_ptr<IqRequest>> transport_info_requests_;
struct PendingMessage {
+ PendingMessage();
+ PendingMessage(PendingMessage&& moved);
PendingMessage(std::unique_ptr<JingleMessage> message,
const ReplyCallback& reply_callback);
~PendingMessage();
+ PendingMessage& operator=(PendingMessage&& moved);
std::unique_ptr<JingleMessage> message;
- const ReplyCallback reply_callback;
+ ReplyCallback reply_callback;
};
// A message queue to guarantee the incoming messages are processed in order.
@@ -164,6 +165,10 @@ class JingleSession : public Session {
std::string outgoing_id_prefix_ = base::Uint64ToString(base::RandUint64());
int next_outgoing_id_ = 0;
+ // Transport info messages that are received while the session is being
+ // authenticated.
+ std::vector<PendingMessage> pending_transport_info_;
+
base::WeakPtrFactory<JingleSession> weak_factory_;
DISALLOW_COPY_AND_ASSIGN(JingleSession);

Powered by Google App Engine
This is Rietveld 408576698