This is Webservice SDK for mbed. LPCXpresso1769/LPC1768/FRDM-K64F/LPC4088

Fork of libMiMic by Ryo Iizuka

Revision:
12:efe841863fc8
Parent:
11:c82a7b2899b0
Child:
13:a71705c5e6fd
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/core/NyLPC_stdlib.c	Sat Apr 20 05:03:57 2013 +0000
@@ -0,0 +1,197 @@
+/*********************************************************************************
+ * 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;
+}
+
+
+
+
+/** ----------
+ * Standard functions
+ ---------- */
+
+
+
+
+/**
+ * same as itoa
+ */
+void NyLPC_itoa(int i_n,char* o_out,int i_digit)
+{
+     int i, sign;
+     if ((sign = i_n) < 0){
+         i_n = -i_n;
+     }
+     i = 0;
+     do{
+         o_out[i++] = i_n % 10 + '0';
+     }while ((i_n /= 10) > 0);
+     if (sign < 0){
+         o_out[i++] = '-';
+     }
+     o_out[i] = '\0';
+     NyLPC_reverse(o_out);
+}
+
+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 (;NyLPC_tolower(*s1) == NyLPC_tolower(*s2) && *s1 != '\0';s1++, s2++);
+  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--)
+    {
+        c=(int)((unsigned char)NyLPC_tolower(*i_s1)) - (int)((unsigned char)NyLPC_tolower(*i_s2));
+        if(c!=0){
+            return c;
+        }
+        i_s1++;
+        i_s2++;
+    }
+    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;
+}
+
+
+
+
+