Mercurial > pidgin.yaz
changeset 8972:f09801513729
[gaim-migrate @ 9746]
Evan S. of adium submitted a patch to make oscar.c think SMS numbers
are valid screen names, and I XPed the crap out of aim_snvalid
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Wed, 19 May 2004 03:48:15 +0000 |
parents | f831a38eb6ba |
children | 269f576d61ac |
files | src/protocols/oscar/util.c |
diffstat | 1 files changed, 66 insertions(+), 20 deletions(-) [+] |
line wrap: on
line diff
--- a/src/protocols/oscar/util.c Wed May 19 03:26:52 2004 +0000 +++ b/src/protocols/oscar/util.c Wed May 19 03:48:15 2004 +0000 @@ -158,34 +158,80 @@ } /** - * Check if the given screen name is a valid AIM or ICQ screen name. + * Check if the given screen name is a valid AIM screen name. + * Example: BobDole + * + * @return 1 if the screen name is valid, 0 if not. + */ +static int aim_snvalid_aim(const char *sn) +{ + int i; + + for (i = 0; sn[i] != '\0'; i++) { + if (!isalnum(sn[i]) && (sn[i] != ' ') && (sn[i] != '@') && (sn[i] != '.') && (sn[i] != '_')) + return 0; + } + + return 1; +} + +/** + * Check if the given screen name is a valid ICQ screen name. + * Example: 1234567 + * + * @return 1 if the screen name is valid, 0 if not. + */ +static int aim_snvalid_icq(const char *sn) +{ + int i; + + for (i = 0; sn[i] != '\0'; i++) { + if (!isdigit(sn[i])) + return 0; + } + + return 1; +} + +/** + * Check if the given screen name is a valid SMS screen name. + * Example: +19195551234 + * + * @return 1 if the screen name is valid, 0 if not. + */ +static int aim_snvalid_sms(const char *sn) +{ + int i; + + if (sn[0] != '+') + return 0; + + for (i = 1; sn[i] != '\0'; i++) { + if (!isdigit(sn[i])) + return 0; + } + + return 1; +} + +/** + * Check if the given screen name is a valid oscar screen name. * * @return 1 if the screen name is valid, 0 if not. */ faim_export int aim_snvalid(const char *sn) { - int isICQ = 0; - int i = 0; - - if (!sn) + if ((sn == NULL) || (*sn == '\0')) return 0; - if (isdigit(sn[0])) - isICQ = 1; + if (isalpha(sn[0])) + return aim_snvalid_aim(sn); + else if (isdigit(sn[0])) + return aim_snvalid_icq(sn); + else if (sn[0] == '+') + return aim_snvalid_sms(sn); - while (sn[i] != '\0') { - /* If it started with a digit then it betta be all digits, ho */ - if (isICQ) { - if (!isdigit(sn[i])) - return 0; - } else { - if (!isalnum(sn[i]) && (sn[i] != ' ') && (sn[i] != '@') && (sn[i] != '.') && (sn[i] != '_')) - return 0; - } - i++; - } - - return 1; + return 0; } /*