| OLD | NEW | 
|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "components/sessions/core/serialized_navigation_entry.h" | 5 #include "components/sessions/core/serialized_navigation_entry.h" | 
| 6 | 6 | 
| 7 #include <stddef.h> | 7 #include <stddef.h> | 
| 8 | 8 | 
| 9 #include "base/pickle.h" | 9 #include "base/pickle.h" | 
| 10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" | 
| (...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 175                            const base::string16& str) { | 175                            const base::string16& str) { | 
| 176   int num_bytes = str.size() * sizeof(base::char16); | 176   int num_bytes = str.size() * sizeof(base::char16); | 
| 177   if (*bytes_written + num_bytes < max_bytes) { | 177   if (*bytes_written + num_bytes < max_bytes) { | 
| 178     *bytes_written += num_bytes; | 178     *bytes_written += num_bytes; | 
| 179     pickle->WriteString16(str); | 179     pickle->WriteString16(str); | 
| 180   } else { | 180   } else { | 
| 181     pickle->WriteString16(base::string16()); | 181     pickle->WriteString16(base::string16()); | 
| 182   } | 182   } | 
| 183 } | 183 } | 
| 184 | 184 | 
|  | 185 void WriteStringMapToPickle(base::Pickle* pickle, | 
|  | 186                             int* bytes_written, | 
|  | 187                             int max_bytes, | 
|  | 188                             const std::map<std::string, std::string>& map) { | 
|  | 189   pickle->WriteInt(map.size()); | 
|  | 190   for (const auto entry : map) { | 
|  | 191     WriteStringToPickle(pickle, bytes_written, max_bytes, entry.first); | 
|  | 192     WriteStringToPickle(pickle, bytes_written, max_bytes, entry.second); | 
|  | 193   } | 
|  | 194 } | 
|  | 195 | 
| 185 // A mask used for arbitrary boolean values needed to represent a | 196 // A mask used for arbitrary boolean values needed to represent a | 
| 186 // NavigationEntry. Currently only contains HAS_POST_DATA. | 197 // NavigationEntry. Currently only contains HAS_POST_DATA. | 
| 187 // | 198 // | 
| 188 // NOTE(akalin): We may want to just serialize |has_post_data_| | 199 // NOTE(akalin): We may want to just serialize |has_post_data_| | 
| 189 // directly.  Other bools (|is_overriding_user_agent_|) haven't been | 200 // directly.  Other bools (|is_overriding_user_agent_|) haven't been | 
| 190 // added to this mask. | 201 // added to this mask. | 
| 191 enum TypeMask { | 202 enum TypeMask { | 
| 192   HAS_POST_DATA = 1 | 203   HAS_POST_DATA = 1 | 
| 193 }; | 204 }; | 
| 194 | 205 | 
| (...skipping 11 matching lines...) Expand all  Loading... | 
| 206 // | 217 // | 
| 207 // type_mask (has_post_data_) | 218 // type_mask (has_post_data_) | 
| 208 // referrer_url_ | 219 // referrer_url_ | 
| 209 // referrer_policy_ (broken, crbug.com/450589) | 220 // referrer_policy_ (broken, crbug.com/450589) | 
| 210 // original_request_url_ | 221 // original_request_url_ | 
| 211 // is_overriding_user_agent_ | 222 // is_overriding_user_agent_ | 
| 212 // timestamp_ | 223 // timestamp_ | 
| 213 // search_terms_ | 224 // search_terms_ | 
| 214 // http_status_code_ | 225 // http_status_code_ | 
| 215 // referrer_policy_ | 226 // referrer_policy_ | 
|  | 227 // extended_info_map_ | 
| 216 | 228 | 
| 217 void SerializedNavigationEntry::WriteToPickle(int max_size, | 229 void SerializedNavigationEntry::WriteToPickle(int max_size, | 
| 218                                               base::Pickle* pickle) const { | 230                                               base::Pickle* pickle) const { | 
| 219   pickle->WriteInt(index_); | 231   pickle->WriteInt(index_); | 
| 220 | 232 | 
| 221   int bytes_written = 0; | 233   int bytes_written = 0; | 
| 222 | 234 | 
| 223   WriteStringToPickle(pickle, &bytes_written, max_size, | 235   WriteStringToPickle(pickle, &bytes_written, max_size, | 
| 224                       virtual_url_.spec()); | 236                       virtual_url_.spec()); | 
| 225 | 237 | 
| (...skipping 24 matching lines...) Expand all  Loading... | 
| 250       original_request_url_.is_valid() ? | 262       original_request_url_.is_valid() ? | 
| 251       original_request_url_.spec() : std::string()); | 263       original_request_url_.spec() : std::string()); | 
| 252   pickle->WriteBool(is_overriding_user_agent_); | 264   pickle->WriteBool(is_overriding_user_agent_); | 
| 253   pickle->WriteInt64(timestamp_.ToInternalValue()); | 265   pickle->WriteInt64(timestamp_.ToInternalValue()); | 
| 254 | 266 | 
| 255   WriteString16ToPickle(pickle, &bytes_written, max_size, search_terms_); | 267   WriteString16ToPickle(pickle, &bytes_written, max_size, search_terms_); | 
| 256 | 268 | 
| 257   pickle->WriteInt(http_status_code_); | 269   pickle->WriteInt(http_status_code_); | 
| 258 | 270 | 
| 259   pickle->WriteInt(referrer_policy_); | 271   pickle->WriteInt(referrer_policy_); | 
|  | 272 | 
|  | 273   WriteStringMapToPickle(pickle, &bytes_written, max_size, extended_info_map_); | 
| 260 } | 274 } | 
| 261 | 275 | 
| 262 bool SerializedNavigationEntry::ReadFromPickle(base::PickleIterator* iterator) { | 276 bool SerializedNavigationEntry::ReadFromPickle(base::PickleIterator* iterator) { | 
| 263   *this = SerializedNavigationEntry(); | 277   *this = SerializedNavigationEntry(); | 
| 264   std::string virtual_url_spec; | 278   std::string virtual_url_spec; | 
| 265   int transition_type_int = 0; | 279   int transition_type_int = 0; | 
| 266   if (!iterator->ReadInt(&index_) || | 280   if (!iterator->ReadInt(&index_) || | 
| 267       !iterator->ReadString(&virtual_url_spec) || | 281       !iterator->ReadString(&virtual_url_spec) || | 
| 268       !iterator->ReadString16(&title_) || | 282       !iterator->ReadString16(&title_) || | 
| 269       !iterator->ReadString(&encoded_page_state_) || | 283       !iterator->ReadString(&encoded_page_state_) || | 
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 328       int mapped_referrer_policy; | 342       int mapped_referrer_policy; | 
| 329       if (!SerializedNavigationDriver::Get()->MapReferrerPolicyToNewValues( | 343       if (!SerializedNavigationDriver::Get()->MapReferrerPolicyToNewValues( | 
| 330               referrer_policy_, &mapped_referrer_policy)) { | 344               referrer_policy_, &mapped_referrer_policy)) { | 
| 331         referrer_url_ = GURL(); | 345         referrer_url_ = GURL(); | 
| 332       } | 346       } | 
| 333       referrer_policy_ = mapped_referrer_policy; | 347       referrer_policy_ = mapped_referrer_policy; | 
| 334       encoded_page_state_ = | 348       encoded_page_state_ = | 
| 335           SerializedNavigationDriver::Get()->StripReferrerFromPageState( | 349           SerializedNavigationDriver::Get()->StripReferrerFromPageState( | 
| 336               encoded_page_state_); | 350               encoded_page_state_); | 
| 337     } | 351     } | 
|  | 352 | 
|  | 353     int extended_info_map_size = 0; | 
|  | 354     if (iterator->ReadInt(&extended_info_map_size) && | 
|  | 355         extended_info_map_size >= 0) { | 
|  | 356       for (int i = 0; i < extended_info_map_size; ++i) { | 
|  | 357         std::string key; | 
|  | 358         std::string value; | 
|  | 359         if (iterator->ReadString(&key) && iterator->ReadString(&value)) | 
|  | 360           extended_info_map_[key] = value; | 
|  | 361       } | 
|  | 362     } else { | 
|  | 363       extended_info_map_.clear(); | 
|  | 364     } | 
| 338   } | 365   } | 
| 339 | 366 | 
| 340   SerializedNavigationDriver::Get()->Sanitize(this); | 367   SerializedNavigationDriver::Get()->Sanitize(this); | 
| 341 | 368 | 
| 342   is_restored_ = true; | 369   is_restored_ = true; | 
| 343 | 370 | 
| 344   return true; | 371   return true; | 
| 345 } | 372 } | 
| 346 | 373 | 
| 347 // TODO(zea): perhaps sync state (scroll position, form entries, etc.) as well? | 374 // TODO(zea): perhaps sync state (scroll position, form entries, etc.) as well? | 
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 476           redirect_chain_[last_entry].spec()); | 503           redirect_chain_[last_entry].spec()); | 
| 477     } | 504     } | 
| 478   } | 505   } | 
| 479 | 506 | 
| 480   sync_data.set_is_restored(is_restored_); | 507   sync_data.set_is_restored(is_restored_); | 
| 481 | 508 | 
| 482   return sync_data; | 509   return sync_data; | 
| 483 } | 510 } | 
| 484 | 511 | 
| 485 }  // namespace sessions | 512 }  // namespace sessions | 
| OLD | NEW | 
|---|