|  | /* | 
|  | * This file is part of the UCB release of Plan 9. It is subject to the license | 
|  | * terms in the LICENSE file found in the top-level directory of this | 
|  | * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No | 
|  | * part of the UCB release of Plan 9, including this file, may be copied, | 
|  | * modified, propagated, or distributed except according to the terms contained | 
|  | * in the LICENSE file. | 
|  | */ | 
|  | #include <stdlib.h> | 
|  |  | 
|  | #include <stdio.h> | 
|  | #include <parlib/parlib.h> | 
|  | #include <unistd.h> | 
|  | #include <signal.h> | 
|  | #include <fcntl.h> | 
|  | #include <ctype.h> | 
|  | #include <iplib/iplib.h> | 
|  | #include <ndblib/ndb.h> | 
|  |  | 
|  | /* | 
|  | *  Parse a data base entry.  Entries may span multiple | 
|  | *  lines.  An entry starts on a left margin.  All subsequent | 
|  | *  lines must be indented by white space.  An entry consists | 
|  | *  of tuples of the forms: | 
|  | *	attribute-name | 
|  | *	attribute-name=value | 
|  | *	attribute-name="value with white space" | 
|  | * | 
|  | *  The parsing returns a 2-dimensional structure.  The first | 
|  | *  dimension joins all tuples. All tuples on the same line | 
|  | *  form a ring along the second dimension. | 
|  | */ | 
|  |  | 
|  | /* | 
|  | *  parse the next entry in the file | 
|  | */ | 
|  | struct ndbtuple* | 
|  | ndbparse(struct ndb *db) | 
|  | { | 
|  | char *line; | 
|  | struct ndbtuple *t; | 
|  | struct ndbtuple *first, *last; | 
|  | int len; | 
|  |  | 
|  | first = last = 0; | 
|  | for(;;){ | 
|  | if((line = fgets(db->buf, sizeof(db->buf),db->b)) == 0) | 
|  | break; | 
|  | len = strlen(db->buf); | 
|  | if(line[len-1] != '\n') | 
|  | break; | 
|  | if(first && !isspace(*line) && *line != '#'){ | 
|  | fseek(db->b, -len, 1); | 
|  | break; | 
|  | } | 
|  | t = _ndbparseline(line); | 
|  | if(t == 0) | 
|  | continue; | 
|  | if(first) | 
|  | last->entry = t; | 
|  | else | 
|  | first = t; | 
|  | last = t; | 
|  | while(last->entry) | 
|  | last = last->entry; | 
|  | } | 
|  | ndbsetmalloctag(first, getcallerpc(&db)); | 
|  | return first; | 
|  | } |