9 #include <moira_site.h>
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_DPHONE 155
43 #define LOC_MPHONE 243
49 #define LEN_ADDRESS 30
50 #define LEN_DORM_ROOM 15
86 struct entry *e, *get_next_entry();
88 char buf[BUFSIZ], *file = NULL;
90 whoami = rindex(argv[0], '/');
96 for (i = 1; i < argc; i++) {
97 if (!strcmp(argv[i], "-w"))
99 else if (!strcmp(argv[i], "-D"))
100 setenv("ING_SET", "set printqry");
101 else if (!strcmp(argv[i], "-n"))
103 else if (!strcmp(argv[i], "-u"))
105 else if (file != NULL)
106 fprintf(stderr, "Usage: %s [-w] [-D] [-n] [-u] inputfile\n", whoami);
111 in = fopen(file, "r");
113 fprintf(stderr, "Unable to open %s for input\n", file);
118 ## range of u is users
120 while (e = get_next_entry(in)) {
134 struct entry *get_next_entry(in)
137 static struct entry e;
138 static char buf[BUFSIZ], eid[16], classbuf[10], titlebuf[12];
139 static char name[LEN_NAME+1], id[LEN_ID+1], course[LEN_COURSE+1];
140 static char year[LEN_YEAR+1], address[LEN_ADDRESS+1];
141 static char dorm_room[LEN_DORM_ROOM+1], city[LEN_CITY+1];
142 static char state[LEN_STATE+1], dphone[LEN_DPHONE+1], mphone[LEN_MPHONE+1];
143 static char sname[LEN_NAME+1], title[128];
144 static int nyear = 0;
145 int ends_jr, ends_iii, ends_iv, ends_sr;
152 gettimeofday(&tv, NULL);
153 tm = localtime(&tv.tv_sec);
159 if (fgets(buf, sizeof(buf), in) == NULL)
160 return((struct entry *)NULL);
162 strncpy(name, &buf[LOC_NAME], LEN_NAME); name[LEN_NAME] = 0;
163 strncpy(id, &buf[LOC_ID], LEN_ID); id[LEN_ID] = 0;
164 strncpy(course, &buf[LOC_COURSE], LEN_COURSE); course[LEN_COURSE] = 0;
165 strncpy(year, &buf[LOC_YEAR], LEN_YEAR); year[LEN_YEAR] = 0;
166 strncpy(address, &buf[LOC_ADDRESS], LEN_ADDRESS); address[LEN_ADDRESS] = 0;
167 strncpy(dorm_room, &buf[LOC_DORM_ROOM], LEN_DORM_ROOM); dorm_room[LEN_DORM_ROOM] = 0;
168 strncpy(city, &buf[LOC_CITY], LEN_CITY); city[LEN_CITY] = 0;
169 strncpy(state, &buf[LOC_STATE], LEN_STATE); state[LEN_STATE] = 0;
170 strncpy(dphone, &buf[LOC_DPHONE], LEN_DPHONE); dphone[LEN_DPHONE] = 0;
171 strncpy(mphone, &buf[LOC_MPHONE], LEN_MPHONE); mphone[LEN_MPHONE] = 0;
174 e.name = strtrim(sname);
175 p = index(name, ',');
178 e.last = strtrim(name);
184 if (p = index(e.first, ' ')) {
186 e.first = strtrim(e.first);
187 e.middle = strtrim(p + 1);
189 e.first = strtrim(e.first);
196 ends_jr = ends_iii = ends_iv = ends_sr = 0;
199 LookForJrAndIII(e.last, &ends_sr, &ends_jr, &ends_iii, &ends_iv);
200 LookForJrAndIII(e.first, &ends_sr, &ends_jr, &ends_iii, &ends_iv);
208 EncryptID(e.eid, e.id, e.first, e.last);
210 e.year = strtrim(year);
212 if (e.year[0] == 'G') {
214 sprintf(title, "Grad Student");
217 sprintf(classbuf, "%d", nyear + 4 - atoi(e.year) + 1900);
218 sprintf(title, "Undergrad (class of %s)", classbuf);
221 e.course = strtrim(course);
222 e.address = strtrim(address);
223 e.dorm = strtrim(dorm_room);
224 e.city = strtrim(city);
225 e.state = strtrim(state);
226 e.dphone = strtrim(dphone);
227 e.mphone = strtrim(mphone);
235 int changed, nochange;
236 char buf[BUFSIZ], *from, *to;
237 ## char *first, *last, *eid, *title, *sid, *name;
238 ## char class[9], haddr[128], hphone[17], ophone[13], dept[24];
242 if (strlen(first) > 16)
245 if (strlen(last) > 16)
249 ## repeat retrieve (id = u.users_id)
250 ## where u.#last = @last and u.#first = @first and u.mit_id = @eid
252 com_err(whoami, 0, "New user found: %s %s\n", first, last);
256 ## repeat replace u (mit_id=@eid) where u.users_id = @id
260 strcpy(dept, e->course);
262 strcpy(haddr, e->address);
265 strcat(haddr, e->dorm);
269 strcat(haddr, e->city);
274 strcat(haddr, e->state);
276 strcpy(hphone, e->dphone);
277 strcpy(ophone, e->mphone);
278 ## repeat replace u (xname = @name, xdept = @dept, xtitle = @title,
279 ## xaddress = @haddr, xphone1 = @hphone, xphone2 = @ophone,
281 ## where u.users_id = @id
285 set_next_object_id(object, limit)
290 ## int rowcount, exists, value;
294 ## repeat retrieve (value = values.#value) where values.#name = @name
295 ## inquire_equel(rowcount = "rowcount")
301 ## retrieve (exists = any(users.name where users.name = value))
302 ## inquire_equel(rowcount = "rowcount")
309 if (limit && value > MAX_ID_VALUE)
310 value = MIN_ID_VALUE;
311 ## retrieve (exists = any(users.name where users.name = value))
314 ## repeat replace values (#value = @value) where values.#name = @name