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

}