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 "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 Loading... |
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 Loading... |
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 } |
OLD | NEW |