/*
* Copyright 2009, 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.bluetoothdebug;
import android.bluetooth.BluetoothA2dp;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothClass;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothDevicePicker;
import android.bluetooth.BluetoothHeadset;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
/**
* Prints Bluetooth intents to logcat. For example:
* BTDEBUG : a.b.device.a.FOUND
* BTDEBUG : a.b.device.e.DEVICE = 00:18:13:F2:CC:33
* BTDEBUG : a.b.device.e.RSSI = -35
* BTDEBUG : a.b.device.e.CLASS = 200404
* BTDEBUG : a.b.adapter.a.DISCOVERY_FINISHED
* BTDEBUG : a.b.device.a.BOND_STATE_CHANGED
* BTDEBUG : a.b.device.e.DEVICE = 00:18:13:F2:CC:33
* BTDEBUG : a.b.device.e.BOND_STATE = 11
* BTDEBUG : a.b.device.e.PREVIOUS_BOND_STATE = 10
*/
public class DebugReceiver extends BroadcastReceiver {
private static final String TAG = "BTDEBUG";
public void onReceive(Context context, Intent intent) {
Log.d(TAG, shorten(intent.getAction()));
Bundle bundle = intent.getExtras();
if (bundle == null) return;
for (String extra : bundle.keySet()) {
Log.d(TAG, "\t" + shorten(extra) + " = " + bundle.get(extra));
}
}
// shorten string to shorthand
// android.bluetooth.device.extra.DEVICE -> a.b.device.e.DEVICE
private static String shorten(String action) {
return action.replace("android", "a")
.replace("bluetooth", "b")
.replace("extra", "e")
.replace("action", "a");
}
}