aboutsummaryrefslogtreecommitdiff
path: root/libctf/testsuite
diff options
context:
space:
mode:
Diffstat (limited to 'libctf/testsuite')
-rw-r--r--libctf/testsuite/libctf-regression/type-add-unnamed-struct-ctf.c19
-rw-r--r--libctf/testsuite/libctf-regression/type-add-unnamed-struct.c72
-rw-r--r--libctf/testsuite/libctf-regression/type-add-unnamed-struct.lk3
3 files changed, 94 insertions, 0 deletions
diff --git a/libctf/testsuite/libctf-regression/type-add-unnamed-struct-ctf.c b/libctf/testsuite/libctf-regression/type-add-unnamed-struct-ctf.c
new file mode 100644
index 0000000..d319aaf
--- /dev/null
+++ b/libctf/testsuite/libctf-regression/type-add-unnamed-struct-ctf.c
@@ -0,0 +1,19 @@
+struct foo
+{
+ union
+ {
+ struct
+ {
+ int bar;
+ };
+ };
+ union
+ {
+ struct
+ {
+ int baz;
+ };
+ };
+};
+
+struct foo *bar;
diff --git a/libctf/testsuite/libctf-regression/type-add-unnamed-struct.c b/libctf/testsuite/libctf-regression/type-add-unnamed-struct.c
new file mode 100644
index 0000000..98be257
--- /dev/null
+++ b/libctf/testsuite/libctf-regression/type-add-unnamed-struct.c
@@ -0,0 +1,72 @@
+#include <ctf-api.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+int
+main (int argc, char *argv[])
+{
+ ctf_dict_t *fp;
+ ctf_archive_t *ctf;
+ ctf_dict_t *dyn;
+ ctf_next_t *i = NULL;
+ ctf_id_t type;
+ ctf_id_t newtype;
+ const char *memb;
+ ctf_membinfo_t mi;
+ const char *membs[] = { "bar", "baz", NULL };
+ const char **walk;
+ int err;
+
+ if (argc != 2)
+ {
+ fprintf (stderr, "Syntax: %s PROGRAM\n", argv[0]);
+ exit(1);
+ }
+
+ if ((ctf = ctf_open (argv[1], NULL, &err)) == NULL)
+ goto open_err;
+
+ if ((fp = ctf_dict_open (ctf, NULL, &err)) == NULL)
+ goto open_err;
+
+ if ((dyn = ctf_create (&err)) == NULL)
+ goto create_err;
+
+ /* Copy 'struct foo' into the dynamic dict, then make sure we can look up a
+ member situated inside an unnamed struct. */
+
+ if ((type = ctf_lookup_by_name (fp, "struct foo")) == CTF_ERR)
+ {
+ fprintf (stderr, "Cannot look up struct foo: %s\n", ctf_errmsg (ctf_errno (dyn)));
+ return 1;
+ }
+
+ if ((newtype = ctf_add_type (dyn, fp, type)) == CTF_ERR)
+ goto copy_err;
+
+ for (walk = membs; *walk != NULL; walk++)
+ {
+ if (ctf_member_info (dyn, newtype, *walk, &mi) < 0)
+ goto lookup_err;
+ printf ("Looked up %s, type %lx, offset %lx\n", *walk, (long) mi.ctm_type, mi.ctm_offset);
+ }
+
+ ctf_dict_close (dyn);
+ ctf_dict_close (fp);
+ ctf_close (ctf);
+
+ return 0;
+
+ open_err:
+ fprintf (stderr, "%s: cannot open: %s\n", argv[0], ctf_errmsg (err));
+ return 1;
+ create_err:
+ fprintf (stderr, "%s: cannot create: %s\n", argv[0], ctf_errmsg (err));
+ return 1;
+ copy_err:
+ fprintf (stderr, "Type addition failed: %s\n", ctf_errmsg (ctf_errno (dyn)));
+ return 1;
+ lookup_err:
+ fprintf (stderr, "Cannot look up %s: %s\n", *walk, ctf_errmsg (ctf_errno (dyn)));
+ return 1;
+}
diff --git a/libctf/testsuite/libctf-regression/type-add-unnamed-struct.lk b/libctf/testsuite/libctf-regression/type-add-unnamed-struct.lk
new file mode 100644
index 0000000..caa8934
--- /dev/null
+++ b/libctf/testsuite/libctf-regression/type-add-unnamed-struct.lk
@@ -0,0 +1,3 @@
+# source: type-add-unnamed-struct-ctf.c
+Looked up bar, type [0-9a-f]*, offset [0-9a-f]*
+Looked up baz, type [0-9a-f]*, offset [0-9a-f]*