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

Side by Side Diff: chrome/browser/ui/android/autofill/credit_card_scanner_view_android.cc

Issue 2784353002: Android: Remove GetApplicationContext part 2 (Closed)
Patch Set: Fix tests Created 3 years, 8 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
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/ui/android/autofill/credit_card_scanner_view_android.h" 5 #include "chrome/browser/ui/android/autofill/credit_card_scanner_view_android.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/android/context_utils.h"
10 #include "base/android/jni_android.h" 9 #include "base/android/jni_android.h"
11 #include "base/android/jni_string.h" 10 #include "base/android/jni_string.h"
12 #include "base/feature_list.h" 11 #include "base/feature_list.h"
13 #include "base/memory/ptr_util.h" 12 #include "base/memory/ptr_util.h"
14 #include "chrome/browser/ui/android/view_android_helper.h" 13 #include "chrome/browser/ui/android/view_android_helper.h"
15 #include "chrome/browser/ui/autofill/credit_card_scanner_view_delegate.h" 14 #include "chrome/browser/ui/autofill/credit_card_scanner_view_delegate.h"
16 #include "components/autofill/core/browser/autofill_experiments.h" 15 #include "components/autofill/core/browser/autofill_experiments.h"
17 #include "components/autofill/core/browser/credit_card.h" 16 #include "components/autofill/core/browser/credit_card.h"
18 #include "components/autofill/core/browser/field_types.h" 17 #include "components/autofill/core/browser/field_types.h"
19 #include "content/public/browser/android/content_view_core.h" 18 #include "content/public/browser/android/content_view_core.h"
20 #include "jni/CreditCardScannerBridge_jni.h" 19 #include "jni/CreditCardScannerBridge_jni.h"
21 #include "ui/android/view_android.h" 20 #include "ui/android/view_android.h"
22 #include "ui/android/window_android.h" 21 #include "ui/android/window_android.h"
23 22
24 using base::android::JavaParamRef; 23 using base::android::JavaParamRef;
25 24
26 namespace autofill { 25 namespace autofill {
27 26
28 // static 27 // static
29 bool CreditCardScannerView::CanShow() { 28 bool CreditCardScannerView::CanShow() {
30 JNIEnv* env = base::android::AttachCurrentThread(); 29 JNIEnv* env = base::android::AttachCurrentThread();
31 base::android::ScopedJavaGlobalRef<jobject> java_object( 30 base::android::ScopedJavaGlobalRef<jobject> java_object(
32 Java_CreditCardScannerBridge_create( 31 Java_CreditCardScannerBridge_create(env, 0, nullptr));
33 env, 0, base::android::GetApplicationContext(), nullptr));
34 return Java_CreditCardScannerBridge_canScan(env, java_object); 32 return Java_CreditCardScannerBridge_canScan(env, java_object);
35 } 33 }
36 34
37 // static 35 // static
38 std::unique_ptr<CreditCardScannerView> CreditCardScannerView::Create( 36 std::unique_ptr<CreditCardScannerView> CreditCardScannerView::Create(
39 const base::WeakPtr<CreditCardScannerViewDelegate>& delegate, 37 const base::WeakPtr<CreditCardScannerViewDelegate>& delegate,
40 content::WebContents* web_contents) { 38 content::WebContents* web_contents) {
41 return base::WrapUnique( 39 return base::WrapUnique(
42 new CreditCardScannerViewAndroid(delegate, web_contents)); 40 new CreditCardScannerViewAndroid(delegate, web_contents));
43 } 41 }
44 42
45 // static 43 // static
46 bool CreditCardScannerViewAndroid::Register(JNIEnv* env) { 44 bool CreditCardScannerViewAndroid::Register(JNIEnv* env) {
47 return RegisterNativesImpl(env); 45 return RegisterNativesImpl(env);
48 } 46 }
49 47
50 CreditCardScannerViewAndroid::CreditCardScannerViewAndroid( 48 CreditCardScannerViewAndroid::CreditCardScannerViewAndroid(
51 const base::WeakPtr<CreditCardScannerViewDelegate>& delegate, 49 const base::WeakPtr<CreditCardScannerViewDelegate>& delegate,
52 content::WebContents* web_contents) 50 content::WebContents* web_contents)
53 : delegate_(delegate), 51 : delegate_(delegate),
54 java_object_(Java_CreditCardScannerBridge_create( 52 java_object_(Java_CreditCardScannerBridge_create(
55 base::android::AttachCurrentThread(), 53 base::android::AttachCurrentThread(),
56 reinterpret_cast<intptr_t>(this), 54 reinterpret_cast<intptr_t>(this),
57 base::android::GetApplicationContext(),
58 web_contents->GetJavaWebContents())) {} 55 web_contents->GetJavaWebContents())) {}
59 56
60 CreditCardScannerViewAndroid::~CreditCardScannerViewAndroid() {} 57 CreditCardScannerViewAndroid::~CreditCardScannerViewAndroid() {}
61 58
62 void CreditCardScannerViewAndroid::ScanCancelled( 59 void CreditCardScannerViewAndroid::ScanCancelled(
63 JNIEnv* env, 60 JNIEnv* env,
64 const JavaParamRef<jobject>& object) { 61 const JavaParamRef<jobject>& object) {
65 delegate_->ScanCancelled(); 62 delegate_->ScanCancelled();
66 } 63 }
67 64
(...skipping 17 matching lines...) Expand all
85 82
86 delegate_->ScanCompleted(card); 83 delegate_->ScanCompleted(card);
87 } 84 }
88 85
89 void CreditCardScannerViewAndroid::Show() { 86 void CreditCardScannerViewAndroid::Show() {
90 JNIEnv* env = base::android::AttachCurrentThread(); 87 JNIEnv* env = base::android::AttachCurrentThread();
91 Java_CreditCardScannerBridge_scan(env, java_object_); 88 Java_CreditCardScannerBridge_scan(env, java_object_);
92 } 89 }
93 90
94 } // namespace autofill 91 } // namespace autofill
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698