fmt.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * $Id: fmt.h 4518 2008-07-28 15:39:28Z henningw $
  3. *
  4. * Copyright (C) 2006 Voice Sistem SRL
  5. *
  6. * This file is part of Kamailio, a free SIP server.
  7. *
  8. * Kamailio is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * Kamailio is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  21. *
  22. *
  23. * History:
  24. * ---------
  25. * 2006-09-08 first version (bogdan)
  26. */
  27. /*!
  28. * \file
  29. * \brief MI :: Format handling
  30. * \ingroup mi
  31. */
  32. #ifndef _MI_FMT_H_
  33. #define _MI_FMT_H_
  34. #include <stdarg.h>
  35. #include <errno.h>
  36. /*! \brief size of the buffer used for printing the FMT */
  37. #define DEFAULT_MI_FMT_BUF_SIZE 2048
  38. extern char *mi_fmt_buf;
  39. extern int mi_fmt_buf_len;
  40. int mi_fmt_init( unsigned int size );
  41. static inline char* mi_print_fmt(char *fmt, va_list ap, int *len)
  42. {
  43. int n;
  44. if (mi_fmt_buf==NULL) {
  45. if (mi_fmt_init(DEFAULT_MI_FMT_BUF_SIZE)!=0) {
  46. LM_ERR("failed to init\n");
  47. return 0;
  48. }
  49. }
  50. n = vsnprintf( mi_fmt_buf, mi_fmt_buf_len, fmt, ap);
  51. if (n<0 || n>=mi_fmt_buf_len) {
  52. LM_ERR("formatting failed with n=%d, %s\n",n,strerror(errno));
  53. return 0;
  54. }
  55. *len = n;
  56. return mi_fmt_buf;
  57. }
  58. #endif