forked from zserge/partcl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtcl_test_subst.h
80 lines (69 loc) · 2.7 KB
/
tcl_test_subst.h
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
#ifndef TCL_TEST_SUBST_H
#define TCL_TEST_SUBST_H
static void check_eval(struct tcl *tcl, const char *s, char *expected) {
int destroy = 0;
if (tcl == NULL) {
struct tcl tmp;
tcl_init(&tmp);
tcl = &tmp;
destroy = 1;
}
if (tcl_eval(tcl, s, strlen(s) + 1) == FERROR) {
FAIL("eval returned error: %s, (%s)\n", tcl_string(tcl->result), s);
} else if (strcmp(tcl_string(tcl->result), expected) != 0) {
FAIL("Expected %s, but got %s. (%s)\n", expected, tcl_string(tcl->result),
s);
} else {
printf("OK: %s -> %s\n", s, expected);
}
if (destroy) {
tcl_destroy(tcl);
}
}
static void test_subst() {
printf("\n");
printf("###################\n");
printf("### SUBST TESTS ###\n");
printf("###################\n");
printf("\n");
check_eval(NULL, "subst hello", "hello");
check_eval(NULL, "subst {hello}", "hello");
check_eval(NULL, "subst {hello world}", "hello world");
check_eval(NULL, "subst {hello {world}}", "hello {world}");
check_eval(NULL, "subst $foo", "");
struct tcl tcl;
tcl_init(&tcl);
tcl_var(&tcl, "foo", tcl_alloc("bar", 3));
tcl_var(&tcl, "bar", tcl_alloc("baz", 3));
tcl_var(&tcl, "baz", tcl_alloc("Hello", 5));
check_eval(&tcl, "subst $foo", "bar");
check_eval(&tcl, "subst $foo[]$foo", "barbar");
check_eval(&tcl, "subst $$foo", "baz");
check_eval(&tcl, "subst [set $foo]", "baz");
check_eval(&tcl, "subst $[set $foo]", "Hello");
check_eval(&tcl, "subst $$$foo", "Hello");
tcl_destroy(&tcl);
check_eval(NULL, "subst {hello}{world}", "helloworld");
check_eval(NULL, "subst hello[subst world]", "helloworld");
check_eval(NULL, "subst hello[\n]world", "helloworld");
/* Example from Picol */
check_eval(NULL, "set a su; set b bst; $a$b Hello", "Hello");
/* This is an error in TCL, but works in Picol */
check_eval(NULL, "set foo {hello world}", "hello world");
check_eval(NULL,
"set foo {hello world}; set bar \"qux $foo\"; subst $foo$bar",
"hello worldqux hello world");
check_eval(NULL, "set a f; set b {o}; set $a$b$b [subst \"hello\"]; set foo",
"hello");
check_eval(NULL, "set {a \"b\"} hello; subst ${a \"b\"}", "hello");
check_eval(NULL, "set \"a b\" hello; subst ${a b}", "hello");
check_eval(NULL, "set q {\"}; set msg hello; subst $q$msg$q", "\"hello\"");
check_eval(NULL, "set q {\"}; subst $q[]hello[]$q", "\"hello\"");
check_eval(NULL, "set x {\n\thello\n}", "\n\thello\n");
/* Some puts commands */
check_eval(NULL, "puts {[}[]hello[]{]}", "[hello]");
check_eval(NULL, "puts {{hello}}", "{hello}");
/* XXX most command involving unpaired braces (e.g. in quotes) don't work
* because of the dirty list implementation */
}
#endif /* TCL_TEST_SUBST_H */