veriexecctl_conf.l revision 1.4 1 1.1 blymn %{
2 1.4 christos /* $NetBSD: veriexecctl_conf.l,v 1.4 2005/04/21 12:45:12 christos Exp $ */
3 1.3 blymn
4 1.3 blymn /*-
5 1.3 blymn * Copyright 2005 Elad Efrat <elad (at) bsd.org.il>
6 1.3 blymn * Copyright 2005 Brett Lymn <blymn (at) netbsd.org>
7 1.3 blymn *
8 1.3 blymn * All rights reserved.
9 1.3 blymn *
10 1.3 blymn * This code has been donated to The NetBSD Foundation by the Author.
11 1.3 blymn *
12 1.3 blymn * Redistribution and use in source and binary forms, with or without
13 1.3 blymn * modification, are permitted provided that the following conditions
14 1.3 blymn * are met:
15 1.3 blymn * 1. Redistributions of source code must retain the above copyright
16 1.3 blymn * notice, this list of conditions and the following disclaimer.
17 1.3 blymn * 2. The name of the author may not be used to endorse or promote products
18 1.3 blymn * derived from this software withough specific prior written permission
19 1.3 blymn *
20 1.3 blymn * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 1.3 blymn * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 1.3 blymn * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 1.3 blymn * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 1.3 blymn * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 1.3 blymn * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 1.3 blymn * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 1.3 blymn * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 1.3 blymn * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 1.3 blymn * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 1.1 blymn *
31 1.1 blymn *
32 1.1 blymn */
33 1.1 blymn
34 1.3 blymn #include <sys/param.h>
35 1.3 blymn #include <sys/types.h>
36 1.3 blymn #include <sys/queue.h>
37 1.3 blymn #include <sys/verified_exec.h>
38 1.3 blymn
39 1.1 blymn #include <stdio.h>
40 1.3 blymn #include <stdlib.h>
41 1.1 blymn #include <string.h>
42 1.3 blymn #include <unistd.h>
43 1.3 blymn #include <err.h>
44 1.3 blymn
45 1.1 blymn #include "veriexecctl_parse.h"
46 1.3 blymn #include "veriexecctl.h"
47 1.1 blymn
48 1.3 blymn u_int64_t entries;
49 1.3 blymn char *filename;
50 1.3 blymn %}
51 1.1 blymn
52 1.3 blymn STRING [0-9a-zA-Z]+
53 1.1 blymn
54 1.3 blymn %%
55 1.1 blymn
56 1.3 blymn /* path */
57 1.3 blymn \/[^ \t]+ {
58 1.4 christos if ((yylval.string = strdup(yytext)) == NULL)
59 1.4 christos err(1, "Cannot allocate string");
60 1.4 christos return PATH;
61 1.3 blymn }
62 1.3 blymn
63 1.3 blymn /* string (fingerprint, type, options) */
64 1.3 blymn {STRING} {
65 1.4 christos if ((yylval.string = strdup(yytext)) == NULL)
66 1.4 christos err(1, "Cannot allocate string");
67 1.4 christos return STRING;
68 1.3 blymn }
69 1.3 blymn
70 1.3 blymn
71 1.3 blymn /* comments, white-outs */
72 1.3 blymn [ \t\r] |
73 1.3 blymn #.* ;
74 1.3 blymn #.*\n |
75 1.3 blymn ^\n { line++; }
76 1.3 blymn
77 1.3 blymn /* eol on a line with data. need a call to ioctl, return eol */
78 1.3 blymn \n {
79 1.3 blymn line++;
80 1.4 christos return EOL;
81 1.3 blymn }
82 1.1 blymn
83 1.3 blymn . { yyerror("Invalid character"); }
84 1.1 blymn
85 1.3 blymn %%
86 1.1 blymn
87 1.4 christos int
88 1.4 christos yywrap(void)
89 1.4 christos {
90 1.4 christos return 1;
91 1.1 blymn }
92 1.1 blymn
93 1.4 christos void
94 1.4 christos yyerror(const char *string)
95 1.4 christos {
96 1.4 christos (void)fprintf(stderr, "%s: %s at \"%s\", line %d\n", getprogname(),
97 1.4 christos string, yytext, line);
98 1.1 blymn }
99