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

Unified Diff: webrtc/p2p/base/p2ptransportchannel.cc

Issue 2590063002: Make P2PTransportChannel inherit from IceTransportInternal. (Closed)
Patch Set: Modified the debug_name(). Created 4 years 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
« no previous file with comments | « webrtc/p2p/base/p2ptransportchannel.h ('k') | webrtc/p2p/base/p2ptransportchannel_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/p2p/base/p2ptransportchannel.cc
diff --git a/webrtc/p2p/base/p2ptransportchannel.cc b/webrtc/p2p/base/p2ptransportchannel.cc
index 5f858c4858f952174b878891a875648bbd69de43..517f59671bb88b945344d05de138a864faf34099 100644
--- a/webrtc/p2p/base/p2ptransportchannel.cc
+++ b/webrtc/p2p/base/p2ptransportchannel.cc
@@ -100,7 +100,8 @@ static constexpr int b_is_better = -1;
P2PTransportChannel::P2PTransportChannel(const std::string& transport_name,
int component,
PortAllocator* allocator)
- : TransportChannelImpl(transport_name, component),
+ : transport_name_(transport_name),
+ component_(component),
allocator_(allocator),
network_thread_(rtc::Thread::Current()),
incoming_only_(false),
@@ -271,15 +272,15 @@ void P2PTransportChannel::SetIceTiebreaker(uint64_t tiebreaker) {
tiebreaker_ = tiebreaker;
}
-TransportChannelState P2PTransportChannel::GetState() const {
+IceTransportState P2PTransportChannel::GetState() const {
return state_;
}
// A channel is considered ICE completed once there is at most one active
// connection per network and at least one active connection.
-TransportChannelState P2PTransportChannel::ComputeState() const {
+IceTransportState P2PTransportChannel::ComputeState() const {
if (!had_connection_) {
- return TransportChannelState::STATE_INIT;
+ return IceTransportState::STATE_INIT;
}
std::vector<Connection*> active_connections;
@@ -289,7 +290,7 @@ TransportChannelState P2PTransportChannel::ComputeState() const {
}
}
if (active_connections.empty()) {
- return TransportChannelState::STATE_FAILED;
+ return IceTransportState::STATE_FAILED;
}
std::set<rtc::Network*> networks;
@@ -301,11 +302,11 @@ TransportChannelState P2PTransportChannel::ComputeState() const {
LOG_J(LS_VERBOSE, this) << "Ice not completed yet for this channel as "
<< network->ToString()
<< " has more than 1 connection.";
- return TransportChannelState::STATE_CONNECTING;
+ return IceTransportState::STATE_CONNECTING;
}
}
- return TransportChannelState::STATE_COMPLETED;
+ return IceTransportState::STATE_COMPLETED;
}
void P2PTransportChannel::SetIceParameters(const IceParameters& ice_params) {
@@ -1399,33 +1400,38 @@ void P2PTransportChannel::SwitchSelectedConnection(Connection* conn) {
// change, it should be called after all the connection states have changed. For
// example, we call this at the end of SortConnectionsAndUpdateState.
void P2PTransportChannel::UpdateState() {
- TransportChannelState state = ComputeState();
+ IceTransportState state = ComputeState();
if (state_ != state) {
- LOG_J(LS_INFO, this) << "Transport channel state changed from " << state_
- << " to " << state;
+ LOG_J(LS_INFO, this) << "Transport channel state changed from "
+ << static_cast<int>(state_) << " to "
+ << static_cast<int>(state);
// Check that the requested transition is allowed. Note that
// P2PTransportChannel does not (yet) implement a direct mapping of the ICE
// states from the standard; the difference is covered by
// TransportController and PeerConnection.
switch (state_) {
- case STATE_INIT:
+ case IceTransportState::STATE_INIT:
// TODO(deadbeef): Once we implement end-of-candidates signaling,
// we shouldn't go from INIT to COMPLETED.
- RTC_DCHECK(state == STATE_CONNECTING || state == STATE_COMPLETED);
+ RTC_DCHECK(state == IceTransportState::STATE_CONNECTING ||
+ state == IceTransportState::STATE_COMPLETED);
break;
- case STATE_CONNECTING:
- RTC_DCHECK(state == STATE_COMPLETED || state == STATE_FAILED);
+ case IceTransportState::STATE_CONNECTING:
+ RTC_DCHECK(state == IceTransportState::STATE_COMPLETED ||
+ state == IceTransportState::STATE_FAILED);
break;
- case STATE_COMPLETED:
+ case IceTransportState::STATE_COMPLETED:
// TODO(deadbeef): Once we implement end-of-candidates signaling,
// we shouldn't go from COMPLETED to CONNECTING.
// Though we *can* go from COMPlETED to FAILED, if consent expires.
- RTC_DCHECK(state == STATE_CONNECTING || state == STATE_FAILED);
+ RTC_DCHECK(state == IceTransportState::STATE_CONNECTING ||
+ state == IceTransportState::STATE_FAILED);
break;
- case STATE_FAILED:
+ case IceTransportState::STATE_FAILED:
// TODO(deadbeef): Once we implement end-of-candidates signaling,
// we shouldn't go from FAILED to CONNECTING or COMPLETED.
- RTC_DCHECK(state == STATE_CONNECTING || state == STATE_COMPLETED);
+ RTC_DCHECK(state == IceTransportState::STATE_CONNECTING ||
+ state == IceTransportState::STATE_COMPLETED);
break;
default:
RTC_DCHECK(false);
@@ -1541,8 +1547,8 @@ void P2PTransportChannel::OnCheckAndPing() {
// A connection is considered a backup connection if the channel state
// is completed, the connection is not the selected connection and it is active.
bool P2PTransportChannel::IsBackupConnection(const Connection* conn) const {
- return state_ == STATE_COMPLETED && conn != selected_connection_ &&
- conn->active();
+ return state_ == IceTransportState::STATE_COMPLETED &&
+ conn != selected_connection_ && conn->active();
}
// Is the connection in a state for us to even consider pinging the other side?
@@ -2022,4 +2028,25 @@ Connection* P2PTransportChannel::MorePingable(Connection* conn1,
}));
}
+void P2PTransportChannel::set_writable(bool writable) {
+ if (writable_ == writable) {
+ return;
+ }
+ LOG_J(LS_VERBOSE, this) << "set_writable from:" << writable_ << " to "
+ << writable;
+ writable_ = writable;
+ if (writable_) {
+ SignalReadyToSend(this);
+ }
+ SignalWritableState(this);
+}
+
+void P2PTransportChannel::set_receiving(bool receiving) {
+ if (receiving_ == receiving) {
+ return;
+ }
+ receiving_ = receiving;
+ SignalReceivingState(this);
+}
+
} // namespace cricket
« no previous file with comments | « webrtc/p2p/base/p2ptransportchannel.h ('k') | webrtc/p2p/base/p2ptransportchannel_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698