Home | History | Annotate | Download | only in src
      1 /******************************************************************************
      2  *
      3  *  Copyright (C) 2015 Google, Inc.
      4  *
      5  *  Licensed under the Apache License, Version 2.0 (the "License");
      6  *  you may not use this file except in compliance with the License.
      7  *  You may obtain a copy of the License at:
      8  *
      9  *  http://www.apache.org/licenses/LICENSE-2.0
     10  *
     11  *  Unless required by applicable law or agreed to in writing, software
     12  *  distributed under the License is distributed on an "AS IS" BASIS,
     13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     14  *  See the License for the specific language governing permissions and
     15  *  limitations under the License.
     16  *
     17  ******************************************************************************/
     18 #define LOG_TAG "hash_map_utils"
     19 
     20 #include "osi/include/hash_map_utils.h"
     21 
     22 #include <base/logging.h>
     23 #include <string.h>
     24 
     25 #include "osi/include/allocator.h"
     26 #include "osi/include/log.h"
     27 #include "osi/include/osi.h"
     28 
     29 std::unordered_map<std::string, std::string>
     30 hash_map_utils_new_from_string_params(const char* params) {
     31   CHECK(params != NULL);
     32 
     33   std::unordered_map<std::string, std::string> map;
     34 
     35   char* str = osi_strdup(params);
     36   if (!str) return map;
     37 
     38   LOG_VERBOSE(LOG_TAG, "%s: source string: '%s'", __func__, str);
     39 
     40   // Parse |str| and add extracted key-and-value pair(s) in |map|.
     41   int items = 0;
     42   char* tmpstr;
     43   char* kvpair = strtok_r(str, ";", &tmpstr);
     44   while (kvpair && *kvpair) {
     45     char* eq = strchr(kvpair, '=');
     46 
     47     if (eq == kvpair) goto next_pair;
     48 
     49     char* key;
     50     char* value;
     51     if (eq) {
     52       key = osi_strndup(kvpair, eq - kvpair);
     53 
     54       // The increment of |eq| moves |eq| to the beginning of the value.
     55       ++eq;
     56       value = (*eq != '\0') ? osi_strdup(eq) : osi_strdup("");
     57     } else {
     58       key = osi_strdup(kvpair);
     59       value = osi_strdup("");
     60     }
     61 
     62     map[key] = value;
     63 
     64     osi_free(key);
     65     osi_free(value);
     66 
     67     items++;
     68   next_pair:
     69     kvpair = strtok_r(NULL, ";", &tmpstr);
     70   }
     71 
     72   if (!items) LOG_VERBOSE(LOG_TAG, "%s: no items found in string\n", __func__);
     73 
     74   osi_free(str);
     75   return map;
     76 }
     77 
     78 void hash_map_utils_dump_string_keys_string_values(
     79     std::unordered_map<std::string, std::string>& map) {
     80   for (const auto& ptr : map) {
     81     LOG_INFO(LOG_TAG, "key: '%s' value: '%s'\n", ptr.first.c_str(),
     82              ptr.second.c_str());
     83   }
     84 }
     85