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

Side by Side Diff: chrome/browser/android/bookmarks/bookmarks_bridge.cc

Issue 79683005: Merge 235499 "Fix a small bug in bookmarks_bridge.cc" (Closed) Base URL: svn://svn.chromium.org/chrome/branches/1700/src/
Patch Set: Created 7 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/android/java/src/org/chromium/chrome/browser/BookmarksBridge.java ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "chrome/browser/android/bookmarks/bookmarks_bridge.h" 5 #include "chrome/browser/android/bookmarks/bookmarks_bridge.h"
6 6
7 #include "base/android/jni_string.h" 7 #include "base/android/jni_string.h"
8 #include "base/prefs/pref_service.h" 8 #include "base/prefs/pref_service.h"
9 #include "chrome/browser/bookmarks/bookmark_model.h" 9 #include "chrome/browser/bookmarks/bookmark_model.h"
10 #include "chrome/browser/bookmarks/bookmark_model_factory.h" 10 #include "chrome/browser/bookmarks/bookmark_model_factory.h"
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 80
81 void BookmarksBridge::GetBookmarksForFolder(JNIEnv* env, 81 void BookmarksBridge::GetBookmarksForFolder(JNIEnv* env,
82 jobject obj, 82 jobject obj,
83 jobject j_folder_id_obj, 83 jobject j_folder_id_obj,
84 jobject j_callback_obj, 84 jobject j_callback_obj,
85 jobject j_result_obj) { 85 jobject j_result_obj) {
86 DCHECK(bookmark_model_->loaded()); 86 DCHECK(bookmark_model_->loaded());
87 long folder_id = Java_BookmarkId_getId(env, j_folder_id_obj); 87 long folder_id = Java_BookmarkId_getId(env, j_folder_id_obj);
88 int type = Java_BookmarkId_getType(env, j_folder_id_obj); 88 int type = Java_BookmarkId_getType(env, j_folder_id_obj);
89 const BookmarkNode* folder = GetFolderWithFallback(folder_id, type); 89 const BookmarkNode* folder = GetFolderWithFallback(folder_id, type);
90 // Recreate the java bookmarkId object due to fallback.
91 ScopedJavaLocalRef<jobject> folder_id_obj =
92 Java_BookmarksBridge_createBookmarkId(
93 env, folder->id(), GetBookmarkType(folder));
94 j_folder_id_obj = folder_id_obj.obj();
95
90 // If this is the Mobile bookmarks folder then add the "Managed bookmarks" 96 // If this is the Mobile bookmarks folder then add the "Managed bookmarks"
91 // folder first, so that it's the first entry. 97 // folder first, so that it's the first entry.
92 if (folder == bookmark_model_->mobile_node() && 98 if (folder == bookmark_model_->mobile_node() &&
93 managed_bookmarks_shim_->HasManagedBookmarks()) { 99 managed_bookmarks_shim_->HasManagedBookmarks()) {
94 ExtractBookmarkNodeInformation( 100 ExtractBookmarkNodeInformation(
95 managed_bookmarks_shim_->GetManagedBookmarksRoot(), 101 managed_bookmarks_shim_->GetManagedBookmarksRoot(),
96 j_result_obj); 102 j_result_obj);
97 } 103 }
98 // Get the folder contents 104 // Get the folder contents
99 for (int i = 0; i < folder->child_count(); ++i) { 105 for (int i = 0; i < folder->child_count(); ++i) {
100 const BookmarkNode* node = folder->GetChild(i); 106 const BookmarkNode* node = folder->GetChild(i);
101 ExtractBookmarkNodeInformation(node, j_result_obj); 107 ExtractBookmarkNodeInformation(node, j_result_obj);
102 } 108 }
103 109
104 Java_BookmarksCallback_onBookmarksAvailable( 110 Java_BookmarksCallback_onBookmarksAvailable(
105 env, j_callback_obj, j_folder_id_obj, j_result_obj); 111 env, j_callback_obj, j_folder_id_obj, j_result_obj);
106 } 112 }
107 113
108 void BookmarksBridge::GetCurrentFolderHierarchy(JNIEnv* env, 114 void BookmarksBridge::GetCurrentFolderHierarchy(JNIEnv* env,
109 jobject obj, 115 jobject obj,
110 jobject j_folder_id_obj, 116 jobject j_folder_id_obj,
111 jobject j_callback_obj, 117 jobject j_callback_obj,
112 jobject j_result_obj) { 118 jobject j_result_obj) {
113 DCHECK(bookmark_model_->loaded()); 119 DCHECK(bookmark_model_->loaded());
114 long folder_id = Java_BookmarkId_getId(env, j_folder_id_obj); 120 long folder_id = Java_BookmarkId_getId(env, j_folder_id_obj);
115 int type = Java_BookmarkId_getType(env, j_folder_id_obj); 121 int type = Java_BookmarkId_getType(env, j_folder_id_obj);
116 const BookmarkNode* folder = GetFolderWithFallback(folder_id, type); 122 const BookmarkNode* folder = GetFolderWithFallback(folder_id, type);
123 // Recreate the java bookmarkId object due to fallback.
124 ScopedJavaLocalRef<jobject> folder_id_obj =
125 Java_BookmarksBridge_createBookmarkId(
126 env, folder->id(), GetBookmarkType(folder));
127 j_folder_id_obj = folder_id_obj.obj();
128
117 // Get the folder heirarchy 129 // Get the folder heirarchy
118 const BookmarkNode* node = folder; 130 const BookmarkNode* node = folder;
119 while (node) { 131 while (node) {
120 ExtractBookmarkNodeInformation(node, j_result_obj); 132 ExtractBookmarkNodeInformation(node, j_result_obj);
121 node = GetParentNode(node); 133 node = GetParentNode(node);
122 } 134 }
123 135
124 Java_BookmarksCallback_onBookmarksFolderHierarchyAvailable( 136 Java_BookmarksCallback_onBookmarksFolderHierarchyAvailable(
125 env, j_callback_obj, j_folder_id_obj, j_result_obj); 137 env, j_callback_obj, j_folder_id_obj, j_result_obj);
126 } 138 }
(...skipping 204 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 JNIEnv* env = AttachCurrentThread(); 343 JNIEnv* env = AttachCurrentThread();
332 ScopedJavaLocalRef<jobject> obj = weak_java_ref_.get(env); 344 ScopedJavaLocalRef<jobject> obj = weak_java_ref_.get(env);
333 if (obj.is_null()) 345 if (obj.is_null())
334 return; 346 return;
335 Java_BookmarksBridge_extensiveBookmarkChangesEnded(env, obj.obj()); 347 Java_BookmarksBridge_extensiveBookmarkChangesEnded(env, obj.obj());
336 } 348 }
337 349
338 void BookmarksBridge::OnManagedBookmarksChanged() { 350 void BookmarksBridge::OnManagedBookmarksChanged() {
339 BookmarkModelChanged(); 351 BookmarkModelChanged();
340 } 352 }
OLDNEW
« no previous file with comments | « chrome/android/java/src/org/chromium/chrome/browser/BookmarksBridge.java ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698