OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/browser/bookmarks/bookmark_model.h" | 5 #include "chrome/browser/bookmarks/bookmark_model.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <functional> | 8 #include <functional> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 287 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
298 DCHECK(node); | 298 DCHECK(node); |
299 if (!node->is_favicon_loaded()) { | 299 if (!node->is_favicon_loaded()) { |
300 BookmarkNode* mutable_node = AsMutable(node); | 300 BookmarkNode* mutable_node = AsMutable(node); |
301 mutable_node->set_is_favicon_loaded(true); | 301 mutable_node->set_is_favicon_loaded(true); |
302 LoadFavicon(mutable_node); | 302 LoadFavicon(mutable_node); |
303 } | 303 } |
304 return node->favicon(); | 304 return node->favicon(); |
305 } | 305 } |
306 | 306 |
307 void BookmarkModel::SetTitle(const BookmarkNode* node, const string16& title) { | 307 void BookmarkModel::SetTitle(const BookmarkNode* node, const string16& title) { |
308 string16 mutable_title = title; | |
309 | |
310 // Remove line break whitespace from Folder names. | |
Ilya Sherman
2011/11/21 21:36:10
Hmm, why do we only want to clean up /folder/ name
KushalP
2011/11/21 22:14:15
This change was made previous to the discussions w
| |
311 if (node->is_folder()) { | |
312 mutable_title = CollapseWhitespace(mutable_title, false); | |
313 } | |
314 | |
308 if (!node) { | 315 if (!node) { |
309 NOTREACHED(); | 316 NOTREACHED(); |
310 return; | 317 return; |
311 } | 318 } |
312 if (node->GetTitle() == title) | 319 if (node->GetTitle() == mutable_title) |
313 return; | 320 return; |
314 | 321 |
315 if (is_permanent_node(node)) { | 322 if (is_permanent_node(node)) { |
316 NOTREACHED(); | 323 NOTREACHED(); |
317 return; | 324 return; |
318 } | 325 } |
319 | 326 |
320 // The title index doesn't support changing the title, instead we remove then | 327 // The title index doesn't support changing the title, instead we remove then |
321 // add it back. | 328 // add it back. |
322 index_->Remove(node); | 329 index_->Remove(node); |
323 AsMutable(node)->set_title(title); | 330 AsMutable(node)->set_title(mutable_title); |
324 index_->Add(node); | 331 index_->Add(node); |
325 | 332 |
326 if (store_.get()) | 333 if (store_.get()) |
327 store_->ScheduleSave(); | 334 store_->ScheduleSave(); |
328 | 335 |
329 FOR_EACH_OBSERVER(BookmarkModelObserver, observers_, | 336 FOR_EACH_OBSERVER(BookmarkModelObserver, observers_, |
330 BookmarkNodeChanged(this, node)); | 337 BookmarkNodeChanged(this, node)); |
331 } | 338 } |
332 | 339 |
333 void BookmarkModel::SetURL(const BookmarkNode* node, const GURL& url) { | 340 void BookmarkModel::SetURL(const BookmarkNode* node, const GURL& url) { |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
429 int index, | 436 int index, |
430 const string16& title) { | 437 const string16& title) { |
431 if (!loaded_ || is_root_node(parent) || !IsValidIndex(parent, index, true)) { | 438 if (!loaded_ || is_root_node(parent) || !IsValidIndex(parent, index, true)) { |
432 // Can't add to the root. | 439 // Can't add to the root. |
433 NOTREACHED(); | 440 NOTREACHED(); |
434 return NULL; | 441 return NULL; |
435 } | 442 } |
436 | 443 |
437 BookmarkNode* new_node = new BookmarkNode(generate_next_node_id(), GURL()); | 444 BookmarkNode* new_node = new BookmarkNode(generate_next_node_id(), GURL()); |
438 new_node->set_date_folder_modified(Time::Now()); | 445 new_node->set_date_folder_modified(Time::Now()); |
439 new_node->set_title(title); | 446 // Folders shouldn't have line breaks in their titles. |
447 new_node->set_title(CollapseWhitespace(title, false)); | |
440 new_node->set_type(BookmarkNode::FOLDER); | 448 new_node->set_type(BookmarkNode::FOLDER); |
441 | 449 |
442 return AddNode(AsMutable(parent), index, new_node, false); | 450 return AddNode(AsMutable(parent), index, new_node, false); |
443 } | 451 } |
444 | 452 |
445 const BookmarkNode* BookmarkModel::AddURL(const BookmarkNode* parent, | 453 const BookmarkNode* BookmarkModel::AddURL(const BookmarkNode* parent, |
446 int index, | 454 int index, |
447 const string16& title, | 455 const string16& title, |
448 const GURL& url) { | 456 const GURL& url) { |
449 return AddURLWithCreationTime(parent, index, title, url, Time::Now()); | 457 return AddURLWithCreationTime(parent, index, title, url, Time::Now()); |
(...skipping 379 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
829 return next_node_id_++; | 837 return next_node_id_++; |
830 } | 838 } |
831 | 839 |
832 BookmarkLoadDetails* BookmarkModel::CreateLoadDetails() { | 840 BookmarkLoadDetails* BookmarkModel::CreateLoadDetails() { |
833 BookmarkNode* bb_node = CreatePermanentNode(BookmarkNode::BOOKMARK_BAR); | 841 BookmarkNode* bb_node = CreatePermanentNode(BookmarkNode::BOOKMARK_BAR); |
834 BookmarkNode* other_node = CreatePermanentNode(BookmarkNode::OTHER_NODE); | 842 BookmarkNode* other_node = CreatePermanentNode(BookmarkNode::OTHER_NODE); |
835 BookmarkNode* synced_node = CreatePermanentNode(BookmarkNode::SYNCED); | 843 BookmarkNode* synced_node = CreatePermanentNode(BookmarkNode::SYNCED); |
836 return new BookmarkLoadDetails(bb_node, other_node, synced_node, | 844 return new BookmarkLoadDetails(bb_node, other_node, synced_node, |
837 new BookmarkIndex(profile_), next_node_id_); | 845 new BookmarkIndex(profile_), next_node_id_); |
838 } | 846 } |
OLD | NEW |