6 * Copyright (C) 1987 by the Massachusetts Institute of Technology
9 * Revision 1.1 1987-08-22 17:14:30 wesommer
15 static char *rcsid_fixname_c = "$Header$";
24 void FixName(ilnm, ifnm, last, first, middle)
26 char *first, *last, *middle;
28 int ends_jr=0, ends_iii=0, ends_iv=0;
35 TrimTrailingSpace(ilnm);
36 LookForJrAndIII(ilnm, &ends_jr, &ends_iii, &ends_iv);
40 strncpy(last, ilnm, LAST_LEN);
42 /* First name & middle initial ... */
44 TrimTrailingSpace(ifnm);
45 LookForJrAndIII(ifnm, &ends_jr, &ends_iii, &ends_iv);
47 GetMidInit(ifnm, middle);
51 /* okay, finish up first name */
52 AppendJrOrIII(ifnm, &ends_jr, &ends_iii, &ends_iv);
54 strncpy(first, ifnm, FIRST_LEN);
57 AppendJrOrIII(nm, phas_jr, phas_iii, phas_iv)
59 register int *phas_jr;
60 register int *phas_iii;
61 register int *phas_iv;
77 register int cflag; /* convert to lcase, unless at start or following */
78 /* a space or punctuation mark (e.g., '-') */
80 for (cflag = 0; *p; p++) {
81 if (cflag && isupper(*p)) {
84 else if (isspace(*p) || ispunct(*p)) {
93 LookForJrAndIII(nm, pends_jr, pends_iii, pends_iv)
95 register int *pends_jr;
96 register int *pends_iii;
97 register int *pends_iv;
99 register int len = strlen(nm);
101 if (len >= 4 && !strcmp(nm + len - 3, " JR")) {
105 else if (len >= 4 && !strcmp(nm + len - 3, " IV")) {
109 else if (len >= 5 && !strcmp(nm + len - 4, " JR.")) {
113 else if (len >= 5 && !strcmp(nm + len - 4, " III")) {
119 LookForSt(nm) /* ST PIERRE, etc. */
124 if (!strcmp(nm,"ST ")) {
125 strcpy(temp, nm + 3);
131 LookForO(nm) /* O BRIEN, etc. */
134 if (!strcmp(nm, "O ") && isalpha(nm[2])) {
139 TrimTrailingSpace(ip)
143 for (p = ip + strlen(ip) - 1; p >= ip && isspace(*p); p--) {
153 for ( ; c= *cp; cp++)
154 if (islower(c)) *cp = toupper(c);
158 register char *nm; /* truncate at first space, if any such */
159 register char *mi; /* set to first char after first space, if any such */
161 while (*nm && !isspace(*nm)) {
167 while (*nm && isspace(*nm)) {