Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 "config.h" | 5 #include "config.h" |
| 6 #include <string> | 6 #include <string> |
| 7 | 7 |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 | 9 |
| 10 MSVC_PUSH_WARNING_LEVEL(0); | 10 MSVC_PUSH_WARNING_LEVEL(0); |
| (...skipping 253 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 264 WriteString(item->referrer(), obj); | 264 WriteString(item->referrer(), obj); |
| 265 | 265 |
| 266 // Subitems | 266 // Subitems |
| 267 WriteInteger(static_cast<int>(item->children().size()), obj); | 267 WriteInteger(static_cast<int>(item->children().size()), obj); |
| 268 for (size_t i = 0, c = item->children().size(); i < c; ++i) | 268 for (size_t i = 0, c = item->children().size(); i < c; ++i) |
| 269 WriteHistoryItem(item->children().at(i).get(), obj); | 269 WriteHistoryItem(item->children().at(i).get(), obj); |
| 270 } | 270 } |
| 271 | 271 |
| 272 // Creates a new HistoryItem tree based on the serialized string. | 272 // Creates a new HistoryItem tree based on the serialized string. |
| 273 // Assumes the data is in the format returned by WriteHistoryItem. | 273 // Assumes the data is in the format returned by WriteHistoryItem. |
| 274 static PassRefPtr<HistoryItem> ReadHistoryItem(const SerializeObject* obj) { | 274 static PassRefPtr<HistoryItem> ReadHistoryItem(const SerializeObject* obj, |
| 275 bool include_form_data) { | |
| 275 // See note in WriteHistoryItem. on this. | 276 // See note in WriteHistoryItem. on this. |
| 276 obj->version = ReadInteger(obj); | 277 obj->version = ReadInteger(obj); |
| 277 | 278 |
| 278 if (obj->version > kVersion || obj->version < 1) | 279 if (obj->version > kVersion || obj->version < 1) |
| 279 return NULL; | 280 return NULL; |
| 280 | 281 |
| 281 RefPtr<HistoryItem> item = HistoryItem::create(); | 282 RefPtr<HistoryItem> item = HistoryItem::create(); |
| 282 | 283 |
| 283 item->setURLString(ReadString(obj)); | 284 item->setURLString(ReadString(obj)); |
| 284 item->setOriginalURLString(ReadString(obj)); | 285 item->setOriginalURLString(ReadString(obj)); |
| 285 item->setTarget(ReadString(obj)); | 286 item->setTarget(ReadString(obj)); |
| 286 item->setParent(ReadString(obj)); | 287 item->setParent(ReadString(obj)); |
| 287 item->setTitle(ReadString(obj)); | 288 item->setTitle(ReadString(obj)); |
| 288 item->setAlternateTitle(ReadString(obj)); | 289 item->setAlternateTitle(ReadString(obj)); |
| 289 item->setLastVisitedTime(ReadReal(obj)); | 290 item->setLastVisitedTime(ReadReal(obj)); |
| 290 int x = ReadInteger(obj); | 291 int x = ReadInteger(obj); |
| 291 int y = ReadInteger(obj); | 292 int y = ReadInteger(obj); |
| 292 item->setScrollPoint(IntPoint(x, y)); | 293 item->setScrollPoint(IntPoint(x, y)); |
| 293 item->setIsTargetItem(ReadBoolean(obj)); | 294 item->setIsTargetItem(ReadBoolean(obj)); |
| 294 item->setVisitCount(ReadInteger(obj)); | 295 item->setVisitCount(ReadInteger(obj)); |
| 295 item->setReferrer(ReadString(obj)); | 296 item->setReferrer(ReadString(obj)); |
| 296 | 297 |
| 297 Vector<String> document_state; | 298 Vector<String> document_state; |
| 298 ReadStringVector(obj, &document_state); | 299 ReadStringVector(obj, &document_state); |
| 299 item->setDocumentState(document_state); | 300 item->setDocumentState(document_state); |
| 300 | 301 |
| 301 // Form data. If there is any form data, we assume POST, otherwise GET. | 302 // Form data. If there is any form data, we assume POST, otherwise GET. |
| 302 // ResourceRequest takes ownership of the new FormData, then gives it to | 303 // FormData is ref counted. |
| 303 // HistoryItem. | |
| 304 ResourceRequest dummy_request; // only way to initialize HistoryItem | 304 ResourceRequest dummy_request; // only way to initialize HistoryItem |
| 305 dummy_request.setHTTPBody(ReadFormData(obj)); | 305 dummy_request.setHTTPBody(ReadFormData(obj)); |
| 306 dummy_request.setHTTPContentType(ReadString(obj)); | 306 dummy_request.setHTTPContentType(ReadString(obj)); |
| 307 dummy_request.setHTTPReferrer(ReadString(obj)); | 307 dummy_request.setHTTPReferrer(ReadString(obj)); |
| 308 if (dummy_request.httpBody()) | 308 if (dummy_request.httpBody()) |
| 309 dummy_request.setHTTPMethod("POST"); | 309 dummy_request.setHTTPMethod("POST"); |
| 310 item->setFormInfoFromRequest(dummy_request); | 310 if (include_form_data) |
| 311 item->setFormInfoFromRequest(dummy_request); | |
| 311 | 312 |
| 312 // Subitems | 313 // Subitems |
| 313 int num_children = ReadInteger(obj); | 314 int num_children = ReadInteger(obj); |
| 314 for (int i = 0; i < num_children; ++i) | 315 for (int i = 0; i < num_children; ++i) |
| 315 item->addChildItem(ReadHistoryItem(obj)); | 316 item->addChildItem(ReadHistoryItem(obj, include_form_data)); |
| 316 | 317 |
| 317 return item.release(); | 318 return item.release(); |
| 318 } | 319 } |
| 319 | 320 |
| 320 // Serialize a HistoryItem to a string, using our JSON Value serializer. | 321 // Serialize a HistoryItem to a string, using our JSON Value serializer. |
| 321 void HistoryItemToString(PassRefPtr<HistoryItem> item, | 322 void HistoryItemToString(PassRefPtr<HistoryItem> item, |
| 322 std::string* serialized_item) { | 323 std::string* serialized_item) { |
| 323 if (!item) { | 324 if (!item) { |
| 324 serialized_item->clear(); | 325 serialized_item->clear(); |
| 325 return; | 326 return; |
| 326 } | 327 } |
| 327 | 328 |
| 328 SerializeObject obj; | 329 SerializeObject obj; |
| 329 WriteHistoryItem(item.get(), &obj); | 330 WriteHistoryItem(item.get(), &obj); |
| 330 *serialized_item = obj.GetAsString(); | 331 *serialized_item = obj.GetAsString(); |
| 331 } | 332 } |
| 332 | 333 |
| 333 // Reconstruct a HistoryItem from a string, using our JSON Value deserializer. | 334 // Reconstruct a HistoryItem from a string, using our JSON Value deserializer. |
| 334 // This assumes that the given serialized string has all the required key,value | 335 // This assumes that the given serialized string has all the required key,value |
| 335 // pairs, and does minimal error checking. | 336 // pairs, and does minimal error checking. If |include_form_data| is true, |
| 337 // the form data from a post is restored, otherwise the form data is empty. | |
| 336 PassRefPtr<HistoryItem> HistoryItemFromString( | 338 PassRefPtr<HistoryItem> HistoryItemFromString( |
|
darin (slow to review)
2009/03/26 17:03:48
nit: since this function is only used in this file
| |
| 337 const std::string& serialized_item) { | 339 const std::string& serialized_item, |
| 340 bool include_form_data) { | |
| 338 if (serialized_item.empty()) | 341 if (serialized_item.empty()) |
| 339 return NULL; | 342 return NULL; |
| 340 | 343 |
| 341 SerializeObject obj(serialized_item.data(), | 344 SerializeObject obj(serialized_item.data(), |
| 342 static_cast<int>(serialized_item.length())); | 345 static_cast<int>(serialized_item.length())); |
| 343 return ReadHistoryItem(&obj); | 346 return ReadHistoryItem(&obj, include_form_data); |
| 347 } | |
| 348 | |
| 349 PassRefPtr<HistoryItem> HistoryItemFromString( | |
| 350 const std::string& serialized_item) { | |
| 351 return HistoryItemFromString(serialized_item, true); | |
| 344 } | 352 } |
| 345 | 353 |
| 346 // For testing purposes only. | 354 // For testing purposes only. |
| 347 void HistoryItemToVersionedString(PassRefPtr<HistoryItem> item, int version, | 355 void HistoryItemToVersionedString(PassRefPtr<HistoryItem> item, int version, |
| 348 std::string* serialized_item) { | 356 std::string* serialized_item) { |
| 349 if (!item) { | 357 if (!item) { |
| 350 serialized_item->clear(); | 358 serialized_item->clear(); |
| 351 return; | 359 return; |
| 352 } | 360 } |
| 353 | 361 |
| 354 // Temporarily change the version. | 362 // Temporarily change the version. |
| 355 int real_version = kVersion; | 363 int real_version = kVersion; |
| 356 kVersion = version; | 364 kVersion = version; |
| 357 | 365 |
| 358 SerializeObject obj; | 366 SerializeObject obj; |
| 359 WriteHistoryItem(item.get(), &obj); | 367 WriteHistoryItem(item.get(), &obj); |
| 360 *serialized_item = obj.GetAsString(); | 368 *serialized_item = obj.GetAsString(); |
| 361 | 369 |
| 362 kVersion = real_version; | 370 kVersion = real_version; |
| 363 } | 371 } |
| 364 | 372 |
| 365 std::string CreateHistoryStateForURL(const GURL& url) { | 373 std::string CreateHistoryStateForURL(const GURL& url) { |
| 366 // TODO(eseide): We probably should be passing a list visit time other than 0 | 374 // TODO(eseide): We probably should be passing a list visit time other than 0 |
| 367 RefPtr<HistoryItem> item(HistoryItem::create(GURLToKURL(url), String(), 0)); | 375 RefPtr<HistoryItem> item(HistoryItem::create(GURLToKURL(url), String(), 0)); |
| 368 std::string data; | 376 std::string data; |
| 369 HistoryItemToString(item, &data); | 377 HistoryItemToString(item, &data); |
| 370 return data; | 378 return data; |
| 371 } | 379 } |
| 372 | 380 |
| 381 std::string RemoveFormDataFromHistoryState(const std::string& content_state) { | |
| 382 RefPtr<HistoryItem> history_item(HistoryItemFromString(content_state, false)); | |
| 383 if (!history_item.get()) { | |
| 384 // Couldn't parse the string, return an empty string. | |
| 385 return std::string(); | |
| 386 } | |
| 387 std::string new_state; | |
| 388 HistoryItemToString(history_item, &new_state); | |
| 389 return new_state; | |
| 390 } | |
| 391 | |
| 373 } // namespace webkit_glue | 392 } // namespace webkit_glue |
| OLD | NEW |