/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
#ident "%Z%%M% %I% %E% SMI" /* SVr4.0 1.7 */
/* LINTLIBRARY */
# include <string.h>
static char _lp_hextable[17] = "0123456789ABCDEF";
#if defined(__STDC__)
char * ltos ( char * s, unsigned long l)
#else
char * ltos (s, l)
char *s;
unsigned long l;
#endif
{
int i = 7;
while (i >= 0)
{
s[i--] = _lp_hextable[l % 16];
l /= 16;
}
s += 8;
return(s);
}
#if defined(__STDC__)
char * htos ( char * s, unsigned short h)
#else
char * htos (s, h)
char *s;
unsigned short h;
#endif
{
int i = 3;
while (i >= 0)
{
s[i--] = _lp_hextable[(long)h % 16];
h = (long) h / 16;
}
s += 4;
return(s);
}
#if defined(__STDC__)
unsigned long stol ( char * s )
#else
unsigned long stol (s)
char *s;
#endif
{
int i = 0;
unsigned long l = 0;
while (i < 8)
{
l <<= 4;
l += strchr(_lp_hextable, s[i++]) - _lp_hextable;
}
return(l);
}
#if defined(__STDC__)
unsigned short stoh ( char * s )
#else
unsigned short stoh (s)
char *s;
#endif
{
int i = 0;
unsigned short h = 0;
while (i < 4)
{
h <<= 4;
h += strchr(_lp_hextable, s[i++]) - _lp_hextable;
}
return(h);
}