| 20 |  | #define getc    getc_unlocked | 
| 21 |  | #endif | 
| 22 |  |  | 
| 23 | < | /* Create a new parameter with empty field list (comment optional) */ | 
| 24 | < | IDF_PARAMETER * | 
| 25 | < | idf_newparam(IDF_LOADED *idf, const char *pname, const char *comm, | 
| 26 | < | IDF_PARAMETER *prev) | 
| 23 | > | /* Create a new object with empty field list (comment optional) */ | 
| 24 | > | IDF_OBJECT * | 
| 25 | > | idf_newobject(IDF_LOADED *idf, const char *pname, const char *comm, | 
| 26 | > | IDF_OBJECT *prev) | 
| 27 |  | { | 
| 28 |  | LUENT           *pent; | 
| 29 | < | IDF_PARAMETER   *pnew; | 
| 29 | > | IDF_OBJECT      *pnew; | 
| 30 |  |  | 
| 31 |  | if ((idf == NULL) | (pname == NULL)) | 
| 32 |  | return(NULL); | 
| 34 |  | pent = lu_find(&idf->ptab, pname); | 
| 35 |  | if (pent == NULL) | 
| 36 |  | return(NULL); | 
| 37 | < | if (pent->key == NULL) {        /* new parameter name/type? */ | 
| 37 | > | if (pent->key == NULL) {        /* new object name/type? */ | 
| 38 |  | pent->key = (char *)malloc(strlen(pname)+1); | 
| 39 |  | if (pent->key == NULL) | 
| 40 |  | return(NULL); | 
| 41 |  | strcpy(pent->key, pname); | 
| 42 |  | } | 
| 43 | < | pnew = (IDF_PARAMETER *)malloc(sizeof(IDF_PARAMETER)+strlen(comm)); | 
| 43 | > | pnew = (IDF_OBJECT *)malloc(sizeof(IDF_OBJECT)+strlen(comm)); | 
| 44 |  | if (pnew == NULL) | 
| 45 |  | return(NULL); | 
| 46 |  | strcpy(pnew->rem, comm); | 
| 47 |  | pnew->nfield = 0; | 
| 48 |  | pnew->flist = NULL; | 
| 49 |  | pnew->pname = pent->key;        /* add to table */ | 
| 50 | < | pnew->pnext = (IDF_PARAMETER *)pent->data; | 
| 50 | > | pnew->pnext = (IDF_OBJECT *)pent->data; | 
| 51 |  | pent->data = (char *)pnew; | 
| 52 |  | pnew->dnext = NULL;             /* add to file list */ | 
| 53 |  | if (prev != NULL || (prev = idf->plast) != NULL) { | 
| 62 |  | return(pnew); | 
| 63 |  | } | 
| 64 |  |  | 
| 65 | < | /* Add a field to the given parameter and follow with the given text */ | 
| 65 | > | /* Add a field to the given object and follow with the given text */ | 
| 66 |  | int | 
| 67 | < | idf_addfield(IDF_PARAMETER *param, const char *fval, const char *comm) | 
| 67 | > | idf_addfield(IDF_OBJECT *param, const char *fval, const char *comm) | 
| 68 |  | { | 
| 69 |  | int             fnum = 1;       /* returned argument number */ | 
| 70 |  | IDF_FIELD       *fnew, *flast; | 
| 83 |  | fnew->rem = cp; | 
| 84 |  | while ((*cp++ = *comm++)) | 
| 85 |  | ; | 
| 86 | < | /* add to parameter's field list */ | 
| 86 | > | /* add to object's field list */ | 
| 87 |  | if ((flast = param->flist) != NULL) { | 
| 88 |  | ++fnum; | 
| 89 |  | while (flast->next != NULL) { | 
| 99 |  | return(fnum); | 
| 100 |  | } | 
| 101 |  |  | 
| 102 | < | /* Retrieve the indexed field from parameter (first field index is 1) */ | 
| 102 | > | /* Retrieve the indexed field from object (first field index is 1) */ | 
| 103 |  | IDF_FIELD * | 
| 104 | < | idf_getfield(IDF_PARAMETER *param, int fn) | 
| 104 | > | idf_getfield(IDF_OBJECT *param, int fn) | 
| 105 |  | { | 
| 106 |  | IDF_FIELD       *fld; | 
| 107 |  |  | 
| 113 |  | return(fld); | 
| 114 |  | } | 
| 115 |  |  | 
| 116 | < | /* Delete the specified parameter from loaded IDF */ | 
| 116 | > | /* Delete the specified object from loaded IDF */ | 
| 117 |  | int | 
| 118 | < | idf_delparam(IDF_LOADED *idf, IDF_PARAMETER *param) | 
| 118 | > | idf_delobject(IDF_LOADED *idf, IDF_OBJECT *param) | 
| 119 |  | { | 
| 120 |  | LUENT           *pent; | 
| 121 | < | IDF_PARAMETER   *pptr, *plast; | 
| 121 | > | IDF_OBJECT      *pptr, *plast; | 
| 122 |  |  | 
| 123 |  | if ((idf == NULL) | (param == NULL)) | 
| 124 |  | return(0); | 
| 125 | < | /* remove from parameter table */ | 
| 125 | > | /* remove from object table */ | 
| 126 |  | pent = lu_find(&idf->ptab, param->pname); | 
| 127 | < | for (plast = NULL, pptr = (IDF_PARAMETER *)pent->data; | 
| 127 | > | for (plast = NULL, pptr = (IDF_OBJECT *)pent->data; | 
| 128 |  | pptr != NULL; plast = pptr, pptr = pptr->pnext) | 
| 129 |  | if (pptr == param) | 
| 130 |  | break; | 
| 151 |  | param->flist = fdel->next; | 
| 152 |  | free(fdel); | 
| 153 |  | } | 
| 154 | < | free(param);                    /* free parameter struct */ | 
| 154 | > | free(param);                    /* free object struct */ | 
| 155 |  | return(1); | 
| 156 |  | } | 
| 157 |  |  | 
| 158 | < | /* Move the specified parameter to the given position in the IDF */ | 
| 158 | > | /* Move the specified object to the given position in the IDF */ | 
| 159 |  | int | 
| 160 | < | idf_movparam(IDF_LOADED *idf, IDF_PARAMETER *param, IDF_PARAMETER *prev) | 
| 160 | > | idf_movobject(IDF_LOADED *idf, IDF_OBJECT *param, IDF_OBJECT *prev) | 
| 161 |  | { | 
| 162 | < | IDF_PARAMETER   *pptr, *plast; | 
| 162 | > | IDF_OBJECT      *pptr, *plast; | 
| 163 |  |  | 
| 164 |  | if ((idf == NULL) | (param == NULL)) | 
| 165 |  | return(0); | 
| 166 | + | /* quick check if already there */ | 
| 167 | + | if (param == (prev==NULL ? idf->pfirst : prev->dnext)) | 
| 168 | + | return(1); | 
| 169 |  | /* find in IDF list, first*/ | 
| 170 |  | for (plast = NULL, pptr = idf->pfirst; | 
| 171 |  | pptr != param; plast = pptr, pptr = pptr->dnext) | 
| 172 |  | if (pptr == NULL) | 
| 173 |  | return(0); | 
| 174 | < | if (plast == NULL) { | 
| 172 | < | if (prev == NULL) | 
| 173 | < | return(1);      /* already in place */ | 
| 174 | > | if (plast == NULL) | 
| 175 |  | idf->pfirst = param->dnext; | 
| 176 | < | } else { | 
| 176 | < | if (prev == plast) | 
| 177 | < | return(1);      /* already in place */ | 
| 176 | > | else | 
| 177 |  | plast->dnext = param->dnext; | 
| 179 | – | } | 
| 178 |  | if (idf->plast == param) | 
| 179 |  | idf->plast = plast; | 
| 180 |  | if (prev == NULL) {             /* means they want it at beginning */ | 
| 187 |  | return(1); | 
| 188 |  | } | 
| 189 |  |  | 
| 190 | < | /* Get a named parameter list */ | 
| 191 | < | IDF_PARAMETER * | 
| 192 | < | idf_getparam(IDF_LOADED *idf, const char *pname) | 
| 190 | > | /* Get a named object list */ | 
| 191 | > | IDF_OBJECT * | 
| 192 | > | idf_getobject(IDF_LOADED *idf, const char *pname) | 
| 193 |  | { | 
| 194 |  | if ((idf == NULL) | (pname == NULL)) | 
| 195 |  | return(NULL); | 
| 196 |  |  | 
| 197 | < | return((IDF_PARAMETER *)lu_find(&idf->ptab,pname)->data); | 
| 197 | > | return((IDF_OBJECT *)lu_find(&idf->ptab,pname)->data); | 
| 198 |  | } | 
| 199 |  |  | 
| 200 |  | /* Read an argument including terminating ',' or ';' -- return which */ | 
| 244 |  | ungetc(c, fp); | 
| 245 |  | } | 
| 246 |  |  | 
| 247 | < | /* Read a parameter and fields from an open file and add to end of list */ | 
| 248 | < | IDF_PARAMETER * | 
| 249 | < | idf_readparam(IDF_LOADED *idf, FILE *fp) | 
| 247 | > | /* Read a object and fields from an open file and add to end of list */ | 
| 248 | > | IDF_OBJECT * | 
| 249 | > | idf_readobject(IDF_LOADED *idf, FILE *fp) | 
| 250 |  | { | 
| 251 | < | char            abuf[IDF_MAXARGL], cbuf[IDF_MAXLINE]; | 
| 251 | > | char            abuf[IDF_MAXARGL], cbuf[100*IDF_MAXLINE]; | 
| 252 |  | int             delim; | 
| 253 | < | IDF_PARAMETER   *pnew; | 
| 253 | > | IDF_OBJECT      *pnew; | 
| 254 |  |  | 
| 255 |  | if ((delim = idf_read_argument(abuf, fp, 1)) == EOF) | 
| 256 |  | return(NULL); | 
| 257 | < | idf_read_comment(cbuf, IDF_MAXLINE, fp); | 
| 258 | < | pnew = idf_newparam(idf, abuf, cbuf, NULL); | 
| 257 | > | idf_read_comment(cbuf, sizeof(cbuf), fp); | 
| 258 | > | pnew = idf_newobject(idf, abuf, cbuf, NULL); | 
| 259 |  | while (delim == ',') | 
| 260 |  | if ((delim = idf_read_argument(abuf, fp, 1)) != EOF) { | 
| 261 | < | idf_read_comment(cbuf, IDF_MAXLINE, fp); | 
| 261 | > | idf_read_comment(cbuf, sizeof(cbuf), fp); | 
| 262 |  | idf_addfield(pnew, abuf, cbuf); | 
| 263 |  | } | 
| 264 |  | if (delim != ';') | 
| 265 | < | fputs("Expected ';' at end of parameter list!\n", stderr); | 
| 265 | > | fputs("Expected ';' at end of object list!\n", stderr); | 
| 266 |  | return(pnew); | 
| 267 |  | } | 
| 268 |  |  | 
| 343 |  | idf = idf_create(hdrcomm);      /* create IDF struct */ | 
| 344 |  | if (idf == NULL) | 
| 345 |  | return(NULL); | 
| 346 | < | /* read each parameter */ | 
| 347 | < | while (idf_readparam(idf, fp) != NULL) | 
| 346 | > | /* read each object */ | 
| 347 | > | while (idf_readobject(idf, fp) != NULL) | 
| 348 |  | ; | 
| 349 |  | if (fp != stdin)                /* close file if not stdin */ | 
| 350 |  | fclose(fp); | 
| 351 |  | return(idf);                    /* success! */ | 
| 352 |  | } | 
| 353 |  |  | 
| 354 | < | /* Write a parameter and fields to an open file */ | 
| 354 | > | /* Write a object and fields to an open file */ | 
| 355 |  | int | 
| 356 | < | idf_writeparam(IDF_PARAMETER *param, FILE *fp, int incl_comm) | 
| 356 | > | idf_writeparam(IDF_OBJECT *param, FILE *fp, int incl_comm) | 
| 357 |  | { | 
| 358 |  | IDF_FIELD       *fptr; | 
| 359 |  |  | 
| 381 |  | idf_write(IDF_LOADED *idf, const char *fname, int incl_comm) | 
| 382 |  | { | 
| 383 |  | FILE            *fp; | 
| 384 | < | IDF_PARAMETER   *pptr; | 
| 384 | > | IDF_OBJECT      *pptr; | 
| 385 |  |  | 
| 386 |  | if (idf == NULL) | 
| 387 |  | return(0); | 
| 410 |  | if (idf->hrem != NULL) | 
| 411 |  | free(idf->hrem); | 
| 412 |  | while (idf->pfirst != NULL) | 
| 413 | < | idf_delparam(idf, idf->pfirst); | 
| 413 | > | idf_delobject(idf, idf->pfirst); | 
| 414 |  | lu_done(&idf->ptab); | 
| 415 |  | } |