query.c 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /*
  2. * search the network database for matches
  3. */
  4. #include <u.h>
  5. #include <libc.h>
  6. #include <bio.h>
  7. #include <ndb.h>
  8. void
  9. usage(void)
  10. {
  11. fprint(2, "usage: query attr value [returned attribute]\n");
  12. exits("usage");
  13. }
  14. void
  15. search(Ndb *db, char *attr, char *val, char *rattr)
  16. {
  17. char *p;
  18. Ndbs s;
  19. Ndbtuple *t, *nt;
  20. if(rattr){
  21. p = ndbgetvalue(db, &s, attr, val, rattr, nil);
  22. if(p){
  23. print("%s\n", p);
  24. free(p);
  25. }
  26. return;
  27. }
  28. t = ndbsearch(db, &s, attr, val);
  29. while(t){
  30. for(nt = t; nt; nt = nt->entry)
  31. print("%s=%s ", nt->attr, nt->val);
  32. print("\n");
  33. ndbfree(t);
  34. t = ndbsnext(&s, attr, val);
  35. }
  36. }
  37. void
  38. main(int argc, char **argv)
  39. {
  40. int reps = 1;
  41. char *rattr = nil, *dbfile = nil;
  42. Ndb *db;
  43. ARGBEGIN{
  44. case 'f':
  45. dbfile = ARGF();
  46. break;
  47. default:
  48. usage();
  49. }ARGEND;
  50. switch(argc){
  51. case 4:
  52. reps = atoi(argv[3]);
  53. /* fall through */
  54. case 3:
  55. rattr = argv[2];
  56. break;
  57. case 2:
  58. rattr = 0;
  59. break;
  60. default:
  61. usage();
  62. }
  63. db = ndbopen(dbfile);
  64. if(db == 0){
  65. fprint(2, "no db files\n");
  66. exits("no db");
  67. }
  68. while(reps--)
  69. search(db, argv[0], argv[1], rattr);
  70. ndbclose(db);
  71. exits(0);
  72. }