vfprintf.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. * Copyright (c) 1995
  3. * The Regents of the University of California. All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that: (1) source code distributions
  7. * retain the above copyright notice and this paragraph in its entirety, (2)
  8. * distributions including binary code include the above copyright notice and
  9. * this paragraph in its entirety in the documentation or other materials
  10. * provided with the distribution, and (3) all advertising materials mentioning
  11. * features or use of this software display the following acknowledgement:
  12. * ``This product includes software developed by the University of California,
  13. * Lawrence Berkeley Laboratory and its contributors.'' Neither the name of
  14. * the University nor the names of its contributors may be used to endorse
  15. * or promote products derived from this software without specific prior
  16. * written permission.
  17. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
  18. * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
  19. * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  20. */
  21. #ifdef HAVE_CONFIG_H
  22. #include "config.h"
  23. #endif
  24. #include <sys/types.h>
  25. #include <stdio.h>
  26. #include <stdarg.h>
  27. #include <stdlib.h>
  28. #include <unistd.h>
  29. #include "netdissect.h"
  30. /*
  31. * Stock 4.3 doesn't have vfprintf.
  32. * This routine is due to Chris Torek.
  33. */
  34. vfprintf(f, fmt, args)
  35. FILE *f;
  36. char *fmt;
  37. va_list args;
  38. {
  39. int ret;
  40. if ((f->_flag & _IOWRT) == 0) {
  41. if (f->_flag & _IORW)
  42. f->_flag |= _IOWRT;
  43. else
  44. return EOF;
  45. }
  46. ret = _doprnt(fmt, args, f);
  47. return ferror(f) ? EOF : ret;
  48. }