blob: 4c1d9f246df501c098ed61289435a1df5c218f6e [file] [log] [blame]
The Android Open Source Project0c908882009-03-03 19:32:16 -08001/*
2 * Copyright (C) 2006 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Bijan Amirzada41242f22014-03-21 12:12:18 -070017package com.android.browser;
The Android Open Source Project0c908882009-03-03 19:32:16 -080018
Enrico Ros1c4d6b82014-10-14 16:23:17 -070019import android.Manifest;
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -070020import android.app.Activity;
The Android Open Source Project0c908882009-03-03 19:32:16 -080021import android.app.Application;
Bijan Amirzada9b1e9882014-02-26 17:15:46 -080022import android.content.Context;
23import android.content.pm.PackageManager;
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -070024import android.os.Bundle;
Enrico Ros1c4d6b82014-10-14 16:23:17 -070025import android.util.Log;
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -070026import android.os.Process;
Tarun Nainaniea28dde2014-08-27 17:25:09 -070027
Vivek Sekhar0989b452014-08-01 12:30:35 -070028import org.codeaurora.swe.Engine;
Bijan Amirzada9b1e9882014-02-26 17:15:46 -080029
30public class Browser extends Application {
The Android Open Source Project0c908882009-03-03 19:32:16 -080031
32 private final static String LOGTAG = "browser";
Bijan Amirzada9b1e9882014-02-26 17:15:46 -080033
Dave Bort31a6d1c2009-04-13 15:56:49 -070034 // Set to true to enable verbose logging.
John Reck6c2e2f32011-08-22 13:41:23 -070035 final static boolean LOGV_ENABLED = false;
Dave Bort31a6d1c2009-04-13 15:56:49 -070036
37 // Set to true to enable extra debug logging.
38 final static boolean LOGD_ENABLED = true;
39
John Reck6f48ba52010-12-03 16:03:14 -080040 @Override
The Android Open Source Project0c908882009-03-03 19:32:16 -080041 public void onCreate() {
Kristian Monsene800e8e2010-12-06 16:59:33 +000042 super.onCreate();
Enrico Ros1c4d6b82014-10-14 16:23:17 -070043
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -070044 if (LOGV_ENABLED) {
The Android Open Source Project0c908882009-03-03 19:32:16 -080045 Log.v(LOGTAG, "Browser.onCreate: this=" + this);
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -070046 }
47
48 registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() {
49 @Override
50 public void onActivityCreated(final Activity activity, Bundle savedInstanceState) {
51 if (LOGV_ENABLED) {
52 Log.v(LOGTAG, "Browser.onActivityCreated: activity=" + activity);
53 }
54 if (!(activity instanceof BrowserActivity) && !(activity instanceof BrowserLauncher) ) {
55 EngineInitializer.getInstance().initializeSync((Context) Browser.this);
56 }
57 }
58
59 @Override
60 public void onActivityDestroyed(Activity activity) {
61 if (LOGV_ENABLED) {
62 Log.v(LOGTAG, "Browser.onActivityDestroyed: activity=" + activity);
63 }
64 }
65
66 @Override
67 public void onActivityPaused(Activity activity) {
68 if (LOGV_ENABLED) {
69 Log.v(LOGTAG, "Browser.onActivityPaused: activity=" + activity);
70 }
71 }
72
73 @Override
74 public void onActivityResumed(Activity activity) {
75 if (LOGV_ENABLED) {
76 Log.v(LOGTAG, "Browser.onActivityResumed: activity=" + activity);
77 }
78 }
79
80 @Override
81 public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
82 if (LOGV_ENABLED) {
83 Log.v(LOGTAG, "Browser.onActivitySaveInstanceState: activity=" + activity);
84 }
85 }
86
87 @Override
88 public void onActivityStarted(Activity activity) {
89 if (LOGV_ENABLED) {
90 Log.v(LOGTAG, "Browser.onActivityStarted: activity=" + activity);
91 }
92 }
93
94 @Override
95 public void onActivityStopped(Activity activity) {
96 if (LOGV_ENABLED) {
97 Log.v(LOGTAG, "Browser.onActivityStopped: activity=" + activity);
98 }
99 }
100 });
Kristian Monsene800e8e2010-12-06 16:59:33 +0000101
Enrico Ros1c4d6b82014-10-14 16:23:17 -0700102 // Chromium specific initialization.
Tarun Nainani8eb00912014-07-17 12:28:32 -0700103 Engine.initializeApplicationParameters();
Enrico Ros1c4d6b82014-10-14 16:23:17 -0700104
105 final boolean isSandboxContext = checkPermission(Manifest.permission.INTERNET,
106 Process.myPid(), Process.myUid()) != PackageManager.PERMISSION_GRANTED;
107
Kulanthaivel Palanichamy77942682014-10-28 11:52:06 -0700108 // SWE: Avoid initializing the engine for sandboxed processes.
109 if (!isSandboxContext) {
Enrico Ros1c4d6b82014-10-14 16:23:17 -0700110 BrowserSettings.initialize((Context) this);
111 Preloader.initialize((Context) this);
112 }
Tarun Nainaniea28dde2014-08-27 17:25:09 -0700113
114 }
The Android Open Source Project0c908882009-03-03 19:32:16 -0800115}
116