os161-1.99
 All Data Structures
atoi.c
00001 /*
00002  * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009
00003  *      The President and Fellows of Harvard College.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. Neither the name of the University nor the names of its contributors
00014  *    may be used to endorse or promote products derived from this software
00015  *    without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND
00018  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED.  IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE
00021  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00022  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
00023  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
00024  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00025  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
00026  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00027  * SUCH DAMAGE.
00028  */
00029 
00030 /*
00031  * This file is shared between libc and the kernel, so don't put anything
00032  * in here that won't work in both contexts.
00033  */
00034 
00035 #ifdef _KERNEL
00036 #include <types.h>
00037 #include <lib.h>
00038 #else
00039 #include <stdlib.h>
00040 #include <string.h>
00041 #endif
00042 
00043 /*
00044  * Standard C function: parse a string that represents a decimal integer.
00045  * Leading whitespace is allowed. Trailing gunk is allowed too. Doesn't
00046  * really report syntax errors or overflow in any useful way.
00047  */
00048 
00049 int
00050 atoi(const char *s)
00051 {
00052         static const char digits[] = "0123456789";  /* legal digits in order */
00053         unsigned val=0;         /* value we're accumulating */
00054         int neg=0;              /* set to true if we see a minus sign */
00055 
00056         /* skip whitespace */
00057         while (*s==' ' || *s=='\t') {
00058                 s++;
00059         }
00060 
00061         /* check for sign */
00062         if (*s=='-') {
00063                 neg=1;
00064                 s++;
00065         }
00066         else if (*s=='+') {
00067                 s++;
00068         }
00069 
00070         /* process each digit */
00071         while (*s) {
00072                 const char *where;
00073                 unsigned digit;
00074                 
00075                 /* look for the digit in the list of digits */
00076                 where = strchr(digits, *s);
00077                 if (where==NULL) {
00078                         /* not found; not a digit, so stop */
00079                         break;
00080                 }
00081 
00082                 /* get the index into the digit list, which is the value */
00083                 digit = (where - digits);
00084 
00085                 /* could (should?) check for overflow here */
00086 
00087                 /* shift the number over and add in the new digit */
00088                 val = val*10 + digit;
00089 
00090                 /* look at the next character */
00091                 s++;
00092         }
00093         
00094         /* handle negative numbers */
00095         if (neg) {
00096                 return -val;
00097         }
00098         
00099         /* done */
00100         return val;
00101 }
 All Data Structures