Wed, 13 May 2009 20:29:03 +0000
Support custom smileys in MUCs (when all participants support BoB and a maximum
of 10 participants are in the chat).
Always announce support for BoB, since disable custom smileys will still turn
off fetching them, and BoB can be used for other purposes further on.
| 2086 | 1 | /* This file is part of the Project Athena Zephyr Notification System. |
| 2 | * It contains source for the ZGetVariable, ZSetVariable, and ZUnsetVariable | |
| 3 | * functions. | |
| 4 | * | |
| 5 | * Created by: Robert French | |
| 6 | * | |
| 7 | * Copyright (c) 1987 by the Massachusetts Institute of Technology. | |
| 8 | * For copying and distribution information, see the file | |
| 9 | * "mit-copyright.h". | |
| 10 | */ | |
| 11 | ||
|
18273
e61c53184c52
#include reorganizations to allow compiling with glib < 2.8 using the
Stu Tomlinson <nosnilmot@pidgin.im>
parents:
15884
diff
changeset
|
12 | #include "libpurple/internal.h" |
|
8792
b0645c9dc276
[gaim-migrate @ 9554]
Christian Hammond <chipx86@chipx86.com>
parents:
5872
diff
changeset
|
13 | #include "internal.h" |
|
5872
754c63f29b77
[gaim-migrate @ 6304]
Christian Hammond <chipx86@chipx86.com>
parents:
4272
diff
changeset
|
14 | #include "util.h" |
| 2086 | 15 | |
| 16 | #include <ctype.h> | |
| 10867 | 17 | #ifndef WIN32 |
| 2086 | 18 | #include <pwd.h> |
| 10867 | 19 | #endif |
| 2086 | 20 | |
| 21 | static int get_localvarfile __P((char *bfr)); | |
| 22 | static char *get_varval __P((char *fn, char *val)); | |
| 23 | static int varline __P((char *bfr, char *var)); | |
| 24 | ||
| 25 | char *ZGetVariable(var) | |
| 26 | char *var; | |
| 27 | { | |
| 28 | char varfile[128], *ret; | |
| 29 | ||
| 30 | if (get_localvarfile(varfile)) | |
| 31 | return ((char *)0); | |
| 32 | ||
| 33 | if ((ret = get_varval(varfile, var)) != ZERR_NONE) | |
| 34 | return (ret); | |
| 35 | ||
| 10867 | 36 | #ifdef WIN32 |
| 37 | sprintf(varfile, "C:\\zephyr\\zephyr.var"); | |
| 38 | #else | |
| 2086 | 39 | sprintf(varfile, "%s/zephyr.vars", CONFDIR); |
| 10867 | 40 | #endif |
| 2086 | 41 | return (get_varval(varfile, var)); |
| 42 | } | |
| 43 | ||
| 44 | Code_t ZSetVariable(var, value) | |
| 45 | char *var; | |
| 46 | char *value; | |
| 47 | { | |
| 48 | int written; | |
| 49 | FILE *fpin, *fpout; | |
| 50 | char varfile[128], varfilebackup[128], varbfr[512]; | |
| 51 | ||
| 52 | written = 0; | |
| 53 | ||
| 54 | if (get_localvarfile(varfile)) | |
| 55 | return (ZERR_INTERNAL); | |
| 56 | ||
| 57 | (void) strcpy(varfilebackup, varfile); | |
| 58 | (void) strcat(varfilebackup, ".backup"); | |
| 59 | ||
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
60 | if (!(fpout = fopen(varfilebackup, "w"))) |
| 2086 | 61 | return (errno); |
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
62 | if ((fpin = fopen(varfile, "r")) != NULL) { |
| 2086 | 63 | while (fgets(varbfr, sizeof varbfr, fpin) != (char *) 0) { |
| 64 | if (varbfr[strlen(varbfr)-1] < ' ') | |
| 65 | varbfr[strlen(varbfr)-1] = '\0'; | |
| 66 | if (varline(varbfr, var)) { | |
| 67 | fprintf(fpout, "%s = %s\n", var, value); | |
| 68 | written = 1; | |
| 69 | } | |
| 70 | else | |
| 71 | fprintf(fpout, "%s\n", varbfr); | |
| 72 | } | |
| 73 | (void) fclose(fpin); /* don't care about errs on input */ | |
| 74 | } | |
| 75 | if (!written) | |
| 76 | fprintf(fpout, "%s = %s\n", var, value); | |
| 77 | if (fclose(fpout) == EOF) | |
| 78 | return(EIO); /* can't rely on errno */ | |
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
79 | if (rename(varfilebackup, varfile)) |
| 2086 | 80 | return (errno); |
| 81 | return (ZERR_NONE); | |
| 82 | } | |
| 83 | ||
| 84 | Code_t ZUnsetVariable(var) | |
| 85 | char *var; | |
| 86 | { | |
| 87 | FILE *fpin, *fpout; | |
| 88 | char varfile[128], varfilebackup[128], varbfr[512]; | |
| 89 | ||
| 90 | if (get_localvarfile(varfile)) | |
| 91 | return (ZERR_INTERNAL); | |
| 92 | ||
| 93 | (void) strcpy(varfilebackup, varfile); | |
| 94 | (void) strcat(varfilebackup, ".backup"); | |
| 95 | ||
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
96 | if (!(fpout = fopen(varfilebackup, "w"))) |
| 2086 | 97 | return (errno); |
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
98 | if ((fpin = fopen(varfile, "r")) != NULL) { |
| 2086 | 99 | while (fgets(varbfr, sizeof varbfr, fpin) != (char *) 0) { |
| 100 | if (varbfr[strlen(varbfr)-1] < ' ') | |
| 101 | varbfr[strlen(varbfr)-1] = '\0'; | |
| 102 | if (!varline(varbfr, var)) | |
| 103 | fprintf(fpout, "%s\n", varbfr); | |
| 104 | } | |
| 105 | (void) fclose(fpin); /* don't care about read close errs */ | |
| 106 | } | |
| 107 | if (fclose(fpout) == EOF) | |
| 108 | return(EIO); /* errno isn't reliable */ | |
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
109 | if (rename(varfilebackup, varfile)) |
| 2086 | 110 | return (errno); |
| 111 | return (ZERR_NONE); | |
| 112 | } | |
| 113 | ||
| 114 | static int get_localvarfile(bfr) | |
| 115 | char *bfr; | |
| 116 | { | |
|
4272
fd89c8c4964d
[gaim-migrate @ 4523]
Robert McQueen <robot101@debian.org>
parents:
4271
diff
changeset
|
117 | const char *envptr; |
| 10867 | 118 | #ifndef WIN32 |
| 2086 | 119 | struct passwd *pwd; |
| 15884 | 120 | envptr = purple_home_dir(); |
| 10867 | 121 | #else |
| 122 | envptr = getenv("HOME"); | |
| 123 | if (!envptr) | |
| 124 | envptr = getenv("HOMEPATH"); | |
| 125 | if (!envptr) | |
| 126 | envptr = "C:\\"; | |
| 127 | #endif | |
| 2086 | 128 | if (envptr) |
| 129 | (void) strcpy(bfr, envptr); | |
| 130 | else { | |
| 10867 | 131 | #ifndef WIN32 |
| 2086 | 132 | if (!(pwd = getpwuid((int) getuid()))) { |
| 133 | fprintf(stderr, "Zephyr internal failure: Can't find your entry in /etc/passwd\n"); | |
| 134 | return (1); | |
| 135 | } | |
| 136 | (void) strcpy(bfr, pwd->pw_dir); | |
| 10867 | 137 | #endif |
| 2086 | 138 | } |
| 139 | ||
| 140 | (void) strcat(bfr, "/"); | |
| 141 | (void) strcat(bfr, ".zephyr.vars"); | |
| 142 | return (0); | |
| 143 | } | |
| 144 | ||
| 145 | static char *get_varval(fn, var) | |
| 146 | char *fn; | |
| 147 | char *var; | |
| 148 | { | |
| 149 | FILE *fp; | |
| 150 | static char varbfr[512]; | |
| 151 | int i; | |
| 152 | ||
|
10592
cd4c3a7d7bdf
[gaim-migrate @ 11998]
Daniel Atallah <datallah@pidgin.im>
parents:
10589
diff
changeset
|
153 | fp = fopen(fn, "r"); |
| 2086 | 154 | if (!fp) |
| 155 | return ((char *)0); | |
| 156 | ||
| 157 | while (fgets(varbfr, sizeof varbfr, fp) != (char *) 0) { | |
| 158 | if (varbfr[strlen(varbfr)-1] < ' ') | |
| 159 | varbfr[strlen(varbfr)-1] = '\0'; | |
| 160 | if (!(i = varline(varbfr, var))) | |
| 161 | continue; | |
| 162 | (void) fclose(fp); /* open read-only, don't care */ | |
| 163 | return (varbfr+i); | |
| 164 | } | |
| 165 | (void) fclose(fp); /* open read-only, don't care */ | |
| 166 | return ((char *)0); | |
| 167 | } | |
| 168 | ||
| 169 | /* If the variable in the line bfr[] is the same as var, return index to | |
| 170 | the variable value, else return 0. */ | |
| 171 | static int varline(bfr, var) | |
| 172 | char *bfr; | |
| 173 | char *var; | |
| 174 | { | |
| 175 | register char *cp; | |
| 176 | ||
| 177 | ||
| 178 | if (!bfr[0] || bfr[0] == '#') /* comment or null line */ | |
| 179 | return (0); | |
| 180 | ||
| 181 | cp = bfr; | |
| 182 | while (*cp && !isspace(*cp) && (*cp != '=')) | |
| 183 | cp++; | |
| 184 | ||
| 10867 | 185 | #ifndef WIN32 |
| 2086 | 186 | #define max(a,b) ((a > b) ? (a) : (b)) |
| 10867 | 187 | #endif |
| 2086 | 188 | |
|
26726
b81bcec8f359
Updates for GTK+ 3.0. Remove some deprecated functions (someone should
Elliott Sales de Andrade <qulogic@pidgin.im>
parents:
18552
diff
changeset
|
189 | if (g_ascii_strncasecmp(bfr, var, max(strlen(var), cp - bfr))) |
| 2086 | 190 | return(0); /* var is not the var in |
| 191 | bfr ==> no match */ | |
| 192 | ||
| 193 | cp = strchr(bfr, '='); | |
| 194 | if (!cp) | |
| 195 | return(0); | |
| 196 | cp++; | |
| 197 | while (*cp && isspace(*cp)) /* space up to variable value */ | |
| 198 | cp++; | |
| 199 | ||
| 200 | return (cp - bfr); /* return index */ | |
| 201 | } |