Home | History | Annotate | Download | only in service
      1 //
      2 //  Copyright (C) 2015 Google, Inc.
      3 //
      4 //  Licensed under the Apache License, Version 2.0 (the "License");
      5 //  you may not use this file except in compliance with the License.
      6 //  You may obtain a copy of the License at:
      7 //
      8 //  http://www.apache.org/licenses/LICENSE-2.0
      9 //
     10 //  Unless required by applicable law or agreed to in writing, software
     11 //  distributed under the License is distributed on an "AS IS" BASIS,
     12 //  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13 //  See the License for the specific language governing permissions and
     14 //  limitations under the License.
     15 //
     16 #include "logging_helpers.h"
     17 
     18 #include <string.h>
     19 
     20 #include <string>
     21 
     22 #define CASE_RETURN_TEXT(code) \
     23   case code:                   \
     24     return #code
     25 
     26 const char *BtAvConnectionStateText(const btav_connection_state_t state) {
     27   switch (state) {
     28     CASE_RETURN_TEXT(BTAV_CONNECTION_STATE_DISCONNECTED);
     29     CASE_RETURN_TEXT(BTAV_CONNECTION_STATE_CONNECTING);
     30     CASE_RETURN_TEXT(BTAV_CONNECTION_STATE_CONNECTED);
     31     CASE_RETURN_TEXT(BTAV_CONNECTION_STATE_DISCONNECTING);
     32     default:
     33       return "Invalid AV connection state";
     34   }
     35 }
     36 
     37 const char *BtAvAudioStateText(const btav_audio_state_t state) {
     38   switch (state) {
     39     CASE_RETURN_TEXT(BTAV_AUDIO_STATE_REMOTE_SUSPEND);
     40     CASE_RETURN_TEXT(BTAV_AUDIO_STATE_STOPPED);
     41     CASE_RETURN_TEXT(BTAV_AUDIO_STATE_STARTED);
     42     default:
     43       return "Invalid audio state";
     44   }
     45 }
     46 
     47 const char *BtTransportText(const btgatt_transport_t t) {
     48   switch(t) {
     49     CASE_RETURN_TEXT(GATT_TRANSPORT_AUTO);
     50     CASE_RETURN_TEXT(GATT_TRANSPORT_BREDR);
     51     CASE_RETURN_TEXT(GATT_TRANSPORT_LE);
     52     default:
     53       return "unknown transport";
     54   }
     55 }
     56 
     57 const char *BtStateText(const bt_state_t state) {
     58   switch (state) {
     59     CASE_RETURN_TEXT(BT_STATE_OFF);
     60     CASE_RETURN_TEXT(BT_STATE_ON);
     61     default:
     62       return "unknown state code";
     63   }
     64 }
     65 
     66 const char *BtDiscoveryStateText(const bt_discovery_state_t state) {
     67   switch (state) {
     68     CASE_RETURN_TEXT(BT_DISCOVERY_STOPPED);
     69     CASE_RETURN_TEXT(BT_DISCOVERY_STARTED);
     70     default:
     71       return "unknown discovery state code";
     72   }
     73 }
     74 
     75 const char *BtScanModeText(const bt_scan_mode_t mode) {
     76   switch (mode) {
     77     CASE_RETURN_TEXT(BT_SCAN_MODE_NONE);
     78     CASE_RETURN_TEXT(BT_SCAN_MODE_CONNECTABLE);
     79     CASE_RETURN_TEXT(BT_SCAN_MODE_CONNECTABLE_DISCOVERABLE);
     80     default:
     81       return "unknown scan mode";
     82   }
     83 }
     84 
     85 const char *BtStatusText(const bt_status_t status) {
     86   switch (status) {
     87     CASE_RETURN_TEXT(BT_STATUS_SUCCESS);
     88     CASE_RETURN_TEXT(BT_STATUS_FAIL);
     89     CASE_RETURN_TEXT(BT_STATUS_NOT_READY);
     90     CASE_RETURN_TEXT(BT_STATUS_NOMEM);
     91     CASE_RETURN_TEXT(BT_STATUS_DONE);
     92     CASE_RETURN_TEXT(BT_STATUS_BUSY);
     93     CASE_RETURN_TEXT(BT_STATUS_UNSUPPORTED);
     94     CASE_RETURN_TEXT(BT_STATUS_PARM_INVALID);
     95     CASE_RETURN_TEXT(BT_STATUS_UNHANDLED);
     96     CASE_RETURN_TEXT(BT_STATUS_AUTH_FAILURE);
     97     CASE_RETURN_TEXT(BT_STATUS_RMT_DEV_DOWN);
     98     CASE_RETURN_TEXT(BT_STATUS_AUTH_REJECTED);
     99     default:
    100       return "unknown status code";
    101   }
    102 }
    103 
    104 const char *BtPropertyText(const bt_property_type_t prop) {
    105   switch (prop) {
    106     CASE_RETURN_TEXT(BT_PROPERTY_BDNAME);
    107     CASE_RETURN_TEXT(BT_PROPERTY_BDADDR);
    108     CASE_RETURN_TEXT(BT_PROPERTY_UUIDS);
    109     CASE_RETURN_TEXT(BT_PROPERTY_CLASS_OF_DEVICE);
    110     CASE_RETURN_TEXT(BT_PROPERTY_TYPE_OF_DEVICE);
    111     CASE_RETURN_TEXT(BT_PROPERTY_SERVICE_RECORD);
    112     CASE_RETURN_TEXT(BT_PROPERTY_ADAPTER_SCAN_MODE);
    113     CASE_RETURN_TEXT(BT_PROPERTY_ADAPTER_BONDED_DEVICES);
    114     CASE_RETURN_TEXT(BT_PROPERTY_ADAPTER_DISCOVERY_TIMEOUT);
    115     CASE_RETURN_TEXT(BT_PROPERTY_REMOTE_FRIENDLY_NAME);
    116     CASE_RETURN_TEXT(BT_PROPERTY_REMOTE_RSSI);
    117     CASE_RETURN_TEXT(BT_PROPERTY_REMOTE_VERSION_INFO);
    118     CASE_RETURN_TEXT(BT_PROPERTY_LOCAL_LE_FEATURES);
    119     CASE_RETURN_TEXT(BT_PROPERTY_REMOTE_DEVICE_TIMESTAMP);
    120     default:
    121       return "Invalid property";
    122   }
    123 }
    124 
    125 const char *BtEventText(const bt_cb_thread_evt evt) {
    126   switch (evt) {
    127     CASE_RETURN_TEXT(ASSOCIATE_JVM);
    128     CASE_RETURN_TEXT(DISASSOCIATE_JVM);
    129     default:
    130       return "unknown state code";
    131   }
    132 }
    133 
    134 const char *BtAclText(const bt_acl_state_t code) {
    135   switch (code) {
    136     CASE_RETURN_TEXT(BT_ACL_STATE_CONNECTED);
    137     CASE_RETURN_TEXT(BT_ACL_STATE_DISCONNECTED);
    138     default:
    139       return "unknown ACL code";
    140   }
    141 }
    142 
    143 std::string BtAddrString(const bt_bdaddr_t *addr) {
    144   char buffer[20];
    145   snprintf(buffer, sizeof(buffer), "%02X:%02X:%02X:%02X:%02X:%02X",
    146            addr->address[0], addr->address[1], addr->address[2],
    147            addr->address[3], addr->address[4], addr->address[5]);
    148   return std::string(buffer);
    149 }
    150