view src/protocols/sametime/meanwhile/mw_debug.c @ 11851:3bfb2cffcef2

[gaim-migrate @ 14142] inspired by Richard Stellingwerff's patch 1339606, this workaround for annoying visible borders on tab close buttons is no longer required with at least gtk 2.6 (if someone can confirm if it was fixed in 2.4 we could remove it there too) committer: Tailor Script <tailor@pidgin.im>
author Stu Tomlinson <stu@nosnilmot.com>
date Thu, 27 Oct 2005 15:15:52 +0000
parents 3ef77720e577
children 0110fc7c6a8a
line wrap: on
line source


/*
  Meanwhile - Unofficial Lotus Sametime Community Client Library
  Copyright (C) 2004  Christopher (siege) O'Brien
  
  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Library General Public
  License as published by the Free Software Foundation; either
  version 2 of the License, or (at your option) any later version.
  
  This library is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  Library General Public License for more details.
  
  You should have received a copy of the GNU Library General Public
  License along with this library; if not, write to the Free
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

#include <glib/gstring.h>

#include "mw_debug.h"


#define FRM               "%02x"
#define FRMT              "%02x%02x "
#define BUF(n)            ((unsigned char) buf[n])
#define ADVANCE(b, n, c)  {b += c; n -= c;}


#ifdef DEBUG
/** writes hex pairs of buf to str */
static void t_pretty_print(GString *str, const char *buf, gsize len) {
  while(len) {
    if(len >= 16) {
      g_string_append_printf(str,
			     FRMT FRMT FRMT FRMT FRMT FRMT FRMT FRMT "\n",
			     BUF(0),  BUF(1),  BUF(2),  BUF(3),
			     BUF(4),  BUF(5),  BUF(6),  BUF(7),
			     BUF(8),  BUF(9),  BUF(10), BUF(11),
			     BUF(12), BUF(13), BUF(14), BUF(15));
      ADVANCE(buf, len, 16);

    } else if(len == 2) {
      g_string_append_printf(str, FRMT "\n", BUF(0), BUF(1));
      ADVANCE(buf, len, 2);
      
    } else if(len > 1) {
      g_string_append_printf(str, FRMT, BUF(0), BUF(1));
      ADVANCE(buf, len, 2);

    } else {
      g_string_append_printf(str, FRM "\n", BUF(0));
      ADVANCE(buf, len, 1);
    }
  }
}
#endif


void pretty_print(const char *buf, gsize len) {
#ifdef DEBUG
  GString *str;

  if(! len) return;

  g_return_if_fail(buf != NULL);

  str = g_string_new(NULL);
  t_pretty_print(str, buf, len);
  g_debug(str->str);
  g_string_free(str, TRUE);
#endif
  ;
}


void pretty_print_opaque(struct mwOpaque *o) {
  if(! o) return;
  pretty_print(o->data, o->len);
}


void mw_debug_mailme_v(struct mwOpaque *block,
		       const char *info, va_list args) {
  /*
    MW_MAILME_MESSAGE
    begin here
    info % args
    pretty_print
    end here
  */

#ifdef DEBUG
  GString *str;
  char *txt;

  str = g_string_new(MW_MAILME_MESSAGE "\n"
		     "  Please send mail to: " MW_MAILME_ADDRESS "\n"
		     MW_MAILME_CUT_START "\n");

  txt = g_strdup_vprintf(info, args);
  g_string_append(str, txt);
  g_free(txt);

  g_string_append(str, "\n");

  if(block) {
    t_pretty_print(str, block->data, block->len);
  }

  g_string_append(str, MW_MAILME_CUT_STOP);

  g_debug(str->str);
  g_string_free(str, TRUE);
#endif
  ;
}


void mw_debug_mailme(struct mwOpaque *block,
		     const char *info, ...) {
  va_list args;
  va_start(args, info);
  mw_debug_mailme_v(block, info, args);
  va_end(args);
}