diff strops.c @ 0:7ac2a177e25d

add elilo source.
author taiki
date Thu, 14 Feb 2013 01:43:26 +0900
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/strops.c	Thu Feb 14 01:43:26 2013 +0900
@@ -0,0 +1,165 @@
+/*
+ *  Copyright (C) 1999-2003 Hewlett-Packard Co.
+ *	Contributed by Stephane Eranian <eranian@hpl.hp.com>
+ *
+ * This file is part of the ELILO, the EFI Linux boot loader.
+ *
+ *  ELILO is free software; you can redistribute it and/or modify
+ *  it under the terms of the GNU General Public License as published by
+ *  the Free Software Foundation; either version 2, or (at your option)
+ *  any later version.
+ *
+ *  ELILO 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 General Public License
+ *  along with ELILO; see the file COPYING.  If not, write to the Free
+ *  Software Foundation, 59 Temple Place - Suite 330, Boston, MA
+ *  02111-1307, USA.
+ *
+ * Please check out the elilo.txt for complete documentation on how
+ * to use this program.
+ */
+
+#include <efi.h>
+#include <efilib.h>
+
+//#define CHAR_NULL	(CHAR16)'\0'
+
+CHAR16 *
+StrChr(IN const CHAR16 *s, IN const CHAR16 c)
+{
+        for(; *s != c; ++s)  if (*s == CHAR_NULL) return NULL;
+
+        return (CHAR16 *)s;
+}
+
+CHAR16 *
+StrnCpy(OUT CHAR16 *dst, IN const CHAR16 *src, IN UINTN size)
+{
+	CHAR16 *res = dst;
+
+	while (size && size-- && (*dst++ = *src++) != CHAR_NULL);
+	/*
+	 * does the null padding
+	 */
+	while (size && size-- > 0) *dst++ = CHAR_NULL;
+
+	return res;
+}
+
+CHAR8 *
+StrnXCpy(OUT CHAR8 *dst, IN const CHAR16 *src, IN UINTN size)
+{
+	CHAR8 *res = dst;
+
+	while (size && size-- && (*dst++ = (CHAR8)*src++) != '\0');
+	/*
+	 * does the null padding
+	 */
+	while (size && size-- > 0) *dst++ = '\0';
+
+	return res;
+}
+	
+VOID
+U2ascii(CHAR16 *in, CHAR8 *out, UINTN maxlen)
+{
+	while(maxlen-- > 1 && (*out++ = *in++));
+	*out = '\0';
+}
+	
+CHAR8 *
+strncpya(OUT CHAR8 *dst, IN const CHAR8 *src, IN UINTN size)
+{
+	CHAR8 *res = dst;
+
+	while (size && size-- && (*dst++ = *src++) != '\0');
+	/*
+	 * does the null padding
+	 */
+	while (size && size-- > 0) *dst++ = '\0';
+
+	return res;
+}
+
+CHAR8 *
+strcpya(CHAR8 *dst, const CHAR8 *src)
+{
+	CHAR8 *tmp = dst;
+
+    while (*src) {
+        *(dst++) = *(src++);
+    }
+    *dst = 0;
+
+    return tmp;
+
+}
+
+CHAR8 *
+strchra(IN const CHAR8 *s, IN const CHAR8 c)
+{
+        for(; *s != c; ++s)   
+                if (*s == 0) return NULL;
+        return (CHAR8 *)s;
+}
+
+CHAR8 *
+strcata(IN CHAR8 *dst,IN CHAR8 *src)
+{   
+    return strcpya(dst+strlena(dst), src);
+}
+
+CHAR8 *
+strrchra(IN const CHAR8 *s, const INTN c)
+{
+  CHAR8 *found, *p, ch = (CHAR8)c;
+
+  /* Since strchr is fast, we use it rather than the obvious loop.  */
+
+  if (ch == '\0') return strchra(s, '\0');
+
+  found = NULL;
+  while ((p = strchra(s, ch)) != NULL)
+    {
+      found = p;
+      s = p + 1;
+    }
+
+  return (CHAR8 *) found;
+}
+
+CHAR8 *
+strtok_simple(CHAR8 *in, CHAR8 c)
+{
+	static CHAR8 *last;
+	CHAR8 *tmp;
+
+	if (in == NULL) in = last;
+
+	if (in == NULL) return NULL;
+
+	if (*in == c) in++;
+
+	tmp = strchra(in, c);
+	if (tmp) {
+		*tmp = '\0';
+		last = tmp+1;
+	} else {
+		last = NULL;
+	}
+	return in;
+}
+	
+VOID
+ascii2U(CHAR8 *in, CHAR16 *out, UINTN maxlen)
+{
+	while(maxlen-- > 1 && (*out++ = *in++));
+
+	*out = (CHAR16)0;
+}
+
+