Index: chrome/browser/android/bookmarks/bookmarks_bridge.cc |
diff --git a/chrome/browser/android/bookmarks/bookmarks_bridge.cc b/chrome/browser/android/bookmarks/bookmarks_bridge.cc |
index 6ec80cb35e8c4a07204d76b7924b6d0c2b5bff9e..30ae8fb2e700c40bf88fb07fa88cbd5bec475d08 100644 |
--- a/chrome/browser/android/bookmarks/bookmarks_bridge.cc |
+++ b/chrome/browser/android/bookmarks/bookmarks_bridge.cc |
@@ -102,6 +102,12 @@ void BookmarksBridge::GetBookmarksForFolder(JNIEnv* env, |
if (!folder->is_folder() || !IsReachable(folder)) |
return; |
+ // Recreate the java bookmarkId object due to fallback. |
+ ScopedJavaLocalRef<jobject> folder_id_obj = |
+ Java_BookmarksBridge_createBookmarkId( |
+ env, folder->id(), GetBookmarkType(folder)); |
+ j_folder_id_obj = folder_id_obj.obj(); |
+ |
// If this is the Mobile bookmarks folder then add the "Managed bookmarks" |
// folder first, so that it's the first entry. |
if (folder == bookmark_model_->mobile_node() && |
@@ -140,6 +146,12 @@ void BookmarksBridge::GetCurrentFolderHierarchy(JNIEnv* env, |
if (!folder->is_folder() || !IsReachable(folder)) |
return; |
+ // Recreate the java bookmarkId object due to fallback. |
+ ScopedJavaLocalRef<jobject> folder_id_obj = |
+ Java_BookmarksBridge_createBookmarkId( |
+ env, folder->id(), GetBookmarkType(folder)); |
+ j_folder_id_obj = folder_id_obj.obj(); |
+ |
// Get the folder heirarchy |
const BookmarkNode* node = folder; |
while (node) { |