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

Side by Side Diff: chrome/browser/android/webapk/webapk_update_manager.cc

Issue 2409453002: Fix crash on WebAPK startup (Closed)
Patch Set: Merge branch 'master' into startup_crash0 Created 4 years, 2 months 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
« no previous file with comments | « chrome/browser/android/webapk/webapk_update_manager.h ('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 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/webapk/webapk_update_manager.h" 5 #include "chrome/browser/android/webapk/webapk_update_manager.h"
6 6
7 #include <jni.h> 7 #include <jni.h>
8 8
9 #include "base/android/jni_string.h" 9 #include "base/android/jni_string.h"
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "chrome/browser/android/webapk/webapk_installer.h" 11 #include "chrome/browser/android/webapk/webapk_installer.h"
12 #include "chrome/browser/profiles/profile.h" 12 #include "chrome/browser/profiles/profile.h"
13 #include "chrome/browser/profiles/profile_manager.h" 13 #include "chrome/browser/profiles/profile_manager.h"
14 #include "content/public/browser/browser_thread.h" 14 #include "content/public/browser/browser_thread.h"
15 #include "jni/WebApkUpdateManager_jni.h" 15 #include "jni/WebApkUpdateManager_jni.h"
16 #include "third_party/skia/include/core/SkBitmap.h" 16 #include "third_party/skia/include/core/SkBitmap.h"
17 #include "ui/gfx/android/java_bitmap.h" 17 #include "ui/gfx/android/java_bitmap.h"
18 #include "url/gurl.h" 18 #include "url/gurl.h"
19 19
20 using base::android::JavaParamRef; 20 using base::android::JavaParamRef;
21 21
22 // static 22 // static
23 bool WebApkUpdateManager::Register(JNIEnv* env) { 23 bool WebApkUpdateManager::Register(JNIEnv* env) {
24 return RegisterNativesImpl(env); 24 return RegisterNativesImpl(env);
25 } 25 }
26 26
27 // static 27 // static
28 void WebApkUpdateManager::OnBuiltWebApk(bool success, 28 void WebApkUpdateManager::OnBuiltWebApk(const std::string& id,
29 bool success,
29 const std::string& webapk_package) { 30 const std::string& webapk_package) {
30 JNIEnv* env = base::android::AttachCurrentThread(); 31 JNIEnv* env = base::android::AttachCurrentThread();
31 32
32 if (success) { 33 if (success) {
33 DVLOG(1) 34 DVLOG(1)
34 << "Sent request to update WebAPK to server. Seems to have worked."; 35 << "Sent request to update WebAPK to server. Seems to have worked.";
35 } else { 36 } else {
36 LOG(WARNING) << "Server request to update WebAPK failed."; 37 LOG(WARNING) << "Server request to update WebAPK failed.";
37 } 38 }
38 39
39 base::android::ScopedJavaLocalRef<jstring> java_webapk_package = 40 base::android::ScopedJavaLocalRef<jstring> java_id =
40 base::android::ConvertUTF8ToJavaString(env, webapk_package); 41 base::android::ConvertUTF8ToJavaString(env, id);
41 Java_WebApkUpdateManager_onBuiltWebApk(env, success, 42 Java_WebApkUpdateManager_onBuiltWebApk(env, java_id.obj(), success);
42 java_webapk_package.obj());
43 } 43 }
44 44
45 // static JNI method. 45 // static JNI method.
46 static void UpdateAsync(JNIEnv* env, 46 static void UpdateAsync(JNIEnv* env,
47 const JavaParamRef<jclass>& clazz, 47 const JavaParamRef<jclass>& clazz,
48 const JavaParamRef<jstring>& java_id,
48 const JavaParamRef<jstring>& java_start_url, 49 const JavaParamRef<jstring>& java_start_url,
49 const JavaParamRef<jstring>& java_scope, 50 const JavaParamRef<jstring>& java_scope,
50 const JavaParamRef<jstring>& java_name, 51 const JavaParamRef<jstring>& java_name,
51 const JavaParamRef<jstring>& java_short_name, 52 const JavaParamRef<jstring>& java_short_name,
52 const JavaParamRef<jstring>& java_icon_url, 53 const JavaParamRef<jstring>& java_icon_url,
53 const JavaParamRef<jstring>& java_icon_murmur2_hash, 54 const JavaParamRef<jstring>& java_icon_murmur2_hash,
54 const JavaParamRef<jobject>& java_icon_bitmap, 55 const JavaParamRef<jobject>& java_icon_bitmap,
55 jint java_display_mode, 56 jint java_display_mode,
56 jint java_orientation, 57 jint java_orientation,
57 jlong java_theme_color, 58 jlong java_theme_color,
58 jlong java_background_color, 59 jlong java_background_color,
59 const JavaParamRef<jstring>& java_web_manifest_url, 60 const JavaParamRef<jstring>& java_web_manifest_url,
60 const JavaParamRef<jstring>& java_webapk_package, 61 const JavaParamRef<jstring>& java_webapk_package,
61 jint java_webapk_version) { 62 jint java_webapk_version) {
62 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 63 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
63 64
64 Profile* profile = ProfileManager::GetLastUsedProfile(); 65 Profile* profile = ProfileManager::GetLastUsedProfile();
65 if (profile == nullptr) { 66 if (profile == nullptr) {
66 NOTREACHED() << "Profile not found."; 67 NOTREACHED() << "Profile not found.";
67 return; 68 return;
68 } 69 }
69 70
71 std::string id(ConvertJavaStringToUTF8(env, java_id));
70 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); 72 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url));
71 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); 73 GURL scope(ConvertJavaStringToUTF8(env, java_scope));
72 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); 74 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url));
73 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url)); 75 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url));
74 ShortcutInfo info(start_url); 76 ShortcutInfo info(start_url);
75 info.scope = scope; 77 info.scope = scope;
76 info.name = ConvertJavaStringToUTF16(env, java_name); 78 info.name = ConvertJavaStringToUTF16(env, java_name);
77 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); 79 info.short_name = ConvertJavaStringToUTF16(env, java_short_name);
78 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); 80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode);
79 info.orientation = 81 info.orientation =
80 static_cast<blink::WebScreenOrientationLockType>(java_orientation); 82 static_cast<blink::WebScreenOrientationLockType>(java_orientation);
81 info.theme_color = (long)java_theme_color; 83 info.theme_color = (long)java_theme_color;
82 info.background_color = (long)java_background_color; 84 info.background_color = (long)java_background_color;
83 info.icon_url = icon_url; 85 info.icon_url = icon_url;
84 info.manifest_url = web_manifest_url; 86 info.manifest_url = web_manifest_url;
85 87
86 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap); 88 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap);
87 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); 89 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock);
88 icon_bitmap.setImmutable(); 90 icon_bitmap.setImmutable();
89 91
90 std::string icon_murmur2_hash; 92 std::string icon_murmur2_hash;
91 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash); 93 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash);
92 94
93 std::string webapk_package; 95 std::string webapk_package;
94 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); 96 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package);
95 97
96 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap); 98 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap);
97 installer->UpdateAsync( 99 installer->UpdateAsync(
98 profile, 100 profile,
99 base::Bind(&WebApkUpdateManager::OnBuiltWebApk), 101 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id),
100 icon_murmur2_hash, webapk_package, java_webapk_version); 102 icon_murmur2_hash, webapk_package, java_webapk_version);
101 } 103 }
OLDNEW
« no previous file with comments | « chrome/browser/android/webapk/webapk_update_manager.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698