简单命令行框架

简单命令行框架

概述

实现一个简单的命令行功能 输入命令 然后分解命令 分解的命令填写到order_sorder_s作为近似全局变量 讲命令和命令对应的参数传到对应的处理函数。

注意

具体的资源申请包括文件fd socket_fd 等其他系统资源,都需要在每个任务中申请 且释放,要保证不能影响到其他命令处理的执行

demo


/****************************************
*author cat_with_apple/LoveM            *
*time 2016/8/9                          *
*version version1                       *
*                                       *
****************************************/



#include <stdio.h>
#include <string.h>

typedef enum order_table_enum{TFTP_PUT=0,TFTP_GET,TFTP_LIST,TFTP_HELP,TFTP_QUIT,WRONG}order_table_enum_t;// number table
char *order_table_string[]={"put","get","list","help","quit",NULL};

typedef struct order_s {
  char buff[1024];//整个命令
  int table[10];//每个参数的下标号码
  enum order_table_enum order_n;//命令编号
}ORDER_S;


order_table_enum_t get_order(ORDER_S*order_s);


void process(ORDER_S*order_s);
void put_process(const ORDER_S*order_s);
void get_process(const ORDER_S*order_s);
void list_process(const ORDER_S*order_s);
void help_process(void);
void quit_process(const ORDER_S*order_s);
void wrong_processs(const ORDER_S*order_s);


int main(int argc, const char *argv[])
{

  ORDER_S order_s;
  while(1)
  {
    get_order(&order_s);
    process(&order_s);
  }

  return 0;
}


//填充填充order_s结构体
order_table_enum_t get_order(ORDER_S*order_s)
{
  char *p1,*p2;

  printf("<zhaohe>#:");
  fgets(order_s->buff,sizeof(order_s->buff),stdin);
  order_s->buff[strlen(order_s->buff)-1]='\0';

  //strtok 分解字符串  填写order_s->table[]
  int i=1;
  p1=strtok(order_s->buff," ");
  order_s->table[0]=0;
  while( (p2=strtok(NULL," ")) != NULL)
  {
    order_s->table[i]=p2-p1;
    i++;
  }

  //填写结构体的order_s->order_n
  for (int j = 0; order_table_string[j]!=NULL; ++j)
  {
    if (strcmp(order_table_string[j],&order_s->buff[0])==0)
    {
      order_s->order_n=(order_table_enum_t)j; //填写对应的指令编号
      break;
    }
    else if(order_table_string[j+1]==NULL)
    {
      order_s->order_n=(order_table_enum_t)(j+1);//如果所有命令都不匹配填写WRONG
    }
  }

  // printf("调试信息:命令是%s%lu\n", order_s->buff,sizeof(order_s->buff));
  return order_s->order_n;
}

void process(ORDER_S*order_s)
{
  switch(order_s->order_n)
  {
    case TFTP_PUT:  put_process(order_s); break;
    case TFTP_GET:  get_process(order_s);break;
    case TFTP_LIST: list_process(order_s); break;
    case TFTP_HELP: help_process(); break;
    case TFTP_QUIT: quit_process(order_s);break;
    case WRONG: wrong_processs(order_s); break;
    default:printf("switch wrong :遇到未知值\n"); break;
  }
}


void put_process(const ORDER_S*order_s)
{
  printf("put_process........\n");
  return;
}

void get_process(const ORDER_S*order_s)
{
  printf("get_process........\n");
  return;
}


void list_process(const ORDER_S*order_s)
{
  printf("list_process........\n");
  return;
}


void quit_process(const ORDER_S*order_s)
{
  printf("quit_process.......\n");
  return;
}

void help_process(void)
{
  printf("****************************************\n");
  printf("*put <file name>                       *\n");
  printf("*get <file name>                       *\n");
  printf("*list <dir name>                       *\n");
  printf("*quit                                  *\n");
  printf("****************************************\n");
  return;
}

void wrong_processs(const ORDER_S*order_s)
{
  printf("wrong_process.......\n");
  return;
}


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,729评论 25 709
  • 大纲 一.Socket简介 二.BSD Socket编程准备 1.地址 2.端口 3.网络字节序 4.半相关与全相...
    y角阅读 7,368评论 2 11
  • 突然,一个小蜗牛出现了,它开口说:你好,我是小灵萌,除了我,还有很多小灵萌,它们会在不同的地方或时机出现...
    小可猪阅读 1,427评论 2 3
  • 前言 最近项目要对一个具有上下刷新列表页做缓存方案,和安卓,后台一起讨论了差不多一个上午,也没得出一个有效可行的方...
    ccc小yyy阅读 5,359评论 8 9
  • 今天早上我突然对自己有了一个觉察 我从来都没有“爱”过,无论对谁,当然也包括自己。 昨天下午接娃,两个同学先后说我...
    lanfang阅读 2,372评论 0 2

友情链接更多精彩内容