This is Webservice SDK for mbed. LPCXpresso1769/LPC1768/FRDM-K64F/LPC4088
Fork of libMiMic by
core/NyLPC_stdlib.c
- Committer:
- nyatla
- Date:
- 2013-08-07
- Revision:
- 48:00d211aac2ec
- Parent:
- 13:a71705c5e6fd
- Child:
- 49:d4334acc3ec3
File content as of revision 48:00d211aac2ec:
/********************************************************************************* * PROJECT: MiMic * -------------------------------------------------------------------------------- * * This file is part of MiMic * Copyright (C)2011 Ryo Iizuka * * MiMic is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published * by the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * For further information please contact. * http://nyatla.jp/ * <airmail(at)ebony.plala.or.jp> or <nyatla(at)nyatla.jp> * *********************************************************************************/ #include "NyLPC_stdlib.h" NyLPC_TUInt32 NyLPC_TUInt32_bswap(NyLPC_TUInt32 n) { return( ((((NyLPC_TUInt32)(n))<<24)&0xff000000)| ((((NyLPC_TUInt32)(n))<< 8)&0x00ff0000)| ((((NyLPC_TUInt32)(n))>> 8)&0x0000ff00)| ((((NyLPC_TUInt32)(n))>>24)&0x000000ff)); } NyLPC_TUInt16 NyLPC_TUInt16_bswap(NyLPC_TUInt16 n) { return NyLPC_TUInt16_BSWAP(n); } static int _line_log_l; static const char* _line_log_m; unsigned int NyLPC_assert_counter=0; unsigned int NyLPC_abort_counter=0; unsigned int NyLPC_debug_counter=0; void NyLPC_assertHook(const char* m,int l) { _line_log_l=l; _line_log_m=m; NyLPC_assert_counter++; return; } void NyLPC_abortHook(const char* m,int l) { _line_log_l=l; _line_log_m=m; NyLPC_abort_counter++; } void NyLPC_debugHook(const char* m,int l) { _line_log_l=l; _line_log_m=m; NyLPC_debug_counter++; return; } NyLPC_TBool NyLPC_TCharArrayPtr_seek(struct NyLPC_TCharArrayPtr* i_struct,NyLPC_TUInt16 i_seek) { if(i_struct->len<i_seek){ return NyLPC_TBool_FALSE; } i_struct->ptr+=i_seek; i_struct->len-=i_seek; return NyLPC_TBool_TRUE; } NyLPC_TBool NyLPC_TUInt32ArrayPtr_seek(struct NyLPC_TUInt32ArrayPtr* i_struct,NyLPC_TUInt16 i_seek) { if(i_struct->len<i_seek){ return NyLPC_TBool_FALSE; } i_struct->ptr+=i_seek; i_struct->len-=i_seek; return NyLPC_TBool_TRUE; } void NyLPC_TUInt32ArrayPtr_setBuf(struct NyLPC_TUInt32ArrayPtr* i_struct,NyLPC_TUInt32* i_ptr,NyLPC_TUInt16 i_len) { i_struct->ptr=i_ptr; i_struct->len=i_len; } /** ---------- * NyLPC_TTextIdTbl ---------- */ /** * IDテーブル */ NyLPC_TUInt8 NyLPC_TTextIdTbl_getMatchId(const NyLPC_TChar* i_str,const struct NyLPC_TTextIdTbl i_tbl[]) { int i; for(i=0;i_tbl[i].n!=NULL;i++){ if(strcmp(i_str,i_tbl[i].n)==0){ break; } } return i_tbl[i].id; } NyLPC_TUInt8 NyLPC_TTextIdTbl_getMatchIdIgnoreCase(const NyLPC_TChar* i_str,const struct NyLPC_TTextIdTbl i_tbl[]) { int i; for(i=0;i_tbl[i].n!=NULL;i++){ if(NyLPC_stricmp(i_str,i_tbl[i].n)==0){ break; } } return i_tbl[i].id; } const NyLPC_TChar* NyLPC_TTextIdTbl_getTextById(NyLPC_TUInt8 i_id,const struct NyLPC_TTextIdTbl i_tbl[]) { int i; for(i=0;i_tbl[i].n!=NULL;i++){ if(i_id==i_tbl[i].id){ return i_tbl[i].n; } } return NULL; } /** ---------- * Standard functions ---------- */ NyLPC_TInt16 NyLPC_itoa(int i_n,char* o_out,int i_base) { int i, sign,v; if ((sign = i_n) < 0){ i_n = -i_n; } i = 0; do{ v=i_n % i_base; o_out[i++] = v<10?(v+'0'):(v+'a'-10); }while ((i_n /= i_base) > 0); if (sign < 0){ o_out[i++] = '-'; } o_out[i] = '\0'; NyLPC_reverse(o_out); return i; } NyLPC_TInt16 NyLPC_uitoa(unsigned int i_n,char* o_out,int i_base) { int i = 0; int v; do{ v=i_n % i_base; o_out[i++] = v<10?(v+'0'):(v+'a'-10); }while ((i_n /= i_base) > 0); o_out[i] = '\0'; NyLPC_reverse(o_out); return i; } /** * 桁数の指定できるuitoaです。 */ NyLPC_TInt16 NyLPC_uitoa2(unsigned int i_n,char* o_out,int i_base,int i_digit) { NyLPC_TInt16 i = 0; NyLPC_TInt16 v; do{ v=i_n % i_base; o_out[i++] = v<10?(v+'0'):(v+'a'-10); }while ((i_n /= i_base) > 0); while(i<i_digit){ o_out[i++] = '0'; } o_out[i] = '\0'; NyLPC_reverse(o_out); return i; } void NyLPC_reverse(char* s) { char *j; char c; j = s + strlen(s) - 1; while(s < j){ c = *s; *s++ = *j; *j-- = c; } } int NyLPC_stricmp(const char *i_s1, const char *i_s2) { const char* s1 =i_s1; const char* s2 =i_s2; for (;*s1 != '\0';s1++, s2++) { if(*s1!=*s2){ if(NyLPC_tolower(*s1) != NyLPC_tolower(*s2)){ break; } } } return (int)((unsigned char)*s1) - (int)((unsigned char)(*s2)); } int NyLPC_strnicmp(const char *i_s1, const char *i_s2,int n) { char c; int n2=n; for(;n2>0;n2--,i_s1++,i_s2++) { if(*i_s1!=*i_s2){ c=(int)((unsigned char)NyLPC_tolower(*i_s1)) - (int)((unsigned char)NyLPC_tolower(*i_s2)); if(c!=0){ return c; } } } return 0; } int NyLPC_ctoi(char i) { if('0'<=i && i<='9') return (i-'0'); return 0; } int NyLPC_ctox(char i) { if('0'<=i && i<='9') return (i-'0'); if('a'<=i && i<='f') return (i-'a'+10); if('A'<=i && i<='F') return (i-'A'+10); return 0; }