view src/protocols/zephyr/error_message.c @ 12111:b528f37d8e95

[gaim-migrate @ 14411] sf patch #1357831, from Sadrul Habib Chowdhury Looks like this was my bug (me being KingAnt). Sorry! The description from Sadrul: This is a simple fix for the following "ShowStopperBug" (from the kwiki): ========== buddy shows as online when offline * I(luke) played with this some today. when my lschiere SILC account signs on, lschiere(aim) appears on my LSchiere2 buddy list as though signing on. As far as the gaim UI is concerned, there is no SILC buddy in that contact. as LSchiere (aim) is my account, I am quite sure that it is not online, plus attempting to IM it yeilds the same result. ========== committer: Tailor Script <tailor@pidgin.im>
author Mark Doliner <mark@kingant.net>
date Wed, 16 Nov 2005 06:07:42 +0000
parents 64895571248f
children
line wrap: on
line source

/*
 * Copyright 1987 by the Student Information Processing Board
 * of the Massachusetts Institute of Technology
 *
 * For copyright info, see "mit-sipb-copyright.h".
 */

#include "error_table.h"
#include "com_err.h"
#include <sysdep.h>

char *error_table_name_r __P((int, char *));

struct et_list * _et_list = (struct et_list *) NULL;

const char * error_message (code)
long	code;
{
    static char buf[COM_ERR_BUF_LEN];

    return(error_message_r(code, buf));
}

const char * error_message_r (code, buf)
long	code;
char	*buf;
{
    int offset;
    struct et_list *et;
    int table_num;
    int started = 0;
    char *cp, namebuf[6];

    offset = code & ((1<<ERRCODE_RANGE)-1);
    table_num = code - offset;
    if (!table_num)
	return strerror(offset);
    for (et = _et_list; et; et = et->next) {
	if (et->table->base == table_num) {
	    /* This is the right table */
	    if (et->table->n_msgs <= offset)
		break;
	    return(et->table->msgs[offset]);
	}
    }

    strcpy (buf, "Unknown code ");
    if (table_num) {
	strcat (buf, error_table_name_r (table_num, namebuf));
	strcat (buf, " ");
    }
    for (cp = buf; *cp; cp++)
	;
    if (offset >= 100) {
	*cp++ = '0' + offset / 100;
	offset %= 100;
	started++;
    }
    if (started || offset >= 10) {
	*cp++ = '0' + offset / 10;
	offset %= 10;
    }
    *cp++ = '0' + offset;
    *cp = '\0';
    return(buf);
}