/simpletypesystem/trunk

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/simpletypesystem/trunk
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
1
#include "SimpleTypeSystem.h"
2
#include "test_macros.h"
3
#include <stdlib.h>
48 by Gustav Hartvigsson
* Finnished SLinkedList.
4
#include <stdint.h>
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
5
#include <time.h>
6
75 by Gustav Hartvigsson
* New goal!
7
void for_each_print (SDynamicArray * self, sint item, sint * itt) {
8
  s_print ("The number is: %d on iteration: %d\n", item, (*itt));
9
  (*itt)++;
10
}
11
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
12
int test_dynamic_array (void) {
13
  setup_unit ();
14
  
15
  SDynamicArray * array = NULL;
16
  array = s_dynamic_array_new (20, NULL);
17
  
18
  test_case (array != NULL, "Array is not null");
19
  
20
  test_case (s_dynamic_array_size (array) == 20, "The array maximum size is 20");
21
  
22
  s_print ("Adding a random number to a random possision in the array"
23
           " (bettween 0 and 20).\n");
24
  
25
  srand(time(NULL));
26
  
75 by Gustav Hartvigsson
* New goal!
27
  sint r_n = rand ();
28
  sint r_p = rand () % 20;
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
29
  
48 by Gustav Hartvigsson
* Finnished SLinkedList.
30
  s_dynamic_array_set (array, r_p, (spointer)(intptr_t) r_n);
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
31
  
48 by Gustav Hartvigsson
* Finnished SLinkedList.
32
  test_case ((intptr_t) s_dynamic_array_get (array, r_p) == r_n,
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
33
             "The the inserted random number matches the generated number.");
34
  
35
  s_print ("Adding a number (12345) to index 21\n");
36
  
75 by Gustav Hartvigsson
* New goal!
37
  s_dynamic_array_set (array, 21, (spointer)(sint *) 12345);
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
38
  
39
  test_case (s_dynamic_array_size (array) > 20, "The new size is larger then the old size.");
40
  
41
  s_print ("Filling array with numbers: 0-32\n");
42
  
75 by Gustav Hartvigsson
* New goal!
43
  for (sint i = 0; i < s_dynamic_array_size (array); i++) {
48 by Gustav Hartvigsson
* Finnished SLinkedList.
44
    s_dynamic_array_set (array, i, (spointer)(intptr_t) i);
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
45
  }
75 by Gustav Hartvigsson
* New goal!
46
  for (sint i = 0; i < s_dynamic_array_size (array); i++) {
47
    sint got_val = (intptr_t) s_dynamic_array_get(array, i);
48
    test_case (got_val == i, "The stored value (%d) matches the expected value (%d).", i, got_val);
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
49
  }
50
  
75 by Gustav Hartvigsson
* New goal!
51
  sint itt = 0;
52
  s_print ("Printing array using a for-each function.\n");
53
  s_dynamic_array_for_each (array, (ForEachFunc)for_each_print, &itt);
54
  
48 by Gustav Hartvigsson
* Finnished SLinkedList.
55
  s_dynamic_array_free (array, FALSE);
56
  
47 by Gustav Hartvigsson
* Added a few skeletal functions to Callback.h
57
  end_unit ();
58
}