|  | /* | 
|  | * 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"); | 
|  | } | 
|  |  | 
|  | } |