replicant-packages_apps_Email/src/com/android/email/activity/setup/DebugFragment.java

138 lines
5.1 KiB
Java

/*
* Copyright (C) 2010 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.email.activity.setup;
import android.app.Fragment;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.WebView;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.CompoundButton.OnCheckedChangeListener;
import com.android.email.DebugUtils;
import com.android.email.Preferences;
import com.android.email.R;
import com.android.email.activity.UiUtilities;
import com.android.email.service.EmailServiceUtils;
import com.android.emailcommon.Logging;
import com.android.mail.preferences.MailPrefs;
import com.android.mail.utils.LogUtils;
public class DebugFragment extends Fragment implements OnCheckedChangeListener,
View.OnClickListener {
private Preferences mPreferences;
// Public no-args constructor needed for fragment re-instantiation
public DebugFragment() {}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (Logging.DEBUG_LIFECYCLE && DebugUtils.DEBUG) {
LogUtils.d(Logging.LOG_TAG, "DebugFragment onCreateView");
}
View view = inflater.inflate(R.layout.debug, container, false);
Context context = getActivity();
mPreferences = Preferences.getPreferences(context);
final CheckBox enableDebugLoggingView = UiUtilities.getView(view, R.id.debug_logging);
enableDebugLoggingView.setChecked(DebugUtils.DEBUG);
final CheckBox enableExchangeLoggingView = UiUtilities.getView(view, R.id.exchange_logging);
final CheckBox enableFileLoggingView = UiUtilities.getView(view, R.id.file_logging);
// Note: To prevent recursion while presetting checkboxes, assign all listeners last
enableDebugLoggingView.setOnCheckedChangeListener(this);
if (EmailServiceUtils.areRemoteServicesInstalled(context)) {
enableExchangeLoggingView.setChecked(DebugUtils.DEBUG_EXCHANGE);
enableFileLoggingView.setChecked(DebugUtils.DEBUG_FILE);
enableExchangeLoggingView.setOnCheckedChangeListener(this);
enableFileLoggingView.setOnCheckedChangeListener(this);
} else {
enableExchangeLoggingView.setVisibility(View.GONE);
enableFileLoggingView.setVisibility(View.GONE);
}
UiUtilities.getView(view, R.id.clear_webview_cache).setOnClickListener(this);
UiUtilities.getView(view, R.id.clear_migration_state).setOnClickListener(this);
final CheckBox enableStrictModeView =
UiUtilities.getView(view, R.id.debug_enable_strict_mode);
enableStrictModeView.setChecked(mPreferences.getEnableStrictMode());
enableStrictModeView.setOnCheckedChangeListener(this);
return view;
}
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
switch (buttonView.getId()) {
case R.id.debug_logging:
mPreferences.setEnableDebugLogging(isChecked);
DebugUtils.DEBUG = isChecked;
break;
case R.id.exchange_logging:
mPreferences.setEnableExchangeLogging(isChecked);
DebugUtils.DEBUG_EXCHANGE = isChecked;
break;
case R.id.file_logging:
mPreferences.setEnableExchangeFileLogging(isChecked);
DebugUtils.DEBUG_FILE = isChecked;
break;
case R.id.debug_enable_strict_mode:
mPreferences.setEnableStrictMode(isChecked);
DebugUtils.enableStrictMode(isChecked);
break;
}
DebugUtils.updateLoggingFlags(getActivity());
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.clear_webview_cache:
clearWebViewCache();
break;
case R.id.clear_migration_state:
clearMigrationState();
break;
}
}
private void clearWebViewCache() {
WebView webview = new WebView(getActivity());
try {
webview.clearCache(true);
LogUtils.w(Logging.LOG_TAG, "Cleard WebView cache.");
} finally {
webview.destroy();
}
}
private void clearMigrationState() {
MailPrefs prefs = MailPrefs.get(getActivity());
prefs.setMigrationState(MailPrefs.PreferenceKeys.MIGRATION_STATE_NONE);
}
}