Fri, 27 Feb 2004 19:25:27 +0000
[gaim-migrate @ 9078]
" An update to com_err on debian appears to have broken
the ability of the zephyr plugin to compile with krb4.
Here's a patch, tested against comerr-dev
2.1-1.34+1.35-WIP-2004.01.31-1 in debian, and an older
version of com_err local to MIT, that fixes this. I
haven't tested this against non-kerberized zephyr, or
against other versions of com_err. A lot of the comerr
(error table) related code appears to be unnecessary.
This also fixes two other issues:
1) Upon each login, every entry in the "Anyone" group
was getting added to the Buddies group. I didn't notice
this earlier, since I usually don't restart gaim very
often.
2) No more compile warnings.
This also replaces occurrences of ZGetSender and
ZGetRealm with gaim_zephyr_get_sender and
gaim_zephyr_get_realm(),
in preparation for getting gaim to alternately use an
external program, "tzc" to talk to zephyr."
--Arun A Tharuvai, aka, the lone gaim zepher user
committer: Luke Schierer <lschiere@pidgin.im>
| 2086 | 1 | /* |
| 2 | * Copyright 1987 by MIT Student Information Processing Board | |
| 3 | * | |
| 4 | * For copyright info, see mit-sipb-copyright.h. | |
| 5 | */ | |
| 6 | ||
| 7 | #include <sysdep.h> | |
| 8354 | 8 | /* #include "error_table.h" */ |
| 2086 | 9 | #include "mit-sipb-copyright.h" |
| 10 | ||
| 8354 | 11 | |
| 12 | #define ERRCODE_RANGE 8 /* # of bits to shift table number */ | |
| 13 | #define BITS_PER_CHAR 6 /* # bits to shift per character in name */ | |
| 14 | ||
| 15 | ||
| 2086 | 16 | #ifndef lint |
| 17 | static const char copyright[] = | |
| 18 | "Copyright 1987,1988 by Student Information Processing Board, Massachusetts Institute of Technology"; | |
| 19 | static const char rcsid_et_name_c[] = | |
| 20 | "$Header$"; | |
| 21 | #endif | |
| 22 | ||
| 23 | static const char char_set[] = | |
| 24 | "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_"; | |
| 25 | ||
| 26 | const char * error_table_name_r(num, buf) | |
| 27 | int num; | |
| 28 | char *buf; | |
| 29 | { | |
| 30 | int ch; | |
| 31 | int i; | |
| 32 | char *p; | |
| 33 | ||
| 34 | /* num = aa aaa abb bbb bcc ccc cdd ddd d?? ??? ??? */ | |
| 35 | p = buf; | |
| 36 | num >>= ERRCODE_RANGE; | |
| 37 | /* num = ?? ??? ??? aaa aaa bbb bbb ccc ccc ddd ddd */ | |
| 38 | num &= 077777777; | |
| 39 | /* num = 00 000 000 aaa aaa bbb bbb ccc ccc ddd ddd */ | |
| 40 | for (i = 4; i >= 0; i--) { | |
| 41 | ch = (num >> BITS_PER_CHAR * i) & ((1 << BITS_PER_CHAR) - 1); | |
| 42 | if (ch != 0) | |
| 43 | *p++ = char_set[ch-1]; | |
| 44 | } | |
| 45 | *p = '\0'; | |
| 46 | return(buf); | |
| 47 | } | |
| 48 | ||
| 49 | const char * error_table_name(num) | |
| 50 | int num; | |
| 51 | { | |
| 52 | static char buf[6]; | |
| 53 | ||
| 54 | return(error_table_name_r(num, buf)); | |
| 55 | } | |
| 56 |