veriexecctl_conf.l revision 1.10 1 1.1 blymn %{
2 1.10 elad /* $NetBSD: veriexecctl_conf.l,v 1.10 2006/11/29 14:28:30 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.10 elad
53 1.10 elad static char *dequote(const char *s)
54 1.10 elad {
55 1.10 elad size_t len;
56 1.10 elad const char *p;
57 1.10 elad char *buf, *q;
58 1.10 elad
59 1.10 elad len = 0;
60 1.10 elad p = s;
61 1.10 elad while (*p) {
62 1.10 elad if (*p == '\\' && *(p+1))
63 1.10 elad ++p;
64 1.10 elad ++len;
65 1.10 elad ++p;
66 1.10 elad }
67 1.10 elad
68 1.10 elad buf = malloc(len + 1);
69 1.10 elad if (buf == NULL)
70 1.10 elad return NULL;
71 1.10 elad
72 1.10 elad p = s;
73 1.10 elad q = buf;
74 1.10 elad while (*p) {
75 1.10 elad if (*p == '\\' && *(p+1))
76 1.10 elad ++p;
77 1.10 elad *q++ = *p++;
78 1.10 elad }
79 1.10 elad *q++ = '\0';
80 1.10 elad
81 1.10 elad return buf;
82 1.10 elad }
83 1.3 blymn %}
84 1.1 blymn
85 1.3 blymn STRING [0-9a-zA-Z]+
86 1.10 elad PCHAR (\\.|[^ \t])
87 1.1 blymn
88 1.3 blymn %%
89 1.1 blymn
90 1.3 blymn /* path */
91 1.10 elad \/{PCHAR}+ {
92 1.10 elad if ((yylval.string = dequote(yytext)) == NULL)
93 1.4 christos err(1, "Cannot allocate string");
94 1.4 christos return PATH;
95 1.3 blymn }
96 1.3 blymn
97 1.3 blymn /* string (fingerprint, type, options) */
98 1.3 blymn {STRING} {
99 1.4 christos if ((yylval.string = strdup(yytext)) == NULL)
100 1.4 christos err(1, "Cannot allocate string");
101 1.4 christos return STRING;
102 1.3 blymn }
103 1.3 blymn
104 1.3 blymn /* comments, white-outs */
105 1.3 blymn [ \t\r] |
106 1.3 blymn #.* ;
107 1.3 blymn #.*\n |
108 1.7 elad \\\n |
109 1.3 blymn ^\n { line++; }
110 1.3 blymn
111 1.3 blymn /* eol on a line with data. need a call to ioctl, return eol */
112 1.3 blymn \n {
113 1.3 blymn line++;
114 1.4 christos return EOL;
115 1.3 blymn }
116 1.1 blymn
117 1.6 elad "," {
118 1.6 elad return TOKEN_COMMA;
119 1.6 elad }
120 1.6 elad
121 1.3 blymn . { yyerror("Invalid character"); }
122 1.1 blymn
123 1.3 blymn %%
124 1.1 blymn
125 1.4 christos int
126 1.4 christos yywrap(void)
127 1.4 christos {
128 1.4 christos return 1;
129 1.1 blymn }
130 1.1 blymn
131 1.4 christos void
132 1.4 christos yyerror(const char *string)
133 1.4 christos {
134 1.5 blymn (void)fprintf(stderr, "%s: %s at \"%s\", line %zu\n", getprogname(),
135 1.4 christos string, yytext, line);
136 1.1 blymn }
137