Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/offline_pages/downloads/offline_page_download_b ridge.h" | 5 #include "chrome/browser/android/offline_pages/downloads/offline_page_download_b ridge.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
| 10 #include "chrome/browser/android/offline_pages/offline_page_model_factory.h" | 10 #include "chrome/browser/android/offline_pages/offline_page_model_factory.h" |
| 11 #include "chrome/browser/profiles/profile.h" | 11 #include "chrome/browser/profiles/profile.h" |
| 12 #include "chrome/browser/profiles/profile_android.h" | 12 #include "chrome/browser/profiles/profile_android.h" |
| 13 #include "components/offline_pages/downloads/download_ui_item.h" | 13 #include "components/offline_pages/downloads/download_ui_item.h" |
| 14 #include "components/offline_pages/offline_page_model.h" | 14 #include "components/offline_pages/offline_page_model.h" |
| 15 #include "jni/OfflinePageDownloadBridge_jni.h" | 15 #include "jni/OfflinePageDownloadBridge_jni.h" |
| 16 #include "net/base/filename_util.h" | 16 #include "net/base/filename_util.h" |
| 17 | 17 |
| 18 using base::android::AttachCurrentThread; | 18 using base::android::AttachCurrentThread; |
| 19 using base::android::ConvertJavaStringToUTF8; | 19 using base::android::ConvertJavaStringToUTF8; |
| 20 using base::android::ConvertUTF8ToJavaString; | 20 using base::android::ConvertUTF8ToJavaString; |
|
fgorski
2016/08/09 04:00:50
please add missing using statement here:
using bas
Dmitry Titov
2016/08/12 04:01:39
Done.
| |
| 21 using base::android::ScopedJavaGlobalRef; | 21 using base::android::ScopedJavaGlobalRef; |
| 22 using base::android::ScopedJavaLocalRef; | 22 using base::android::ScopedJavaLocalRef; |
| 23 | 23 |
| 24 namespace offline_pages { | 24 namespace offline_pages { |
| 25 namespace android { | 25 namespace android { |
| 26 | 26 |
| 27 namespace { | 27 namespace { |
| 28 | 28 |
| 29 void ToJavaOfflinePageDownloadItemList(JNIEnv* env, | 29 void ToJavaOfflinePageDownloadItemList(JNIEnv* env, |
| 30 jobject j_result_obj, | 30 jobject j_result_obj, |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 68 | 68 |
| 69 void OfflinePageDownloadBridge::Destroy(JNIEnv* env, | 69 void OfflinePageDownloadBridge::Destroy(JNIEnv* env, |
| 70 const JavaParamRef<jobject>&) { | 70 const JavaParamRef<jobject>&) { |
| 71 download_ui_adapter_->RemoveObserver(this); | 71 download_ui_adapter_->RemoveObserver(this); |
| 72 delete this; | 72 delete this; |
| 73 } | 73 } |
| 74 | 74 |
| 75 void OfflinePageDownloadBridge::GetAllItems( | 75 void OfflinePageDownloadBridge::GetAllItems( |
| 76 JNIEnv* env, | 76 JNIEnv* env, |
| 77 const JavaParamRef<jobject>& obj, | 77 const JavaParamRef<jobject>& obj, |
| 78 const JavaParamRef<jobject>& j_result_obj) { | 78 const JavaParamRef<jobject>& j_result_obj) { |
|
fgorski
2016/08/09 04:00:50
because of this.
Dmitry Titov
2016/08/12 04:01:39
Acknowledged.
| |
| 79 DCHECK(j_result_obj); | 79 DCHECK(j_result_obj); |
| 80 | 80 |
| 81 const DownloadUIItemsMap& items_map = download_ui_adapter_->GetAllItems(); | 81 const DownloadUIItemsMap& items_map = download_ui_adapter_->GetAllItems(); |
| 82 ToJavaOfflinePageDownloadItemList(env, j_result_obj, items_map); | 82 ToJavaOfflinePageDownloadItemList(env, j_result_obj, items_map); |
| 83 } | 83 } |
| 84 | 84 |
| 85 ScopedJavaLocalRef<jobject> OfflinePageDownloadBridge::GetItemByGuid( | 85 ScopedJavaLocalRef<jobject> OfflinePageDownloadBridge::GetItemByGuid( |
| 86 JNIEnv* env, | 86 JNIEnv* env, |
| 87 const JavaParamRef<jobject>& obj, | 87 const JavaParamRef<jobject>& obj, |
| 88 const base::android::JavaParamRef<jstring>& j_guid) { | 88 const base::android::JavaParamRef<jstring>& j_guid) { |
|
fgorski
2016/08/09 04:00:50
remove base::android:: from here, and other JavaPa
Dmitry Titov
2016/08/12 04:01:39
Done.
| |
| 89 std::string guid = ConvertJavaStringToUTF8(env, j_guid); | 89 std::string guid = ConvertJavaStringToUTF8(env, j_guid); |
| 90 const DownloadUIItem* item = download_ui_adapter_->GetItem(guid); | 90 const DownloadUIItem* item = download_ui_adapter_->GetItem(guid); |
| 91 return ToJavaOfflinePageDownloadItem(env, *item); | 91 return ToJavaOfflinePageDownloadItem(env, *item); |
| 92 } | 92 } |
| 93 | 93 |
| 94 void OfflinePageDownloadBridge::DeleteItemByGuid( | |
| 95 JNIEnv* env, | |
| 96 const JavaParamRef<jobject>& obj, | |
| 97 const base::android::JavaParamRef<jstring>& j_guid) { | |
|
fgorski
2016/08/09 04:00:50
including here.
Dmitry Titov
2016/08/12 04:01:39
Done.
| |
| 98 std::string guid = ConvertJavaStringToUTF8(env, j_guid); | |
| 99 download_ui_adapter_->DeleteItem(guid); | |
| 100 } | |
| 101 | |
| 102 ScopedJavaLocalRef<jstring> OfflinePageDownloadBridge::GetOfflineUrlByGuid( | |
| 103 JNIEnv* env, | |
| 104 const JavaParamRef<jobject>& obj, | |
| 105 const base::android::JavaParamRef<jstring>& j_guid) { | |
|
fgorski
2016/08/09 04:00:50
and here.
Dmitry Titov
2016/08/12 04:01:39
Done.
| |
| 106 std::string guid = ConvertJavaStringToUTF8(env, j_guid); | |
| 107 std::string url = download_ui_adapter_->GetOfflineUrlByGuid(guid); | |
| 108 if (url.empty()) | |
| 109 return ScopedJavaLocalRef<jstring>(); | |
| 110 return ConvertUTF8ToJavaString(env, url); | |
|
fgorski
2016/08/09 04:00:50
It should simply work if url is empty, I don't thi
Dmitry Titov
2016/08/12 04:01:39
Done.
| |
| 111 } | |
| 112 | |
| 94 void OfflinePageDownloadBridge::ItemsLoaded() { | 113 void OfflinePageDownloadBridge::ItemsLoaded() { |
| 95 JNIEnv* env = AttachCurrentThread(); | 114 JNIEnv* env = AttachCurrentThread(); |
| 96 ScopedJavaLocalRef<jobject> obj = weak_java_ref_.get(env); | 115 ScopedJavaLocalRef<jobject> obj = weak_java_ref_.get(env); |
| 97 if (obj.is_null()) | 116 if (obj.is_null()) |
| 98 return; | 117 return; |
| 99 Java_OfflinePageDownloadBridge_downloadItemsLoaded(env, obj.obj()); | 118 Java_OfflinePageDownloadBridge_downloadItemsLoaded(env, obj.obj()); |
| 100 } | 119 } |
| 101 | 120 |
| 102 void OfflinePageDownloadBridge::ItemAdded(const DownloadUIItem& item) { | 121 void OfflinePageDownloadBridge::ItemAdded(const DownloadUIItem& item) { |
| 103 JNIEnv* env = AttachCurrentThread(); | 122 JNIEnv* env = AttachCurrentThread(); |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 135 | 154 |
| 136 DownloadUIAdapter* adapter = | 155 DownloadUIAdapter* adapter = |
| 137 DownloadUIAdapter::FromOfflinePageModel(offline_page_model); | 156 DownloadUIAdapter::FromOfflinePageModel(offline_page_model); |
| 138 | 157 |
| 139 return reinterpret_cast<jlong>( | 158 return reinterpret_cast<jlong>( |
| 140 new OfflinePageDownloadBridge(env, obj, adapter)); | 159 new OfflinePageDownloadBridge(env, obj, adapter)); |
| 141 } | 160 } |
| 142 | 161 |
| 143 } // namespace android | 162 } // namespace android |
| 144 } // namespace offline_pages | 163 } // namespace offline_pages |
| OLD | NEW |