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
  
51
  
52
  
53
  
54
  
55
  
56
  
57
  
58
  
 
#pike __REAL_VERSION__ 
 
inherit __builtin.Sql.Result; 
 
array _values; 
 
void create(array res) { 
  if(!res || !arrayp(res)) 
    error("Bad argument.\n"); 
  _values = res; 
} 
 
int num_rows() { 
  return sizeof(_values); 
} 
 
int num_fields() { 
  return sizeof(_values[0]); 
} 
 
int eof() { 
  return index >= sizeof(_values); 
} 
 
// Only supports the name field. 
array(mapping(string:mixed)) fetch_fields() { 
  array(mapping(string:mixed)) res = allocate(sizeof(_values[0])); 
  int i; 
 
  foreach(sort(indices(_values[0])), string name) 
    res[i++] = ([ "name": name ]); 
 
  return res; 
} 
 
void seek(int skip) { 
  if(skip<0) error("Skip argument not positive.\n"); 
  index += skip; 
} 
 
int|array(string|int) fetch_row() { 
  array res; 
 
  if (index >= sizeof(_values)) 
    return 0; 
 
  sort(indices(_values[index]), res = values(_values[index])); 
  index++; 
  return res; 
} 
 
this_program next_result() 
{ 
  return 0; 
}