12 ##define WHO 11859 /* root */
13 ##define PROG "stu-tape"
15 #define MAX_ID_VALUE 32766
16 #define MIN_ID_VALUE 101
38 #define LOC_ADDRESS 80
39 #define LOC_DORM_ROOM 110
42 #define LOC_DORM_PHONE 159
43 #define LOC_MIT_PHONE1 243
49 #define LEN_ADDRESS 26
50 #define LEN_DORM_ROOM 14
84 struct entry *e, *get_next_entry();
86 char buf[BUFSIZ], *file = NULL;
88 whoami = rindex(argv[0], '/');
94 for (i = 1; i < argc; i++) {
95 if (!strcmp(argv[i], "-w"))
97 else if (!strcmp(argv[i], "-D"))
98 setenv("ING_SET", "set printqry");
99 else if (!strcmp(argv[i], "-n"))
101 else if (file != NULL)
102 fprintf(stderr, "Usage: %s [-w] [-D] [-n] inputfile\n", whoami);
107 in = fopen(file, "r");
109 fprintf(stderr, "Unable to open %s for input\n", file);
114 ## range of u is users
116 while (e = get_next_entry(in)) {
130 struct entry *get_next_entry(in)
133 static struct entry e;
134 static char buf[BUFSIZ], eid[16], classbuf[10], titlebuf[12];
136 int ends_jr, ends_iii, ends_iv;
143 gettimeofday(&tv, NULL);
144 tm = localtime(&tv.tv_sec);
150 fgets(buf, sizeof(buf), in);
152 p = index(&buf[LOC_NAME], ',');
155 e.last = strtrim(&buf[LOC_NAME]);
158 if (p = index(e.first, ' ')) {
160 e.middle = strtrim(p + 1);
165 e.first = strtrim(e.first);
166 ends_jr = ends_iii = ends_iv = 0;
169 LookForJrAndIII(e.last, &ends_jr, &ends_iii, &ends_iv);
170 LookForJrAndIII(e.first, &ends_jr, &ends_iii, &ends_iv);
176 AppendJrOrIII(titlebuf, &ends_jr, &ends_iii, &ends_iv);
181 EncryptID(e.eid, e.id, e.first, e.last);
183 e.course = &buf[LOC_COURSE];
184 e.course[LEN_COURSE] = 0;
185 e.year = &buf[LOC_YEAR];
186 e.year[LEN_YEAR] = 0;
187 if (e.year[0] == 'G')
191 sprintf(classbuf, "%d", year + 4 - atoi(e.year) + 1900);
193 e.address = &buf[LOC_ADDRESS];
194 e.address[LEN_ADDRESS] = 0;
195 e.dorm = &buf[LOC_DORM_ROOM];
196 e.dorm[LEN_DORM_ROOM] = 0;
197 e.city = &buf[LOC_CITY];
198 e.city[LEN_CITY] = 0;
199 e.state = &buf[LOC_STATE];
200 e.state[LEN_STATE] = 0;
201 e.dphone = &buf[LOC_DORM_PHONE];
202 e.dphone[LEN_DPHONE] = 0;
203 e.mphone = &buf[LOC_MIT_PHONE1];
204 e.mphone[LEN_MPHONE] = 0;
212 int changed, nochange;
213 char buf[BUFSIZ], *from, *to;
214 ## char *first, *last, *eid;
215 ## char class[9], haddr[81], hphone[17], ophone[13], dept[13];
222 ## repeat retrieve (id = u.users_id, class = u.mit_year, haddr = u.home_addr,
223 ## hphone = u.home_phone, ophone = u.office_phone,
224 ## dept = u.mit_dept)
225 ## where u.#last = @last and u.#first = @first and u.mit_id = @eid
230 if (strcmp(e->class, strtrim(class))) {
231 com_err(whoami, 0, "updating class for user %s %s from %s to %s",
232 first, last, class, e->class);
233 strcpy(class, e->class);
234 ## repeat replace u (mit_year = @class,
235 ## modtime = "now", modby = WHO, modwith = PROG)
236 ## where u.users_id = @id
238 changed = nochange = 0;
239 strcpy(buf, strtrim(e->address));
240 e->dorm = strtrim(e->dorm);
243 strcat(buf, e->dorm);
245 e->city = strtrim(e->city);
248 strcat(buf, e->city);
251 e->state = strtrim(e->state);
254 strcat(buf, e->state);
256 while (to = index(buf, ','))
258 while (to = index(buf, ':'))
261 if (haddr[0] == ' ') {
262 strncpy(haddr, buf, 80);
265 } else if (strncmp(strtrim(haddr), buf, 80))
268 if (strncmp(strtrim(haddr), buf, 80))
270 strncpy(haddr, buf, 80);
282 if (hphone[0] == ' ') {
283 strncpy(hphone, buf, 16);
285 } else if (strncmp(strtrim(hphone), buf, 16))
288 if (strncmp(strtrim(hphone), buf, 16))
290 strncpy(hphone, buf, 16);
302 if (ophone[0] == ' ') {
303 strncpy(ophone, buf, 12);
305 } else if (strncmp(strtrim(ophone), buf, 12))
308 if (strncmp(strtrim(ophone), buf, 12))
310 strncpy(ophone, buf, 12);
313 e->course = strtrim(e->course);
315 if (dept[0] == ' ') {
316 strncpy(dept, e->course, 12);
318 } else if (strncmp(strtrim(dept), e->course, 11))
321 if (strncmp(strtrim(dept), e->course, 11))
323 strncpy(dept, e->course, 12);
327 com_err(whoami, 0, "updating finger for %s %s", first, last);
328 ## repeat replace u (home_addr = @haddr, home_phone = @hphone,
329 ## office_phone = @ophone, #mit_dept = @dept,
330 ## fmodtime = "now", fmodby = WHO, fmodwith = PROG)
331 ## where u.users_id = @id
333 com_err(whoami, 0, "NOT updating finger for %s %s", first, last);
340 char buf[512], *from, *to;
342 ## char *last, *first, *class, *middle, login[9], *eid, fullname[65];
343 ## char haddr[81], hphone[17], ophone[13], dept[13];
346 strcpy(buf, strtrim(e->address));
349 strcat(buf, strtrim(e->dorm));
353 strcat(buf, strtrim(e->city));
357 strcat(buf, strtrim(e->state));
359 strncpy(haddr, buf, 80);
368 strncpy(hphone, buf, 16);
377 strncpy(ophone, buf, 12);
378 e->course = strtrim(e->course);
379 strncpy(dept, e->course, 12);
382 id = set_next_object_id("users_id");
383 uid = set_next_object_id("uid");
384 sprintf(login, "#%d", uid);
391 sprintf(fullname, "%s %s %s", first, middle, last);
393 sprintf(fullname, "%s %s", first, last);
395 ## append users (#login = login, users_id = id, #uid = uid, shell = "/bin/csh",
396 ## #last = last, #first = first, #middle = middle, status = 0,
397 ## #mit_id = eid, #mit_year = class,
398 ## modtime = "now", modby = WHO, modwith = PROG,
399 ## #fullname = fullname, home_addr = haddr, home_phone = hphone,
400 ## office_phone = ophone, #mit_dept = dept,
401 ## fmodtime = "now", fmodby = WHO, fmodwith = PROG,
403 com_err(whoami, 0, "adding user %s %s", e->first, e->last);
407 set_next_object_id(object)
411 ## int rowcount, exists, value;
415 ## repeat retrieve (value = values.#value) where values.#name = @name
416 ## inquire_equel(rowcount = "rowcount")
422 ## retrieve (exists = any(users.name where users.name = value))
423 ## inquire_equel(rowcount = "rowcount")
430 if (value > MAX_ID_VALUE)
431 value = MIN_ID_VALUE;
432 ## retrieve (exists = any(users.name where users.name = value))
435 ## repeat replace values (#value = @value) where values.#name = @name