345 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			345 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
 | ||
| 
 | ||
| #include "stdlib.h"
 | ||
| #include "mystdlib.h"
 | ||
| #include "mystring.h"
 | ||
| #include "bytearray.h"
 | ||
| #include "board.h"
 | ||
| #include "string.h"
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 从左向右找到字符串s中首次出现字符c的指针,没找到返回0
 | ||
| * 例如 char *s=str_find_char_right("abcdef",'c')
 | ||
| * s="cdef"
 | ||
| *
 | ||
| */
 | ||
| const char *str_find_char_right(const char *s,char c)
 | ||
| {
 | ||
|   while(*s){
 | ||
|     if(*s==c) return s;
 | ||
|     s++;
 | ||
|   }
 | ||
|   return 0;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 从左向右找到字符串s中首次出现字符c的指针,没找到返回0,
 | ||
| * 指针p是向右检索的终点
 | ||
| * 例如 char *s=str_find_char_right("abcdef",'c')
 | ||
| * s="cdef"
 | ||
| *
 | ||
| */
 | ||
| const char *str_find_char_right_p(const char *s, const char *const p, char c)
 | ||
| {
 | ||
|   while (*s++)
 | ||
|   {
 | ||
|     if (*s == c) return s;
 | ||
|     if (s >= p) break;
 | ||
|   }
 | ||
|   return 0;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 从右向左找到字符串s中首次出现字符c的指针,没找到返回0
 | ||
| * 指针p是向左检索的终点,s检索开始
 | ||
| * char *t="abcdef";
 | ||
| * char *s;
 | ||
| * s=str_find_char_left(t,t+4,'b');
 | ||
| * s="bcdef"
 | ||
| *
 | ||
| */
 | ||
| const char *str_find_char_left(const char *const p,const char *s,char c)
 | ||
| {
 | ||
|   while(*s--)
 | ||
|   {
 | ||
|     if(*s==c) return s;
 | ||
|     if(s<=p) break;
 | ||
|   }
 | ||
|   return 0;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 计算字符串 s 的长度
 | ||
| *
 | ||
| */
 | ||
| int str_len(const char *s)
 | ||
| {
 | ||
|   int len=0;
 | ||
|   while(*s++) len++;
 | ||
|   return len;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 把 s2 中的内容复制到 s1 中,长度为 n
 | ||
| *
 | ||
| */
 | ||
| void str_memcpy(char *s1,const char *s2,int n)
 | ||
| {
 | ||
|   while(n--)
 | ||
|     *s1++=*s2++;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 把 s2 中第一个 c 字符前的字符复制到 s1 中,如果没找到则全部复制,返回复制的字符个数
 | ||
| *
 | ||
| */
 | ||
| int str_cpystr(char *s1,const char *s2,char c)
 | ||
| {
 | ||
|   int len;
 | ||
|   const char *str=str_find_char_right((char *)s2,c);
 | ||
|   if(str==0) len=str_len(s2);
 | ||
|   else len=str-s2;
 | ||
|   str_memcpy(s1,s2,len);
 | ||
|   s1[len]=0;
 | ||
|   return len;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 把整数字符串传化为int,直到遇到非数字字符
 | ||
| *
 | ||
| */
 | ||
| static int str_ainttoi(const char *s)
 | ||
| {
 | ||
|   int ret=0;
 | ||
|   int sig=1;
 | ||
|   if(*s=='-'){
 | ||
|     s++;
 | ||
|     sig=-1;
 | ||
|   }
 | ||
|   while(*s)
 | ||
|   {
 | ||
|     if(*s>='0'&&*s<='9')
 | ||
|     {
 | ||
|       ret*=10;
 | ||
|       ret+=*s-'0';
 | ||
|     }
 | ||
|     else return ret;
 | ||
|     s++;
 | ||
|   }
 | ||
|   return ret*sig;
 | ||
| }
 | ||
| int str_ahextoi(const char *s)
 | ||
| {
 | ||
|   int ret=0;
 | ||
|   while(*s)
 | ||
|   {
 | ||
|     if(*s>='0'&&*s<='9')
 | ||
|     {
 | ||
|       ret*=16;
 | ||
|       ret+=*s-'0';
 | ||
|     }
 | ||
|     else if(*s>='a'&&*s<='f')
 | ||
|     {
 | ||
|       ret*=16;
 | ||
|       ret+=*s-'a'+10;
 | ||
|     }
 | ||
|     else if(*s>='A'&&*s<='F')
 | ||
|     {
 | ||
|       ret*=16;
 | ||
|       ret+=*s-'A'+10;
 | ||
|     }
 | ||
|     else return ret;
 | ||
|     s++;
 | ||
|   }
 | ||
|   return ret;
 | ||
| }
 | ||
| int str_atoi(const char *s)
 | ||
| {
 | ||
|   if(s[0]=='0'&&((s[1]=='x')||(s[1]=='X'))){
 | ||
|     return str_ahextoi(&s[2]);
 | ||
|   }else{
 | ||
|     return str_ainttoi(s);
 | ||
|   }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 把字符串以字符c分割为列表
 | ||
| *
 | ||
| */
 | ||
| list_def *str_split(const char *s,char c)
 | ||
| {
 | ||
|   int len=str_len(s)+1;
 | ||
|   char *t=malloc(len);
 | ||
|   char *ptr1,*ptr2;
 | ||
|   list_def *l=list_creat_str();
 | ||
|   str_memcpy(t,s,len);
 | ||
|   ptr1=t;
 | ||
|   ptr2=t;
 | ||
|   while(*ptr1)
 | ||
|   {
 | ||
|     if(*ptr1==c){
 | ||
|       *ptr1=0;
 | ||
|       list_append_str(l,ptr2);
 | ||
|       ptr2=ptr1+1;
 | ||
|     }
 | ||
|     ptr1++;
 | ||
|   }
 | ||
|   list_append_str(l,ptr2);
 | ||
|   free(t);
 | ||
|   return list_temp(l);
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 把字符串转化为数字列表,每个数字之间分隔符是c
 | ||
| *
 | ||
| */
 | ||
| list_def *str_atod_list(const char *s, char c)
 | ||
| {
 | ||
|   list_def *sl=str_split(s,c);
 | ||
|   list_def *dl=list_creat_int();
 | ||
|   for(int i=0;i<list_length(sl);i++)
 | ||
|   {
 | ||
|     int n;
 | ||
|     char *d=list_get_str(sl,i);
 | ||
|     n=str_atoi(d);
 | ||
|     list_append_int(dl,n);
 | ||
|   }
 | ||
|   return tappend(dl,0);
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 判断字符是否是空白字符,是返回1,不是返回0
 | ||
| *
 | ||
| */
 | ||
| static inline int str_is_empty_char(char c)
 | ||
| {
 | ||
|   const char table[]="\t\n\v\f\r ";
 | ||
|   if(str_find_char_right(table,c)!=0)
 | ||
|     return 1;
 | ||
|   else
 | ||
|     return 0;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 判断字符串是否是可打印,是返回1,不是返回0
 | ||
| *
 | ||
| */
 | ||
| int str_is_print_str(const char *str,int len)
 | ||
| {
 | ||
|   for(int i=0;i<len;i++)
 | ||
|   {
 | ||
|     // 既不是空白字符也不是可打印字符
 | ||
|     if(!(str_is_empty_char(str[i])||(str[i]>=' '&&str[i]<='~')))
 | ||
|       return 0;
 | ||
|   }
 | ||
|   return 1;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 去除字符串中多余的空白字符 '\t', '\n', '\v', '\f', '\r', and ' ',返回临时指针
 | ||
| *
 | ||
| */
 | ||
| char *str_simplified(const char *str)
 | ||
| {
 | ||
|   int is_empty=0;
 | ||
|   array_def *arr=arr_creat();
 | ||
|   param_check(arr);
 | ||
|   while(str_is_empty_char(*str)){
 | ||
|     str++;
 | ||
|   }
 | ||
|   while(*str){
 | ||
|     if(str_is_empty_char(*str)==0){
 | ||
|       if(is_empty==1){
 | ||
|         arr_append(arr,' ');
 | ||
|         is_empty=0;
 | ||
|       }
 | ||
|       arr_append(arr,*str);
 | ||
|     }else{
 | ||
|       is_empty=1;
 | ||
|     }
 | ||
|     str++;
 | ||
|   }
 | ||
|   char *ret=tmalloc(arr_length(arr)+1);
 | ||
|   param_check(ret);
 | ||
|   memcpy(ret,arr_data(arr),arr_length(arr));
 | ||
|   ret[arr_length(arr)]=0;
 | ||
|   arr_delete(arr);
 | ||
|   return ret;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 给字符串指针设置值
 | ||
| *
 | ||
| */
 | ||
| void _str_set(char **p,const char *str)
 | ||
| {
 | ||
|   param_check(p);
 | ||
|   int len=0;
 | ||
|   if(str)
 | ||
|     len=str_len(str);
 | ||
|   else
 | ||
|     len=0;
 | ||
|   if(*p!=0)
 | ||
|   {
 | ||
|     free(*p);
 | ||
|   }
 | ||
|   *p=malloc(len+1);
 | ||
|   str_cpystr(*p,str,len);
 | ||
|   (*p)[len]=0;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /*
 | ||
| *
 | ||
| * 创建一个字符串副本
 | ||
| *
 | ||
| */
 | ||
| char *str_duplicate(char *p)
 | ||
| {
 | ||
|   int len=str_len(p);
 | ||
|   char *s=malloc(len+1);
 | ||
|   param_check(s);
 | ||
|   str_cpystr(s,p,len+1);
 | ||
|   return s;
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | 
