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; | |||
|  | } | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 |