Mon, 14 Jan 2008 03:26:47 +0000
Part of a large patch from o_sukhodolsky to fix some build warnings.
Refs #1344
I removed a couple of the changes here, so there are still two warnings.
| 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 | |
|
18552
810a338ef085
Use the glib strcasecmp functions everywhere, as we've had reports of
Richard Laager <rlaager@pidgin.im>
parents:
18273
diff
changeset
|
189 | if (g_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 | } |