From 7d6b896aeb696ba04b9acfdc88708785df15289a Mon Sep 17 00:00:00 2001 From: "jar@chromium.org" Date: Fri, 9 Apr 2010 16:25:08 +0000 Subject: Revert 44092 - Add support for the SPDY session frame. per request from Mbelshe... reverting to fix tree. BUG=34749 TEST=SpdyNetworkTransactionTest.SettingsSaved, SettingsPlayback Review URL: http://codereview.chromium.org/1595013 TBR=mbelshe@chromium.org Review URL: http://codereview.chromium.org/1621009 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@44093 0039d316-1c4b-4281-b951-d872f2087c98 --- net/spdy/spdy_framer.cc | 5 - net/spdy/spdy_framer.h | 3 +- net/spdy/spdy_network_transaction_unittest.cc | 263 +------------------------- net/spdy/spdy_protocol.h | 6 - net/spdy/spdy_session.cc | 111 +++++------ net/spdy/spdy_session.h | 14 +- net/spdy/spdy_settings_storage.cc | 46 ----- net/spdy/spdy_settings_storage.h | 39 ---- 8 files changed, 48 insertions(+), 439 deletions(-) delete mode 100644 net/spdy/spdy_settings_storage.cc delete mode 100644 net/spdy/spdy_settings_storage.h (limited to 'net/spdy') diff --git a/net/spdy/spdy_framer.cc b/net/spdy/spdy_framer.cc index 65ef2e5..864a0d9 100644 --- a/net/spdy/spdy_framer.cc +++ b/net/spdy/spdy_framer.cc @@ -298,11 +298,6 @@ void SpdyFramer::ProcessControlFrameHeader() { SpdyGoAwayControlFrame::size() - SpdyFrame::size()) set_error(SPDY_INVALID_CONTROL_FRAME); break; - case SETTINGS: - if (current_control_frame.length() < - SpdySettingsControlFrame::size() - SpdyControlFrame::size()) - set_error(SPDY_INVALID_CONTROL_FRAME); - break; default: LOG(WARNING) << "Valid spdy control frame with unknown type: " << current_control_frame.type(); diff --git a/net/spdy/spdy_framer.h b/net/spdy/spdy_framer.h index c265be9..ab454cd 100644 --- a/net/spdy/spdy_framer.h +++ b/net/spdy/spdy_framer.h @@ -43,8 +43,7 @@ void FramerSetEnableCompressionHelper(SpdyFramer* framer, bool compress); typedef std::map SpdyHeaderBlock; // A datastructure for holding a set of ID/value pairs for a SETTINGS frame. -typedef std::pair SpdySetting; -typedef std::list SpdySettings; +typedef std::list > SpdySettings; // SpdyFramerVisitorInterface is a set of callbacks for the SpdyFramer. // Implement this interface to receive event callbacks as frames are diff --git a/net/spdy/spdy_network_transaction_unittest.cc b/net/spdy/spdy_network_transaction_unittest.cc index d7d0cdf..fb06906 100644 --- a/net/spdy/spdy_network_transaction_unittest.cc +++ b/net/spdy/spdy_network_transaction_unittest.cc @@ -294,10 +294,6 @@ void AppendHeadersToSpdyFrame(const char* const extra_headers[], spdy::SpdyHeaderBlock* headers) { std::string this_header; std::string this_value; - - if (!extra_header_count) - return; - // Sanity check: Non-NULL header list. DCHECK(NULL != extra_headers) << "NULL header value pair list"; // Sanity check: Non-NULL header map. @@ -500,14 +496,6 @@ int ConstructSpdyReply(const char* const extra_headers[], return packet_size; } -// Construct an expected SPDY SETTINGS frame. -// |settings| are the settings to set. -// Returns the constructed frame. The caller takes ownership of the frame. -spdy::SpdyFrame* ConstructSpdySettings(spdy::SpdySettings settings) { - spdy::SpdyFramer framer; - return framer.CreateSettings(settings); -} - // Construct a single SPDY header entry, for validation. // |extra_headers| are the extra header-value pairs. // |buffer| is the buffer we're filling in. @@ -804,28 +792,16 @@ class SpdyNetworkTransactionTest : public PlatformTest { TransactionHelperResult TransactionHelper(const HttpRequestInfo& request, DelayedSocketData* data, const BoundNetLog& log) { - SessionDependencies session_deps; - HttpNetworkSession* session = CreateSession(&session_deps); - return TransactionHelperWithSession(request, data, log, &session_deps, - session); - } - - TransactionHelperResult TransactionHelperWithSession( - const HttpRequestInfo& request, DelayedSocketData* data, - const BoundNetLog& log, SessionDependencies* session_deps, - HttpNetworkSession* session) { - CHECK(session); - CHECK(session_deps); - TransactionHelperResult out; // We disable SSL for this test. SpdySession::SetSSLMode(false); + SessionDependencies session_deps; scoped_ptr trans( - new SpdyNetworkTransaction(session)); + new SpdyNetworkTransaction(CreateSession(&session_deps))); - session_deps->socket_factory.AddSocketDataProvider(data); + session_deps.socket_factory.AddSocketDataProvider(data); TestCompletionCallback callback; @@ -2478,237 +2454,4 @@ TEST_F(SpdyNetworkTransactionTest, BufferedCancelled) { MessageLoop::current()->RunAllPending(); } -// Test that if the server requests persistence of settings, that we save -// the settings in the SpdySettingsStorage. -TEST_F(SpdyNetworkTransactionTest, SettingsSaved) { - static const SpdyHeaderInfo kSynReplyInfo = { - spdy::SYN_REPLY, // Syn Reply - 1, // Stream ID - 0, // Associated Stream ID - 3, // Priority - spdy::CONTROL_FLAG_NONE, // Control Flags - false, // Compressed - 200, // Status - NULL, // Data - 0, // Data Length - spdy::DATA_FLAG_NONE // Data Flags - }; - static const char* const kExtraHeaders[] = { - "status", "200", - "version", "HTTP/1.1" - }; - - SessionDependencies session_deps; - scoped_refptr session(CreateSession(&session_deps)); - - // Verify that no settings exist initially. - HostPortPair host_port_pair("www.google.com", 80); - EXPECT_TRUE(session->spdy_settings().Get(host_port_pair).empty()); - - // Construct the request. - scoped_ptr req(ConstructSpdyGet(NULL, 0)); - - MockWrite writes[] = { - MockWrite(true, req->data(), req->length() + spdy::SpdyFrame::size()), - }; - - // Construct the reply. - scoped_ptr reply( - ConstructSpdyPacket(&kSynReplyInfo, - kExtraHeaders, - arraysize(kExtraHeaders) / 2, - NULL, - 0)); - - unsigned int kSampleId1 = 0x1; - unsigned int kSampleValue1 = 0x0a0a0a0a; - unsigned int kSampleId2 = 0x2; - unsigned int kSampleValue2 = 0x0b0b0b0b; - unsigned int kSampleId3 = 0xababab; - unsigned int kSampleValue3 = 0x0c0c0c0c; - scoped_ptr settings_frame; - { - // Construct the SETTINGS frame. - spdy::SpdySettings settings; - spdy::SettingsFlagsAndId setting(0); - // First add a persisted setting - setting.set_flags(spdy::SETTINGS_FLAG_PLEASE_PERSIST); - setting.set_id(kSampleId1); - settings.push_back(std::make_pair(setting, kSampleValue1)); - // Next add a non-persisted setting - setting.set_flags(0); - setting.set_id(kSampleId2); - settings.push_back(std::make_pair(setting, kSampleValue2)); - // Next add another persisted setting - setting.set_flags(spdy::SETTINGS_FLAG_PLEASE_PERSIST); - setting.set_id(kSampleId3); - settings.push_back(std::make_pair(setting, kSampleValue3)); - settings_frame.reset(ConstructSpdySettings(settings)); - } - - MockRead reads[] = { - MockRead(true, reply->data(), reply->length() + spdy::SpdyFrame::size()), - MockRead(true, reinterpret_cast(kGetBodyFrame), - arraysize(kGetBodyFrame)), - MockRead(true, settings_frame->data(), - settings_frame->length() + spdy::SpdyFrame::size()), - MockRead(true, 0, 0) // EOF - }; - - HttpRequestInfo request; - request.method = "GET"; - request.url = GURL("http://www.google.com/"); - request.load_flags = 0; - - scoped_refptr data( - new DelayedSocketData(1, reads, arraysize(reads), - writes, arraysize(writes))); - TransactionHelperResult out = TransactionHelperWithSession(request, - data.get(), - NULL, - &session_deps, - session.get()); - EXPECT_EQ(OK, out.rv); - EXPECT_EQ("HTTP/1.1 200 OK", out.status_line); - EXPECT_EQ("hello!", out.response_data); - - { - // Verify we had two persisted settings. - spdy::SpdySettings saved_settings = - session->spdy_settings().Get(host_port_pair); - ASSERT_EQ(2u, saved_settings.size()); - - // Verify the first persisted setting. - spdy::SpdySetting setting = saved_settings.front(); - saved_settings.pop_front(); - EXPECT_EQ(spdy::SETTINGS_FLAG_PERSISTED, setting.first.flags()); - EXPECT_EQ(kSampleId1, setting.first.id()); - EXPECT_EQ(kSampleValue1, setting.second); - - // Verify the second persisted setting. - setting = saved_settings.front(); - saved_settings.pop_front(); - EXPECT_EQ(spdy::SETTINGS_FLAG_PERSISTED, setting.first.flags()); - EXPECT_EQ(kSampleId3, setting.first.id()); - EXPECT_EQ(kSampleValue3, setting.second); - } -} - -// Test that when there are settings saved that they are sent back to the -// server upon session establishment. -TEST_F(SpdyNetworkTransactionTest, SettingsPlayback) { - static const SpdyHeaderInfo kSynReplyInfo = { - spdy::SYN_REPLY, // Syn Reply - 1, // Stream ID - 0, // Associated Stream ID - 3, // Priority - spdy::CONTROL_FLAG_NONE, // Control Flags - false, // Compressed - 200, // Status - NULL, // Data - 0, // Data Length - spdy::DATA_FLAG_NONE // Data Flags - }; - static const char* kExtraHeaders[] = { - "status", "200", - "version", "HTTP/1.1" - }; - - SessionDependencies session_deps; - scoped_refptr session(CreateSession(&session_deps)); - - // Verify that no settings exist initially. - HostPortPair host_port_pair("www.google.com", 80); - EXPECT_TRUE(session->spdy_settings().Get(host_port_pair).empty()); - - unsigned int kSampleId1 = 0x1; - unsigned int kSampleValue1 = 0x0a0a0a0a; - unsigned int kSampleId2 = 0xababab; - unsigned int kSampleValue2 = 0x0c0c0c0c; - // Manually insert settings into the SpdySettingsStorage here. - { - spdy::SpdySettings settings; - spdy::SettingsFlagsAndId setting(0); - // First add a persisted setting - setting.set_flags(spdy::SETTINGS_FLAG_PLEASE_PERSIST); - setting.set_id(kSampleId1); - settings.push_back(std::make_pair(setting, kSampleValue1)); - // Next add another persisted setting - setting.set_flags(spdy::SETTINGS_FLAG_PLEASE_PERSIST); - setting.set_id(kSampleId2); - settings.push_back(std::make_pair(setting, kSampleValue2)); - - session->mutable_spdy_settings()->Set(host_port_pair, settings); - } - - EXPECT_EQ(2u, session->spdy_settings().Get(host_port_pair).size()); - - // Construct the SETTINGS frame. - const spdy::SpdySettings& settings = - session->spdy_settings().Get(host_port_pair); - scoped_ptr settings_frame(ConstructSpdySettings(settings)); - - // Construct the request. - scoped_ptr req(ConstructSpdyGet(NULL, 0)); - - MockWrite writes[] = { - MockWrite(true, settings_frame->data(), - settings_frame->length() + spdy::SpdyFrame::size()), - MockWrite(true, req->data(), req->length() + spdy::SpdyFrame::size()), - }; - - // Construct the reply. - scoped_ptr reply( - ConstructSpdyPacket(&kSynReplyInfo, - kExtraHeaders, - arraysize(kExtraHeaders) / 2, - NULL, - 0)); - - MockRead reads[] = { - MockRead(true, reply->data(), reply->length() + spdy::SpdyFrame::size()), - MockRead(true, reinterpret_cast(kGetBodyFrame), - arraysize(kGetBodyFrame)), - MockRead(true, 0, 0) // EOF - }; - - HttpRequestInfo request; - request.method = "GET"; - request.url = GURL("http://www.google.com/"); - request.load_flags = 0; - - scoped_refptr data( - new DelayedSocketData(2, reads, arraysize(reads), - writes, arraysize(writes))); - TransactionHelperResult out = TransactionHelperWithSession(request, - data.get(), - NULL, - &session_deps, - session.get()); - EXPECT_EQ(OK, out.rv); - EXPECT_EQ("HTTP/1.1 200 OK", out.status_line); - EXPECT_EQ("hello!", out.response_data); - - { - // Verify we had two persisted settings. - spdy::SpdySettings saved_settings = - session->spdy_settings().Get(host_port_pair); - ASSERT_EQ(2u, saved_settings.size()); - - // Verify the first persisted setting. - spdy::SpdySetting setting = saved_settings.front(); - saved_settings.pop_front(); - EXPECT_EQ(spdy::SETTINGS_FLAG_PERSISTED, setting.first.flags()); - EXPECT_EQ(kSampleId1, setting.first.id()); - EXPECT_EQ(kSampleValue1, setting.second); - - // Verify the second persisted setting. - setting = saved_settings.front(); - saved_settings.pop_front(); - EXPECT_EQ(spdy::SETTINGS_FLAG_PERSISTED, setting.first.flags()); - EXPECT_EQ(kSampleId2, setting.first.id()); - EXPECT_EQ(kSampleValue2, setting.second); - } -} - } // namespace net diff --git a/net/spdy/spdy_protocol.h b/net/spdy/spdy_protocol.h index 435c55b..c8d5830 100644 --- a/net/spdy/spdy_protocol.h +++ b/net/spdy/spdy_protocol.h @@ -241,13 +241,7 @@ union SettingsFlagsAndId { SettingsFlagsAndId(uint32 val) : id_(val) {}; uint8 flags() const { return flags_[0]; } - void set_flags(uint8 flags) { flags_[0] = flags; } uint32 id() const { return (ntohl(id_) & kSettingsIdMask); }; - void set_id(uint32 id) { - DCHECK_EQ(0u, (id & ~kSettingsIdMask)); - id = htonl(id & kSettingsIdMask); - id_ = flags() | id; - } }; // A SETTINGS Control Frame structure. diff --git a/net/spdy/spdy_session.cc b/net/spdy/spdy_session.cc index 1ab3904..2607f90 100644 --- a/net/spdy/spdy_session.cc +++ b/net/spdy/spdy_session.cc @@ -25,7 +25,6 @@ #include "net/socket/ssl_client_socket.h" #include "net/spdy/spdy_frame_builder.h" #include "net/spdy/spdy_protocol.h" -#include "net/spdy/spdy_settings_storage.h" #include "net/spdy/spdy_stream.h" #include "net/tools/dump_cache/url_to_filename_encoder.h" @@ -216,8 +215,6 @@ SpdySession::SpdySession(const HostPortPair& host_port_pair, spdy_framer_.set_visitor(this); session_->ssl_config_service()->GetSSLConfig(&ssl_config_); - - SendSettings(); } SpdySession::~SpdySession() { @@ -370,7 +367,10 @@ scoped_refptr SpdySession::GetOrCreateStream( scoped_ptr syn_frame( spdy_framer_.CreateSynStream(stream_id, 0, request.priority, flags, false, &headers)); - QueueFrame(syn_frame.get(), request.priority, stream); + int length = spdy::SpdyFrame::size() + syn_frame->length(); + IOBuffer* buffer = new IOBuffer(length); + memcpy(buffer->data(), syn_frame->data(), length); + queue_.push(SpdyIOBuffer(buffer, length, request.priority, stream)); static StatsCounter spdy_requests("spdy.requests"); spdy_requests.Increment(); @@ -381,6 +381,14 @@ scoped_refptr SpdySession::GetOrCreateStream( LOG(INFO) << "SPDY SYN_STREAM HEADERS ----------------------------------"; DumpSpdyHeaders(headers); + // Schedule to write to the socket after we've made it back + // to the message loop so that we can aggregate multiple + // requests. + // TODO(mbelshe): Should we do the "first" request immediately? + // maybe we should only 'do later' for subsequent + // requests. + WriteSocketLater(); + return stream; } @@ -415,7 +423,15 @@ int SpdySession::WriteStreamData(spdy::SpdyStreamId stream_id, // TODO(mbelshe): reduce memory copies here. scoped_ptr frame( spdy_framer_.CreateDataFrame(stream_id, data->data(), len, flags)); - QueueFrame(frame.get(), stream->priority(), stream); + int length = spdy::SpdyFrame::size() + frame->length(); + IOBufferWithSize* buffer = new IOBufferWithSize(length); + memcpy(buffer->data(), frame->data(), length); + queue_.push(SpdyIOBuffer(buffer, length, stream->priority(), stream)); + + // Whenever we queue onto the socket we need to ensure that we will write to + // it later. + WriteSocketLater(); + return ERR_IO_PENDING; } @@ -564,10 +580,8 @@ void SpdySession::OnWriteComplete(int result) { write_pending_ = false; - scoped_refptr stream = in_flight_write_.stream(); - - LOG(INFO) << "Spdy write complete (result=" << result << ")" - << (stream ? " for stream " + stream->stream_id() : ""); + LOG(INFO) << "Spdy write complete (result=" << result << ") for stream: " + << in_flight_write_.stream()->stream_id(); if (result >= 0) { // It should not be possible to have written more bytes than our @@ -579,23 +593,22 @@ void SpdySession::OnWriteComplete(int result) { // We only notify the stream when we've fully written the pending frame. if (!in_flight_write_.buffer()->BytesRemaining()) { scoped_refptr stream = in_flight_write_.stream(); - if (stream) { - // Report the number of bytes written to the caller, but exclude the - // frame size overhead. NOTE: if this frame was compressed the - // reported bytes written is the compressed size, not the original - // size. - if (result > 0) { - result = in_flight_write_.buffer()->size(); - DCHECK_GT(result, static_cast(spdy::SpdyFrame::size())); - result -= static_cast(spdy::SpdyFrame::size()); - } - - // It is possible that the stream was cancelled while we were writing - // to the socket. - if (!stream->cancelled()) - stream->OnWriteComplete(result); + DCHECK(stream.get()); + + // Report the number of bytes written to the caller, but exclude the + // frame size overhead. NOTE: if this frame was compressed the reported + // bytes written is the compressed size, not the original size. + if (result > 0) { + result = in_flight_write_.buffer()->size(); + DCHECK_GT(result, static_cast(spdy::SpdyFrame::size())); + result -= static_cast(spdy::SpdyFrame::size()); } + // It is possible that the stream was cancelled while we were writing + // to the socket. + if (!stream->cancelled()) + stream->OnWriteComplete(result); + // Cleanup the write which just completed. in_flight_write_.release(); } @@ -651,9 +664,6 @@ void SpdySession::WriteSocketLater() { if (delayed_write_pending_) return; - if (state_ < CONNECTED) - return; - delayed_write_pending_ = true; MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( this, &SpdySession::WriteSocket)); @@ -771,17 +781,6 @@ int SpdySession::GetNewStreamId() { return id; } -void SpdySession::QueueFrame(spdy::SpdyFrame* frame, - spdy::SpdyPriority priority, - SpdyStream* stream) { - int length = spdy::SpdyFrame::size() + frame->length(); - IOBuffer* buffer = new IOBuffer(length); - memcpy(buffer->data(), frame->data(), length); - queue_.push(SpdyIOBuffer(buffer, length, priority, stream)); - - WriteSocketLater(); -} - void SpdySession::CloseSessionOnError(net::Error err) { DCHECK_LT(err, OK); LOG(INFO) << "spdy::CloseSessionOnError(" << err << ") for " << @@ -1041,16 +1040,6 @@ void SpdySession::OnControl(const spdy::SpdyControlFrame* frame) { } switch (type) { - case spdy::GOAWAY: - OnGoAway(*reinterpret_cast(frame)); - break; - case spdy::SETTINGS: - OnSettings( - *reinterpret_cast(frame)); - break; - case spdy::RST_STREAM: - OnFin(*reinterpret_cast(frame)); - break; case spdy::SYN_STREAM: OnSyn(*reinterpret_cast(frame), headers); @@ -1060,6 +1049,12 @@ void SpdySession::OnControl(const spdy::SpdyControlFrame* frame) { *reinterpret_cast(frame), headers); break; + case spdy::RST_STREAM: + OnFin(*reinterpret_cast(frame)); + break; + case spdy::GOAWAY: + OnGoAway(*reinterpret_cast(frame)); + break; default: DCHECK(false); // Error! } @@ -1103,24 +1098,4 @@ void SpdySession::OnGoAway(const spdy::SpdyGoAwayControlFrame& frame) { // closed. } -void SpdySession::OnSettings(const spdy::SpdySettingsControlFrame& frame) { - spdy::SpdySettings settings; - if (spdy_framer_.ParseSettings(&frame, &settings)) { - SpdySettingsStorage* settings_storage = session_->mutable_spdy_settings(); - settings_storage->Set(host_port_pair_, settings); - } -} - -void SpdySession::SendSettings() { - const SpdySettingsStorage& settings_storage = session_->spdy_settings(); - const spdy::SpdySettings& settings = settings_storage.Get(host_port_pair_); - if (settings.empty()) - return; - - // Create the SETTINGS frame and send it. - scoped_ptr settings_frame( - spdy_framer_.CreateSettings(settings)); - QueueFrame(settings_frame.get(), 0, NULL); -} - } // namespace net diff --git a/net/spdy/spdy_session.h b/net/spdy/spdy_session.h index d7f60c0..653f193 100644 --- a/net/spdy/spdy_session.h +++ b/net/spdy/spdy_session.h @@ -91,8 +91,7 @@ class SpdySession : public base::RefCounted, spdy::SpdyFramer* GetFramer() { return &spdy_framer_; } // Create a new SpdySession. - // |host_port_pair| is the host/port that this session connects to. - // |session| is the HttpNetworkSession + // |host| is the hostname that this session connects to. SpdySession(const HostPortPair& host_port_pair, HttpNetworkSession* session); // Closes all open streams. Used as part of shutdown. @@ -125,7 +124,6 @@ class SpdySession : public base::RefCounted, const spdy::SpdyHeaderBlock& headers); void OnFin(const spdy::SpdyRstStreamControlFrame& frame); void OnGoAway(const spdy::SpdyGoAwayControlFrame& frame); - void OnSettings(const spdy::SpdySettingsControlFrame& frame); // IO Callbacks void OnTCPConnect(int result); @@ -133,9 +131,6 @@ class SpdySession : public base::RefCounted, void OnReadComplete(int result); void OnWriteComplete(int result); - // Send relevant SETTINGS. This is generally called on connection setup. - void SendSettings(); - // Start reading from the socket. void ReadSocket(); @@ -146,13 +141,6 @@ class SpdySession : public base::RefCounted, // Get a new stream id. int GetNewStreamId(); - // Queue a frame for sending. - // |frame| is the frame to send. - // |priority| is the priority for insertion into the queue. - // |stream| is the stream which this IO is associated with (or NULL). - void QueueFrame(spdy::SpdyFrame* frame, spdy::SpdyPriority priority, - SpdyStream* stream); - // Closes this session. This will close all active streams and mark // the session as permanently closed. // |err| should not be OK; this function is intended to be called on diff --git a/net/spdy/spdy_settings_storage.cc b/net/spdy/spdy_settings_storage.cc deleted file mode 100644 index 68d9cc1..0000000 --- a/net/spdy/spdy_settings_storage.cc +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright (c) 2010 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. - -#include "net/spdy/spdy_settings_storage.h" - -#include - -namespace net { - -SpdySettingsStorage::SpdySettingsStorage() { -} - -const spdy::SpdySettings& SpdySettingsStorage::Get( - const HostPortPair& host_port_pair) const { - SettingsMap::const_iterator it = settings_map_.find(host_port_pair); - if (it == settings_map_.end()) { - static const spdy::SpdySettings kEmpty; - return kEmpty; - } - return it->second; -} - -void SpdySettingsStorage::Set(const HostPortPair& host_port_pair, - const spdy::SpdySettings& settings) { - spdy::SpdySettings persistent_settings; - - // Iterate through the list, and only copy those settings which are marked - // for persistence. - spdy::SpdySettings::const_iterator it; - for (it = settings.begin(); it != settings.end(); ++it) { - spdy::SettingsFlagsAndId id = it->first; - if (id.flags() & spdy::SETTINGS_FLAG_PLEASE_PERSIST) { - id.set_flags(spdy::SETTINGS_FLAG_PERSISTED); - persistent_settings.push_back(std::make_pair(id, it->second)); - } - } - - // If we didn't persist anything, then we are done. - if (persistent_settings.empty()) - return; - - settings_map_[host_port_pair] = persistent_settings; -} - -} // namespace net \ No newline at end of file diff --git a/net/spdy/spdy_settings_storage.h b/net/spdy/spdy_settings_storage.h deleted file mode 100644 index 79f3b970..0000000 --- a/net/spdy/spdy_settings_storage.h +++ /dev/null @@ -1,39 +0,0 @@ -// Copyright (c) 2010 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 NET_SPDY_SPDY_SETTING_STORAGE_H_ -#define NET_SPDY_SPDY_SETTING_STORAGE_H_ - -#include -#include "base/basictypes.h" -#include "net/base/host_port_pair.h" -#include "net/spdy/spdy_framer.h" - -namespace net { - -// SpdySettingsStorage stores SpdySettings which have been transmitted between -// endpoints for the SPDY SETTINGS frame. -class SpdySettingsStorage { - public: - SpdySettingsStorage(); - - // Get a copy of the SpdySettings stored for a host. - // If no settings are stored, returns an empty set of settings. - const spdy::SpdySettings& Get(const HostPortPair& host_port_pair) const; - - // Save settings for a host. - void Set(const HostPortPair& host_port_pair, - const spdy::SpdySettings& settings); - - private: - typedef std::map SettingsMap; - - SettingsMap settings_map_; - - DISALLOW_COPY_AND_ASSIGN(SpdySettingsStorage); -}; - -} // namespace net - -#endif // NET_SPDY_SPDY_SETTING_STORAGE_H_ -- cgit v1.1