OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [newlib-1.17.0/] [newlib/] [libc/] [stdio/] [sniprintf.c] - Diff between revs 148 and 158

Only display areas with differences | Details | Blame | View Log

Rev 148 Rev 158
/*
/*
 * Copyright (c) 1990, 2007 The Regents of the University of California.
 * Copyright (c) 1990, 2007 The Regents of the University of California.
 * All rights reserved.
 * All rights reserved.
 *
 *
 * Redistribution and use in source and binary forms are permitted
 * Redistribution and use in source and binary forms are permitted
 * provided that the above copyright notice and this paragraph are
 * provided that the above copyright notice and this paragraph are
 * duplicated in all such forms and that any documentation,
 * duplicated in all such forms and that any documentation,
 * advertising materials, and other materials related to such
 * advertising materials, and other materials related to such
 * distribution and use acknowledge that the software was developed
 * distribution and use acknowledge that the software was developed
 * by the University of California, Berkeley.  The name of the
 * by the University of California, Berkeley.  The name of the
 * University may not be used to endorse or promote products derived
 * University may not be used to endorse or promote products derived
 * from this software without specific prior written permission.
 * from this software without specific prior written permission.
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 */
 */
 
 
/* This code created by modifying snprintf.c so copyright inherited. */
/* This code created by modifying snprintf.c so copyright inherited. */
/* doc in siprintf.c */
/* doc in siprintf.c */
 
 
#include <_ansi.h>
#include <_ansi.h>
#include <reent.h>
#include <reent.h>
#include <stdio.h>
#include <stdio.h>
#ifdef _HAVE_STDC
#ifdef _HAVE_STDC
#include <stdarg.h>
#include <stdarg.h>
#else
#else
#include <varargs.h>
#include <varargs.h>
#endif
#endif
#include <limits.h>
#include <limits.h>
#include <errno.h>
#include <errno.h>
#include "local.h"
#include "local.h"
 
 
int
int
#ifdef _HAVE_STDC
#ifdef _HAVE_STDC
_DEFUN (_sniprintf_r, (ptr, str, size, fmt),
_DEFUN (_sniprintf_r, (ptr, str, size, fmt),
        struct _reent *ptr _AND
        struct _reent *ptr _AND
        char *str _AND
        char *str _AND
        size_t size _AND
        size_t size _AND
        _CONST char *fmt _DOTS)
        _CONST char *fmt _DOTS)
#else
#else
_sniprintf_r (ptr, str, size, fmt, va_alist)
_sniprintf_r (ptr, str, size, fmt, va_alist)
     struct _reent *ptr;
     struct _reent *ptr;
     char *str;
     char *str;
     size_t size;
     size_t size;
     _CONST char *fmt;
     _CONST char *fmt;
     va_dcl
     va_dcl
#endif
#endif
{
{
  int ret;
  int ret;
  va_list ap;
  va_list ap;
  FILE f;
  FILE f;
 
 
  if (size > INT_MAX)
  if (size > INT_MAX)
    {
    {
      ptr->_errno = EOVERFLOW;
      ptr->_errno = EOVERFLOW;
      return EOF;
      return EOF;
    }
    }
  f._flags = __SWR | __SSTR;
  f._flags = __SWR | __SSTR;
  f._bf._base = f._p = (unsigned char *) str;
  f._bf._base = f._p = (unsigned char *) str;
  f._bf._size = f._w = (size > 0 ? size - 1 : 0);
  f._bf._size = f._w = (size > 0 ? size - 1 : 0);
  f._file = -1;  /* No file. */
  f._file = -1;  /* No file. */
#ifdef _HAVE_STDC
#ifdef _HAVE_STDC
  va_start (ap, fmt);
  va_start (ap, fmt);
#else
#else
  va_start (ap);
  va_start (ap);
#endif
#endif
  ret = _svfiprintf_r (ptr, &f, fmt, ap);
  ret = _svfiprintf_r (ptr, &f, fmt, ap);
  va_end (ap);
  va_end (ap);
  if (ret < EOF)
  if (ret < EOF)
    ptr->_errno = EOVERFLOW;
    ptr->_errno = EOVERFLOW;
  if (size > 0)
  if (size > 0)
    *f._p = 0;
    *f._p = 0;
  return (ret);
  return (ret);
}
}
 
 
#ifndef _REENT_ONLY
#ifndef _REENT_ONLY
 
 
int
int
#ifdef _HAVE_STDC
#ifdef _HAVE_STDC
_DEFUN (sniprintf, (str, size, fmt),
_DEFUN (sniprintf, (str, size, fmt),
        char *str _AND
        char *str _AND
        size_t size _AND
        size_t size _AND
        _CONST char *fmt _DOTS)
        _CONST char *fmt _DOTS)
#else
#else
sniprintf (str, size, fmt, va_alist)
sniprintf (str, size, fmt, va_alist)
     char *str;
     char *str;
     size_t size;
     size_t size;
     _CONST char *fmt;
     _CONST char *fmt;
     va_dcl
     va_dcl
#endif
#endif
{
{
  int ret;
  int ret;
  va_list ap;
  va_list ap;
  FILE f;
  FILE f;
  struct _reent *ptr = _REENT;
  struct _reent *ptr = _REENT;
 
 
  if (size > INT_MAX)
  if (size > INT_MAX)
    {
    {
      ptr->_errno = EOVERFLOW;
      ptr->_errno = EOVERFLOW;
      return EOF;
      return EOF;
    }
    }
  f._flags = __SWR | __SSTR;
  f._flags = __SWR | __SSTR;
  f._bf._base = f._p = (unsigned char *) str;
  f._bf._base = f._p = (unsigned char *) str;
  f._bf._size = f._w = (size > 0 ? size - 1 : 0);
  f._bf._size = f._w = (size > 0 ? size - 1 : 0);
  f._file = -1;  /* No file. */
  f._file = -1;  /* No file. */
#ifdef _HAVE_STDC
#ifdef _HAVE_STDC
  va_start (ap, fmt);
  va_start (ap, fmt);
#else
#else
  va_start (ap);
  va_start (ap);
#endif
#endif
  ret = _svfiprintf_r (ptr, &f, fmt, ap);
  ret = _svfiprintf_r (ptr, &f, fmt, ap);
  va_end (ap);
  va_end (ap);
  if (ret < EOF)
  if (ret < EOF)
    ptr->_errno = EOVERFLOW;
    ptr->_errno = EOVERFLOW;
  if (size > 0)
  if (size > 0)
    *f._p = 0;
    *f._p = 0;
  return (ret);
  return (ret);
}
}
 
 
#endif
#endif
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.