File: testReplaceExisting.c

package info (click to toggle)
libfastjson 1.2304.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,144 kB
  • sloc: sh: 4,486; ansic: 4,464; makefile: 114
file content (97 lines) | stat: -rw-r--r-- 2,957 bytes parent folder | download | duplicates (6)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include "config.h"
#include <stdio.h>
#include <stdlib.h>
#include <stddef.h>
#include <string.h>

#include "../json.h"
#include "../debug.h"

/* this is a work-around until we manage to fix configure.ac */
#pragma GCC diagnostic ignored "-Wdeclaration-after-statement"

int main(int __attribute__((unused)) argc, char __attribute__((unused)) **argv)
{
	struct fjson_object_iterator it;
	struct fjson_object_iterator itEnd;
	const char *key;
	MC_SET_DEBUG(1);

	/*
	 * Check that replacing an existing object keeps the key valid,
	 * and that it keeps the order the same.
	 */
	fjson_object *my_object = fjson_object_new_object();
	fjson_object_object_add(my_object, "foo1", fjson_object_new_string("bar1"));
	fjson_object_object_add(my_object, "foo2", fjson_object_new_string("bar2"));
	fjson_object_object_add(my_object, "deleteme", fjson_object_new_string("bar2"));
	fjson_object_object_add(my_object, "foo3", fjson_object_new_string("bar3"));

	printf("==== delete-in-loop test starting ====\n");

	int orig_count = 0;
	itEnd = fjson_object_iter_end(my_object);
	it = fjson_object_iter_begin(my_object);
	while (!fjson_object_iter_equal(&it, &itEnd)) {
		key = fjson_object_iter_peek_name(&it);
		printf("Key at index %d is [%s]", orig_count, key);
		/* need to advance now, as del invalidates "it" */
		fjson_object_iter_next(&it);
		if (strcmp(key, "deleteme") == 0) {
			fjson_object_object_del(my_object, key);
			printf(" (deleted)\n");
		} else {
			printf(" (kept)\n");
		}
		orig_count++;
	}

	printf("==== replace-value first loop starting ====\n");

	const char *original_key = NULL;
	orig_count = 0;
	itEnd = fjson_object_iter_end(my_object);
	it = fjson_object_iter_begin(my_object);
	while (!fjson_object_iter_equal(&it, &itEnd)) {
		key = fjson_object_iter_peek_name(&it);
		/* need to advance now, as modify invalidates "it" */
		fjson_object_iter_next(&it);
		printf("Key at index %d is [%s]\n", orig_count, key);
		orig_count++;
		if (strcmp(key, "foo2") != 0)
			continue;
		printf("replacing value for key [%s]\n", key);
		original_key = key;
		fjson_object_object_add(my_object, key, fjson_object_new_string("zzz"));
	}

	printf("==== second loop starting ====\n");

	int new_count = 0;
	int retval = 0;
	itEnd = fjson_object_iter_end(my_object);
	it = fjson_object_iter_begin(my_object);
	while (!fjson_object_iter_equal(&it, &itEnd)) {
		key = fjson_object_iter_peek_name(&it);
		/* need to advance now, as modify invalidates "it" */
		fjson_object_iter_next(&it);
		printf("Key at index %d is [%s]\n", new_count, key);
		new_count++;
		if (strcmp(key, "foo2") != 0)
			continue;
		printf("pointer for key [%s] does %smatch\n", key,
		       (key == original_key) ? "" : "NOT ");
		if (key != original_key)
			retval = 1;
	}
	if (new_count != orig_count)
	{
		printf("mismatch between original count (%d) and new count (%d)\n",
		       orig_count, new_count);
		retval = 1;
	}

	fjson_object_put( my_object );

	return retval;
}