File: db.c

package info (click to toggle)
swig 1.1p5-1
  • links: PTS
  • area: main
  • in suites: hamm
  • size: 9,448 kB
  • ctags: 5,025
  • sloc: cpp: 21,599; ansic: 13,333; yacc: 3,297; python: 2,794; makefile: 2,197; perl: 1,984; tcl: 1,583; sh: 736; lisp: 201; objc: 143
file content (50 lines) | stat: -rw-r--r-- 1,039 bytes parent folder | download | duplicates (12)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#include "db.h"
#include <stdlib.h>
#include <string.h>

static int  nusers = 0;
static int  maxitems = 256;
static User *user_data = 0;

void add_user(User u) {
  if (!user_data) {
    user_data = (User *) malloc(maxitems*sizeof(User));
  }
  if (nusers == maxitems) {
    maxitems = maxitems*2;
    user_data = (User *) realloc(user_data,maxitems*sizeof(User));
  }
  user_data[nusers] = u;
  nusers++;
}

static int usercmp(const void *u1, const void *u2) {
  User *user1 = (User *) u1;
  User *user2 = (User *) u2;
  return (strcmp(user1->login,user2->login));
}

void sort_users() {
  qsort(user_data,nusers,sizeof(User),usercmp);
}

static int usersearch(const void *k, const void *u) {
  char *key = (char *) k;
  User *user = (User *) u;
  return (strcmp(key,user->login));
}

User *lookup_user(char *name) {
  User *u;
  u = (User *) bsearch(name,user_data, nusers, sizeof(User), usersearch);
  return u;
}

User *get_user(int i) {
  if (i >= nusers) return 0;
  else return &user_data[i];
}

int num_users() {
  return nusers;
}