summaryrefslogtreecommitdiffstats
path: root/source/aparser/token.awk
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2000-05-17 06:53:21 +0000
committerAndrew Tridgell <tridge@samba.org>2000-05-17 06:53:21 +0000
commitab0beaf3573471fab1fda3358987b337811f99b7 (patch)
tree0f71b3b111d0edac038b9cbdbd6e6bce615104a9 /source/aparser/token.awk
parent1c3193aa1c1137734dc34ef2e6d62abb0609c30e (diff)
downloadsamba-ab0beaf3573471fab1fda3358987b337811f99b7.tar.gz
samba-ab0beaf3573471fab1fda3358987b337811f99b7.tar.xz
samba-ab0beaf3573471fab1fda3358987b337811f99b7.zip
- added typedefs
- added parse error checking - made parser more flexible
Diffstat (limited to 'source/aparser/token.awk')
-rw-r--r--source/aparser/token.awk92
1 files changed, 92 insertions, 0 deletions
diff --git a/source/aparser/token.awk b/source/aparser/token.awk
new file mode 100644
index 00000000000..a64700f5368
--- /dev/null
+++ b/source/aparser/token.awk
@@ -0,0 +1,92 @@
+# tokenise the input file
+
+function parse_error(msg) {
+ printf("PARSE ERROR: %s\nLine "NR" : "$0"\n", msg);
+ exit 1;
+}
+
+# ignore blank lines
+/^[ \t]*$/ {
+ next;
+}
+
+# ignore comments
+/^[ \t]*\#/ {
+ next;
+}
+
+# ignore C comments
+/^[ \t]*\/\*.*\*\// {
+ next;
+}
+
+/^[ \t]*module/ {
+ {if (module!="") parse_error("you can only specify one module name");}
+ start_module($2);
+ next;
+}
+
+{if (module=="") parse_error("you must specify the module name first");}
+
+/^[ \t]*typedef struct.*\{/ {
+ {if (current_struct!="") parse_error("you cannot have nested structures");}
+ start_struct($3);
+ next;
+}
+
+/^[ \t]*typedef.*;/ {
+ {if (current_struct!="") parse_error("typedefs must be global");}
+ split($0,a,"[ \t;]*");
+ parse_typedef(a[2], a[3]);
+ next;
+}
+
+/^[ \t]*struct.*\{/ {
+ {if (current_struct!="") parse_error("you cannot have nested structures");}
+ start_struct($2);
+ next;
+}
+
+{if (current_struct=="") parse_error("this must appear inside a structure");}
+
+/^[ \t]*union.*\{/ {
+ {if (current_union!="") parse_error("you cannot have nested unions");}
+ start_union($2);
+ next;
+}
+
+/^[ \t]*case.*;/ {
+ {if (current_union=="") parse_error("this must appear inide a union");}
+ split($0,a,"[ \t;]*");
+ parse_case(a[3],a[4],a[5]);
+ next;
+}
+
+/^[ \t]*\}$/ {
+ {if (current_union=="") parse_error("this must appear inside a union");}
+ end_union();
+ next;
+}
+
+{if (current_union!="") parse_error("this cannot appear inside a union");}
+
+/^[ \t]*\};/ {
+ end_struct("");
+ next;
+}
+
+/^[ \t]*\} .*;/ {
+ split($0,a,"[ \t;]*");
+ end_struct(a[2]);
+ next;
+}
+
+/^.*;/ {
+ split($0,a,"[ \t;]*");
+ add_struct_elem(a[2], a[3]);
+ next;
+}
+
+{
+ parse_error("Unknown construct.");
+}