/* * Copyright (C) 2008 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; import com.android.email.Controller; import com.android.email.Email; import com.android.email.Preferences; import com.android.email.R; import com.android.exchange.Eas; import com.android.exchange.utility.FileLogger; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.widget.CheckBox; import android.widget.CompoundButton; import android.widget.TextView; import android.widget.CompoundButton.OnCheckedChangeListener; public class Debug extends Activity implements OnCheckedChangeListener { private TextView mVersionView; private CheckBox mEnableDebugLoggingView; private CheckBox mEnableSensitiveLoggingView; private CheckBox mEnableExchangeLoggingView; private CheckBox mEnableExchangeFileLoggingView; private Preferences mPreferences; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.debug); mPreferences = Preferences.getPreferences(this); mVersionView = (TextView)findViewById(R.id.version); mEnableDebugLoggingView = (CheckBox)findViewById(R.id.debug_logging); mEnableSensitiveLoggingView = (CheckBox)findViewById(R.id.sensitive_logging); mEnableDebugLoggingView.setOnCheckedChangeListener(this); mEnableSensitiveLoggingView.setOnCheckedChangeListener(this); mVersionView.setText(String.format(getString(R.string.debug_version_fmt).toString(), getString(R.string.build_number))); mEnableDebugLoggingView.setChecked(Email.DEBUG); mEnableSensitiveLoggingView.setChecked(Email.DEBUG_SENSITIVE); //EXCHANGE-REMOVE-SECTION-START mEnableExchangeLoggingView = (CheckBox)findViewById(R.id.exchange_logging); mEnableExchangeFileLoggingView = (CheckBox)findViewById(R.id.exchange_file_logging); mEnableExchangeLoggingView.setOnCheckedChangeListener(this); mEnableExchangeFileLoggingView.setOnCheckedChangeListener(this); mEnableExchangeLoggingView.setChecked(Eas.USER_LOG); mEnableExchangeFileLoggingView.setChecked(Eas.FILE_LOG); //EXCHANGE-REMOVE-SECTION-END } public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { switch (buttonView.getId()) { case R.id.debug_logging: Email.DEBUG = isChecked; mPreferences.setEnableDebugLogging(Email.DEBUG); break; case R.id.sensitive_logging: Email.DEBUG_SENSITIVE = isChecked; mPreferences.setEnableSensitiveLogging(Email.DEBUG_SENSITIVE); break; //EXCHANGE-REMOVE-SECTION-START case R.id.exchange_logging: mPreferences.setEnableExchangeLogging(isChecked); break; case R.id.exchange_file_logging: mPreferences.setEnableExchangeFileLogging(isChecked); if (!isChecked) { FileLogger.close(); } break; //EXCHANGE-REMOVE-SECTION-END } updateLoggingFlags(this); } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == R.id.dump_settings) { Preferences.getPreferences(this).dump(); return true; } return super.onOptionsItemSelected(item); } @Override public boolean onCreateOptionsMenu(Menu menu) { super.onCreateOptionsMenu(menu); getMenuInflater().inflate(R.menu.debug_option, menu); return true; } /** * Load enabled debug flags from the preferences and upadte the EAS debug flag. */ public static void updateLoggingFlags(Context context) { //EXCHANGE-REMOVE-SECTION-START Preferences prefs = Preferences.getPreferences(context); int debugLogging = prefs.getEnableDebugLogging() ? Eas.DEBUG_BIT : 0; int exchangeLogging = prefs.getEnableExchangeLogging() ? Eas.DEBUG_EXCHANGE_BIT : 0; int fileLogging = prefs.getEnableExchangeFileLogging() ? Eas.DEBUG_FILE_BIT : 0; int debugBits = debugLogging | exchangeLogging | fileLogging; Controller.getInstance(context).serviceLogging(debugBits); //EXCHANGE-REMOVE-SECTION-END } }