aboutsummaryrefslogtreecommitdiffstats
path: root/protocols/oscar/oscar_util.c
blob: c2ce8e4db0b7e8da5a669eb05693b8fd28fd0cf6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include <aim.h>
#include <ctype.h>

/*
* int snlen(const char *)
*
* This takes a screen name and returns its length without
* spaces.  If there are no spaces in the SN, then the
* return is equal to that of strlen().
*
*/
static int aim_snlen(const char *sn)
{
	int i = 0;
	const char *curPtr = NULL;

	if (!sn) {
		return 0;
	}

	curPtr = sn;
	while ((*curPtr) != (char) '\0') {
		if ((*curPtr) != ' ') {
			i++;
		}
		curPtr++;
	}

	return i;
}

/*
* int sncmp(const char *, const char *)
*
* This takes two screen names and compares them using the rules
* on screen names for AIM/AOL.  Mainly, this means case and space
* insensitivity (all case differences and spacing differences are
* ignored).
*
* Return: 0 if equal
*     non-0 if different
*
*/

int aim_sncmp(const char *sn1, const char *sn2)
{
	const char *curPtr1 = NULL, *curPtr2 = NULL;

	if (aim_snlen(sn1) != aim_snlen(sn2)) {
		return 1;
	}

	curPtr1 = sn1;
	curPtr2 = sn2;
	while ((*curPtr1 != (char) '\0') && (*curPtr2 != (char) '\0')) {
		if ((*curPtr1 == ' ') || (*curPtr2 == ' ')) {
			if (*curPtr1 == ' ') {
				curPtr1++;
			}
			if (*curPtr2 == ' ') {
				curPtr2++;
			}
		} else {
			if (g_ascii_toupper(*curPtr1) != g_ascii_toupper(*curPtr2)) {
				return 1;
			}
			curPtr1++;
			curPtr2++;
		}
	}

	/* Should both be NULL */
	if (*curPtr1 != *curPtr2) {
		return 1;
	}

	return 0;
}
pan class="o">|| ( i == 0 && strstr( s, "\n%\n" ) ) ) { buflen += i; memset( s + buflen, 0, BUFSIZE - buflen ); if( !( t = strstr( s, "\n%\n" ) ) || s[0] != '?' ) { /* FIXME: Clean up */ // help_close( *help ); *help = NULL; g_free( s ); return( NULL ); } i = strchr( s, '\n' ) - s; if( h->string ) { h = h->next = g_new0( help_t, 1 ); } h->string = g_new ( char, i ); strncpy( h->string, s + 1, i - 1 ); h->string[i-1] = 0; h->fd = (*help)->fd; h->offset.file_offset = lseek( h->fd, 0, SEEK_CUR ) - buflen + i + 1; h->length = t - s - i - 1; h->mtime = mtime; buflen -= ( t + 3 - s ); t = g_strdup( t + 3 ); g_free( s ); s = g_renew( char, t, BUFSIZE + 1 ); s[BUFSIZE] = 0; } g_free( s ); return( *help ); } char *help_get( help_t **help, char *string ) { time_t mtime; struct stat stat[1]; help_t *h; h=*help; while( h ) { if( g_strcasecmp( h->string, string ) == 0 ) break; h = h->next; } if( h && h->length > 0 ) { char *s = g_new( char, h->length + 1 ); if( fstat( h->fd, stat ) != 0 ) { g_free( h ); *help = NULL; return NULL; } mtime = stat->st_mtime; if( mtime > h->mtime ) return NULL; s[h->length] = 0; if( h->fd >= 0 ) { lseek( h->fd, h->offset.file_offset, SEEK_SET ); read( h->fd, s, h->length ); } else { strncpy( s, h->offset.mem_offset, h->length ); } return s; } return NULL; }