.TH cdb_find 3 .SH NAME cdb_find \- look up a key in a constant database .SH SYNTAX .B #include <cdb.h> .br .B #include <uint32.h> int cdb_find(struct cdb *\fIc\fR,char *\fIkey\fR,unsigned long int \fIkeylen\fR); .br int cdb_datalen(struct cdb *\fIc\fR); .br int cdb_datapos(struct cdb *\fIc\fR); .br int cdb_findnext(struct cdb *\fIc\fR,char *\fIkey\fR,unsigned long int \fIkeylen\fR); .SH DESCRIPTION \fBcdb_find\fR looks for \fIkey\fR. If cdb_find returns 0, the database does not contain that key; stop. If cdb_find returns -1, there was a read error; abort. \fBcdb_datalen\fR returns the length of the data associated with the \fIkey\fR. Use it to allocate a pointer \fIp\fR with enough space to hold the data. \fBcdb_datapos\fR returns the position of the data inside the file. Use it as argument to cdb_read to retrieve the data. There may be several records under a single key. You can use \fBcdb_findnext\fR to find the next record under this key. .SH EXAMPLE static struct cdb; if (cdb_find(&c,key,strlen(key)>0) { char *buf=alloca(cdb_datalen(&c)); cdb_read(&c,buf,cdb_datalen(&c),cdb_datapos(&c)); write(1,buf,cdb_datalen(&c)); .br } .SH "SEE ALSO" cdb_read(3), cdb_init(3), cdb_free(3), cdbmake(1)