veriexecctl_conf.l revision 1.9 1 1.1 blymn %{
2 1.9 elad /* $NetBSD: veriexecctl_conf.l,v 1.9 2006/11/28 22:22:03 elad Exp $ */
3 1.3 blymn
4 1.3 blymn /*-
5 1.8 elad * Copyright 2005 Elad Efrat <elad (at) NetBSD.org>
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.9 elad #include <prop/proplib.h>
46 1.9 elad
47 1.1 blymn #include "veriexecctl_parse.h"
48 1.3 blymn #include "veriexecctl.h"
49 1.1 blymn
50 1.3 blymn u_int64_t entries;
51 1.3 blymn char *filename;
52 1.3 blymn %}
53 1.1 blymn
54 1.3 blymn STRING [0-9a-zA-Z]+
55 1.1 blymn
56 1.3 blymn %%
57 1.1 blymn
58 1.3 blymn /* path */
59 1.3 blymn \/[^ \t]+ {
60 1.4 christos if ((yylval.string = strdup(yytext)) == NULL)
61 1.4 christos err(1, "Cannot allocate string");
62 1.4 christos return PATH;
63 1.3 blymn }
64 1.3 blymn
65 1.3 blymn /* string (fingerprint, type, options) */
66 1.3 blymn {STRING} {
67 1.4 christos if ((yylval.string = strdup(yytext)) == NULL)
68 1.4 christos err(1, "Cannot allocate string");
69 1.4 christos return STRING;
70 1.3 blymn }
71 1.3 blymn
72 1.3 blymn /* comments, white-outs */
73 1.3 blymn [ \t\r] |
74 1.3 blymn #.* ;
75 1.3 blymn #.*\n |
76 1.7 elad \\\n |
77 1.3 blymn ^\n { line++; }
78 1.3 blymn
79 1.3 blymn /* eol on a line with data. need a call to ioctl, return eol */
80 1.3 blymn \n {
81 1.3 blymn line++;
82 1.4 christos return EOL;
83 1.3 blymn }
84 1.1 blymn
85 1.6 elad "," {
86 1.6 elad return TOKEN_COMMA;
87 1.6 elad }
88 1.6 elad
89 1.3 blymn . { yyerror("Invalid character"); }
90 1.1 blymn
91 1.3 blymn %%
92 1.1 blymn
93 1.4 christos int
94 1.4 christos yywrap(void)
95 1.4 christos {
96 1.4 christos return 1;
97 1.1 blymn }
98 1.1 blymn
99 1.4 christos void
100 1.4 christos yyerror(const char *string)
101 1.4 christos {
102 1.5 blymn (void)fprintf(stderr, "%s: %s at \"%s\", line %zu\n", getprogname(),
103 1.4 christos string, yytext, line);
104 1.1 blymn }
105