Blame argp/argp-fmtstream.h

Packit 6c4009
/* Word-wrapping and line-truncating streams.
Packit 6c4009
   Copyright (C) 1997-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
   Written by Miles Bader <miles@gnu.ai.mit.edu>.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library; if not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
/* This package emulates glibc `line_wrap_stream' semantics for systems that
Packit 6c4009
   don't have that.  If the system does have it, it is just a wrapper for
Packit 6c4009
   that.  This header file is only used internally while compiling argp, and
Packit 6c4009
   shouldn't be installed.  */
Packit 6c4009
Packit 6c4009
#ifndef _ARGP_FMTSTREAM_H
Packit 6c4009
#define _ARGP_FMTSTREAM_H
Packit 6c4009
Packit 6c4009
#include <stdio.h>
Packit 6c4009
#include <string.h>
Packit 6c4009
#include <unistd.h>
Packit 6c4009
Packit 6c4009
#if defined (__GNU_LIBRARY__) && defined (HAVE_LINEWRAP_H)
Packit 6c4009
/* line_wrap_stream is available, so use that.  */
Packit 6c4009
#define ARGP_FMTSTREAM_USE_LINEWRAP
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifdef ARGP_FMTSTREAM_USE_LINEWRAP
Packit 6c4009
/* Just be a simple wrapper for line_wrap_stream; the semantics are
Packit 6c4009
   *slightly* different, as line_wrap_stream doesn't actually make a new
Packit 6c4009
   object, it just modifies the given stream (reversibly) to do
Packit 6c4009
   line-wrapping.  Since we control who uses this code, it doesn't matter.  */
Packit 6c4009
Packit 6c4009
#include <linewrap.h>
Packit 6c4009
Packit 6c4009
typedef FILE *argp_fmtstream_t;
Packit 6c4009
Packit 6c4009
#define argp_make_fmtstream line_wrap_stream
Packit 6c4009
#define __argp_make_fmtstream line_wrap_stream
Packit 6c4009
#define argp_fmtstream_free line_unwrap_stream
Packit 6c4009
#define __argp_fmtstream_free line_unwrap_stream
Packit 6c4009
Packit 6c4009
#define __argp_fmtstream_putc(fs,ch) putc(ch,fs)
Packit 6c4009
#define argp_fmtstream_putc(fs,ch) putc(ch,fs)
Packit 6c4009
#define __argp_fmtstream_puts(fs,str) fputs(str,fs)
Packit 6c4009
#define argp_fmtstream_puts(fs,str) fputs(str,fs)
Packit 6c4009
#define __argp_fmtstream_write(fs,str,len) fwrite(str,1,len,fs)
Packit 6c4009
#define argp_fmtstream_write(fs,str,len) fwrite(str,1,len,fs)
Packit 6c4009
#define __argp_fmtstream_printf fprintf
Packit 6c4009
#define argp_fmtstream_printf fprintf
Packit 6c4009
Packit 6c4009
#define __argp_fmtstream_lmargin line_wrap_lmargin
Packit 6c4009
#define argp_fmtstream_lmargin line_wrap_lmargin
Packit 6c4009
#define __argp_fmtstream_set_lmargin line_wrap_set_lmargin
Packit 6c4009
#define argp_fmtstream_set_lmargin line_wrap_set_lmargin
Packit 6c4009
#define __argp_fmtstream_rmargin line_wrap_rmargin
Packit 6c4009
#define argp_fmtstream_rmargin line_wrap_rmargin
Packit 6c4009
#define __argp_fmtstream_set_rmargin line_wrap_set_rmargin
Packit 6c4009
#define argp_fmtstream_set_rmargin line_wrap_set_rmargin
Packit 6c4009
#define __argp_fmtstream_wmargin line_wrap_wmargin
Packit 6c4009
#define argp_fmtstream_wmargin line_wrap_wmargin
Packit 6c4009
#define __argp_fmtstream_set_wmargin line_wrap_set_wmargin
Packit 6c4009
#define argp_fmtstream_set_wmargin line_wrap_set_wmargin
Packit 6c4009
#define __argp_fmtstream_point line_wrap_point
Packit 6c4009
#define argp_fmtstream_point line_wrap_point
Packit 6c4009
Packit 6c4009
#else /* !ARGP_FMTSTREAM_USE_LINEWRAP */
Packit 6c4009
/* Guess we have to define our own version.  */
Packit 6c4009
Packit 6c4009

Packit 6c4009
struct argp_fmtstream
Packit 6c4009
{
Packit 6c4009
  FILE *stream;			/* The stream we're outputting to.  */
Packit 6c4009
Packit 6c4009
  size_t lmargin, rmargin;	/* Left and right margins.  */
Packit 6c4009
  ssize_t wmargin;		/* Margin to wrap to, or -1 to truncate.  */
Packit 6c4009
Packit 6c4009
  /* Point in buffer to which we've processed for wrapping, but not output.  */
Packit 6c4009
  size_t point_offs;
Packit 6c4009
  /* Output column at POINT_OFFS, or -1 meaning 0 but don't add lmargin.  */
Packit 6c4009
  ssize_t point_col;
Packit 6c4009
Packit 6c4009
  char *buf;			/* Output buffer.  */
Packit 6c4009
  char *p;			/* Current end of text in BUF. */
Packit 6c4009
  char *end;			/* Absolute end of BUF.  */
Packit 6c4009
};
Packit 6c4009
Packit 6c4009
typedef struct argp_fmtstream *argp_fmtstream_t;
Packit 6c4009
Packit 6c4009
__BEGIN_DECLS
Packit 6c4009
Packit 6c4009
/* Return an argp_fmtstream that outputs to STREAM, and which prefixes lines
Packit 6c4009
   written on it with LMARGIN spaces and limits them to RMARGIN columns
Packit 6c4009
   total.  If WMARGIN >= 0, words that extend past RMARGIN are wrapped by
Packit 6c4009
   replacing the whitespace before them with a newline and WMARGIN spaces.
Packit 6c4009
   Otherwise, chars beyond RMARGIN are simply dropped until a newline.
Packit 6c4009
   Returns NULL if there was an error.  */
Packit 6c4009
extern argp_fmtstream_t __argp_make_fmtstream (FILE *__stream,
Packit 6c4009
					       size_t __lmargin,
Packit 6c4009
					       size_t __rmargin,
Packit 6c4009
					       ssize_t __wmargin);
Packit 6c4009
extern argp_fmtstream_t argp_make_fmtstream (FILE *__stream,
Packit 6c4009
					     size_t __lmargin,
Packit 6c4009
					     size_t __rmargin,
Packit 6c4009
					     ssize_t __wmargin);
Packit 6c4009
Packit 6c4009
/* Flush __FS to its stream, and free it (but don't close the stream).  */
Packit 6c4009
extern void __argp_fmtstream_free (argp_fmtstream_t __fs);
Packit 6c4009
extern void argp_fmtstream_free (argp_fmtstream_t __fs);
Packit 6c4009
Packit 6c4009
extern ssize_t __argp_fmtstream_printf (argp_fmtstream_t __fs,
Packit 6c4009
					const char *__fmt, ...)
Packit 6c4009
     __attribute__ ((__format__ (printf, 2, 3)));
Packit 6c4009
extern ssize_t argp_fmtstream_printf (argp_fmtstream_t __fs,
Packit 6c4009
				      const char *__fmt, ...)
Packit 6c4009
     __attribute__ ((__format__ (printf, 2, 3)));
Packit 6c4009
Packit 6c4009
extern int __argp_fmtstream_putc (argp_fmtstream_t __fs, int __ch);
Packit 6c4009
extern int argp_fmtstream_putc (argp_fmtstream_t __fs, int __ch);
Packit 6c4009
Packit 6c4009
extern int __argp_fmtstream_puts (argp_fmtstream_t __fs, const char *__str);
Packit 6c4009
extern int argp_fmtstream_puts (argp_fmtstream_t __fs, const char *__str);
Packit 6c4009
Packit 6c4009
extern size_t __argp_fmtstream_write (argp_fmtstream_t __fs,
Packit 6c4009
				      const char *__str, size_t __len);
Packit 6c4009
extern size_t argp_fmtstream_write (argp_fmtstream_t __fs,
Packit 6c4009
				    const char *__str, size_t __len);
Packit 6c4009

Packit 6c4009
/* Access macros for various bits of state.  */
Packit 6c4009
#define argp_fmtstream_lmargin(__fs) ((__fs)->lmargin)
Packit 6c4009
#define argp_fmtstream_rmargin(__fs) ((__fs)->rmargin)
Packit 6c4009
#define argp_fmtstream_wmargin(__fs) ((__fs)->wmargin)
Packit 6c4009
#define __argp_fmtstream_lmargin argp_fmtstream_lmargin
Packit 6c4009
#define __argp_fmtstream_rmargin argp_fmtstream_rmargin
Packit 6c4009
#define __argp_fmtstream_wmargin argp_fmtstream_wmargin
Packit 6c4009
Packit 6c4009
/* Set __FS's left margin to LMARGIN and return the old value.  */
Packit 6c4009
extern size_t argp_fmtstream_set_lmargin (argp_fmtstream_t __fs,
Packit 6c4009
					  size_t __lmargin);
Packit 6c4009
extern size_t __argp_fmtstream_set_lmargin (argp_fmtstream_t __fs,
Packit 6c4009
					    size_t __lmargin);
Packit 6c4009
Packit 6c4009
/* Set __FS's right margin to __RMARGIN and return the old value.  */
Packit 6c4009
extern size_t argp_fmtstream_set_rmargin (argp_fmtstream_t __fs,
Packit 6c4009
					  size_t __rmargin);
Packit 6c4009
extern size_t __argp_fmtstream_set_rmargin (argp_fmtstream_t __fs,
Packit 6c4009
					    size_t __rmargin);
Packit 6c4009
Packit 6c4009
/* Set __FS's wrap margin to __WMARGIN and return the old value.  */
Packit 6c4009
extern size_t argp_fmtstream_set_wmargin (argp_fmtstream_t __fs,
Packit 6c4009
					  size_t __wmargin);
Packit 6c4009
extern size_t __argp_fmtstream_set_wmargin (argp_fmtstream_t __fs,
Packit 6c4009
					    size_t __wmargin);
Packit 6c4009
Packit 6c4009
/* Return the column number of the current output point in __FS.  */
Packit 6c4009
extern size_t argp_fmtstream_point (argp_fmtstream_t __fs);
Packit 6c4009
extern size_t __argp_fmtstream_point (argp_fmtstream_t __fs);
Packit 6c4009
Packit 6c4009
/* Internal routines.  */
Packit 6c4009
extern void _argp_fmtstream_update (argp_fmtstream_t __fs);
Packit 6c4009
extern void __argp_fmtstream_update (argp_fmtstream_t __fs);
Packit 6c4009
extern int _argp_fmtstream_ensure (argp_fmtstream_t __fs, size_t __amount);
Packit 6c4009
extern int __argp_fmtstream_ensure (argp_fmtstream_t __fs, size_t __amount);
Packit 6c4009

Packit 6c4009
#ifdef __OPTIMIZE__
Packit 6c4009
/* Inline versions of above routines.  */
Packit 6c4009
Packit 6c4009
#if !_LIBC
Packit 6c4009
#define __argp_fmtstream_putc argp_fmtstream_putc
Packit 6c4009
#define __argp_fmtstream_puts argp_fmtstream_puts
Packit 6c4009
#define __argp_fmtstream_write argp_fmtstream_write
Packit 6c4009
#define __argp_fmtstream_set_lmargin argp_fmtstream_set_lmargin
Packit 6c4009
#define __argp_fmtstream_set_rmargin argp_fmtstream_set_rmargin
Packit 6c4009
#define __argp_fmtstream_set_wmargin argp_fmtstream_set_wmargin
Packit 6c4009
#define __argp_fmtstream_point argp_fmtstream_point
Packit 6c4009
#define __argp_fmtstream_update _argp_fmtstream_update
Packit 6c4009
#define __argp_fmtstream_ensure _argp_fmtstream_ensure
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef ARGP_FS_EI
Packit 6c4009
#define ARGP_FS_EI extern inline
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
ARGP_FS_EI size_t
Packit 6c4009
__argp_fmtstream_write (argp_fmtstream_t __fs, const char *__str, size_t __len)
Packit 6c4009
{
Packit 6c4009
  if (__fs->p + __len <= __fs->end || __argp_fmtstream_ensure (__fs, __len))
Packit 6c4009
    {
Packit 6c4009
      memcpy (__fs->p, __str, __len);
Packit 6c4009
      __fs->p += __len;
Packit 6c4009
      return __len;
Packit 6c4009
    }
Packit 6c4009
  else
Packit 6c4009
    return 0;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
ARGP_FS_EI int
Packit 6c4009
__argp_fmtstream_puts (argp_fmtstream_t __fs, const char *__str)
Packit 6c4009
{
Packit 6c4009
  size_t __len = strlen (__str);
Packit 6c4009
  if (__len)
Packit 6c4009
    {
Packit 6c4009
      size_t __wrote = __argp_fmtstream_write (__fs, __str, __len);
Packit 6c4009
      return __wrote == __len ? 0 : -1;
Packit 6c4009
    }
Packit 6c4009
  else
Packit 6c4009
    return 0;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
ARGP_FS_EI int
Packit 6c4009
__argp_fmtstream_putc (argp_fmtstream_t __fs, int __ch)
Packit 6c4009
{
Packit 6c4009
  if (__fs->p < __fs->end || __argp_fmtstream_ensure (__fs, 1))
Packit 6c4009
    return *__fs->p++ = __ch;
Packit 6c4009
  else
Packit 6c4009
    return EOF;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
/* Set __FS's left margin to __LMARGIN and return the old value.  */
Packit 6c4009
ARGP_FS_EI size_t
Packit 6c4009
__argp_fmtstream_set_lmargin (argp_fmtstream_t __fs, size_t __lmargin)
Packit 6c4009
{
Packit 6c4009
  size_t __old;
Packit 6c4009
  if ((size_t) (__fs->p - __fs->buf) > __fs->point_offs)
Packit 6c4009
    __argp_fmtstream_update (__fs);
Packit 6c4009
  __old = __fs->lmargin;
Packit 6c4009
  __fs->lmargin = __lmargin;
Packit 6c4009
  return __old;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
/* Set __FS's right margin to __RMARGIN and return the old value.  */
Packit 6c4009
ARGP_FS_EI size_t
Packit 6c4009
__argp_fmtstream_set_rmargin (argp_fmtstream_t __fs, size_t __rmargin)
Packit 6c4009
{
Packit 6c4009
  size_t __old;
Packit 6c4009
  if ((size_t) (__fs->p - __fs->buf) > __fs->point_offs)
Packit 6c4009
    __argp_fmtstream_update (__fs);
Packit 6c4009
  __old = __fs->rmargin;
Packit 6c4009
  __fs->rmargin = __rmargin;
Packit 6c4009
  return __old;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
/* Set FS's wrap margin to __WMARGIN and return the old value.  */
Packit 6c4009
ARGP_FS_EI size_t
Packit 6c4009
__argp_fmtstream_set_wmargin (argp_fmtstream_t __fs, size_t __wmargin)
Packit 6c4009
{
Packit 6c4009
  size_t __old;
Packit 6c4009
  if ((size_t) (__fs->p - __fs->buf) > __fs->point_offs)
Packit 6c4009
    __argp_fmtstream_update (__fs);
Packit 6c4009
  __old = __fs->wmargin;
Packit 6c4009
  __fs->wmargin = __wmargin;
Packit 6c4009
  return __old;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
/* Return the column number of the current output point in __FS.  */
Packit 6c4009
ARGP_FS_EI size_t
Packit 6c4009
__argp_fmtstream_point (argp_fmtstream_t __fs)
Packit 6c4009
{
Packit 6c4009
  if ((size_t) (__fs->p - __fs->buf) > __fs->point_offs)
Packit 6c4009
    __argp_fmtstream_update (__fs);
Packit 6c4009
  return __fs->point_col >= 0 ? __fs->point_col : 0;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
#if !_LIBC
Packit 6c4009
#undef __argp_fmtstream_putc
Packit 6c4009
#undef __argp_fmtstream_puts
Packit 6c4009
#undef __argp_fmtstream_write
Packit 6c4009
#undef __argp_fmtstream_set_lmargin
Packit 6c4009
#undef __argp_fmtstream_set_rmargin
Packit 6c4009
#undef __argp_fmtstream_set_wmargin
Packit 6c4009
#undef __argp_fmtstream_point
Packit 6c4009
#undef __argp_fmtstream_update
Packit 6c4009
#undef __argp_fmtstream_ensure
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#endif /* __OPTIMIZE__ */
Packit 6c4009
Packit 6c4009
__END_DECLS
Packit 6c4009
Packit 6c4009
#endif /* ARGP_FMTSTREAM_USE_LINEWRAP */
Packit 6c4009
Packit 6c4009
#endif /* argp-fmtstream.h */