当前位置: 首页>>代码示例>>C++>>正文


C++ STR_FUNC_MAP::find方法代码示例

本文整理汇总了C++中STR_FUNC_MAP::find方法的典型用法代码示例。如果您正苦于以下问题:C++ STR_FUNC_MAP::find方法的具体用法?C++ STR_FUNC_MAP::find怎么用?C++ STR_FUNC_MAP::find使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在STR_FUNC_MAP的用法示例。


在下文中一共展示了STR_FUNC_MAP::find方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: do_cmd

int32_t do_cmd(char* key)
{
  key = strip_line(key);
  if (!key[0])
  {
    return TFS_SUCCESS;
  }

#ifdef _WITH_READ_LINE
  // not blank line, add to history
  add_history(key);
#endif

  char* token = strchr(key, ' ');
  if (token != NULL)
  {
    *token = '\0';
  }

  STR_FUNC_MAP_ITER it = g_cmd_map.find(Func::str_to_lower(key));

  if (it == g_cmd_map.end())
  {
    fprintf(stderr, "unknown command. \n");
    return TFS_ERROR;
  }
  // ok this is current command
  g_cur_cmd = key;

  if (token != NULL)
  {
    token++;
    key = token;
  }
  else
  {
    key = NULL;
  }

  VSTRING param;
  param.clear();
  while ((token = strsep(&key, " ")) != NULL)
  {
    if ('\0' == token[0])
    {
      continue;
    }
    param.push_back(token);
  }

  // check param count
  int32_t param_cnt = param.size();
  if (param_cnt < it->second.min_param_cnt_ || param_cnt > it->second.max_param_cnt_)
  {
    fprintf(stderr, "%s\t\t%s\n\n", it->second.syntax_, it->second.info_);
    return TFS_ERROR;
  }

  return it->second.func_(param);
}
开发者ID:alimy,项目名称:tfs,代码行数:60,代码来源:adminservertool.cpp

示例2: get_nth_word

// get nth word in current input to store, base on keyth word to check count
int get_nth_word(int32_t nth, char* store, int32_t keyth)
{
  int32_t count = 0, pos = 0, start = 0, key_start = 0, key_end = 0, end = rl_point;
  store[0] = '\0';

  // reach current word's start
  while (end && !is_whitespace(rl_line_buffer[end]))
  {
    end--;
  }

  while (pos < end)
  {
    // reach next word's start
    while (pos < end && is_whitespace(rl_line_buffer[pos]))
    {
      pos++;
    }

    start = pos;
    // reach next word's end
    while (pos < end && !is_whitespace(rl_line_buffer[pos]))
    {
      pos++;
    }

    if (pos != start)
    {
      count++;
    }

    if (keyth == count)         // found key
    {
      key_start = start;
      key_end = pos;
    }
    if (nth == count)           // found nth
    {
      int len = pos - start;
      strncpy(store, rl_line_buffer+start, len);
      store[len] = '\0';
    }
  }

  if (count >= keyth)                // already have key, check count
  {
    char* key = rl_copy_text(key_start, key_end);
    STR_FUNC_MAP_ITER it;
    if ((it = g_cmd_map.find(key)) != g_cmd_map.end()) // valid key
    {
      if (count > it->second.min_param_cnt_) // over count
      {
        if (count < it->second.max_param_cnt_)           // valid over count
        {
          count = INDEX_COMPLETE;
        }
        else
        {
          count = STOP_COMPLETE;
        }
      }
    }
    else                        // invalid key
    {
      count = STOP_COMPLETE;
    }
    free(key);
    key = NULL;
  }

  return count;
}
开发者ID:alimy,项目名称:tfs,代码行数:73,代码来源:adminservertool.cpp


注:本文中的STR_FUNC_MAP::find方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。