Blame


1 3d7e9092 2003-10-14 devnull #include <u.h>
2 3d7e9092 2003-10-14 devnull #include <libc.h>
3 32f69c36 2003-12-11 devnull #include <fcall.h>
4 32f69c36 2003-12-11 devnull #include <fs.h>
5 3d7e9092 2003-10-14 devnull #include "plumb.h"
6 3d7e9092 2003-10-14 devnull
7 3d7e9092 2003-10-14 devnull static char attrbuf[4096];
8 3d7e9092 2003-10-14 devnull
9 b7e6f415 2003-11-23 devnull char *home;
10 3d7e9092 2003-10-14 devnull
11 3d7e9092 2003-10-14 devnull static int
12 3d7e9092 2003-10-14 devnull Strlen(char *s)
13 3d7e9092 2003-10-14 devnull {
14 3d7e9092 2003-10-14 devnull if(s == nil)
15 3d7e9092 2003-10-14 devnull return 0;
16 3d7e9092 2003-10-14 devnull return strlen(s);
17 3d7e9092 2003-10-14 devnull }
18 3d7e9092 2003-10-14 devnull
19 3d7e9092 2003-10-14 devnull static char*
20 3d7e9092 2003-10-14 devnull Strcpy(char *s, char *t)
21 3d7e9092 2003-10-14 devnull {
22 3d7e9092 2003-10-14 devnull if(t == nil)
23 3d7e9092 2003-10-14 devnull return s;
24 3d7e9092 2003-10-14 devnull return strcpy(s, t) + strlen(t);
25 3d7e9092 2003-10-14 devnull }
26 3d7e9092 2003-10-14 devnull
27 3d7e9092 2003-10-14 devnull /* quote attribute value, if necessary */
28 3d7e9092 2003-10-14 devnull static char*
29 3d7e9092 2003-10-14 devnull quote(char *s)
30 3d7e9092 2003-10-14 devnull {
31 3d7e9092 2003-10-14 devnull char *t;
32 3d7e9092 2003-10-14 devnull int c;
33 3d7e9092 2003-10-14 devnull
34 3d7e9092 2003-10-14 devnull if(s == nil){
35 3d7e9092 2003-10-14 devnull attrbuf[0] = '\0';
36 3d7e9092 2003-10-14 devnull return attrbuf;
37 3d7e9092 2003-10-14 devnull }
38 3d7e9092 2003-10-14 devnull if(strpbrk(s, " '=\t") == nil)
39 3d7e9092 2003-10-14 devnull return s;
40 3d7e9092 2003-10-14 devnull t = attrbuf;
41 3d7e9092 2003-10-14 devnull *t++ = '\'';
42 3d7e9092 2003-10-14 devnull while(t < attrbuf+sizeof attrbuf-2){
43 3d7e9092 2003-10-14 devnull c = *s++;
44 3d7e9092 2003-10-14 devnull if(c == '\0')
45 3d7e9092 2003-10-14 devnull break;
46 3d7e9092 2003-10-14 devnull *t++ = c;
47 3d7e9092 2003-10-14 devnull if(c == '\'')
48 3d7e9092 2003-10-14 devnull *t++ = c;
49 3d7e9092 2003-10-14 devnull }
50 3d7e9092 2003-10-14 devnull *t++ = '\'';
51 3d7e9092 2003-10-14 devnull *t = '\0';
52 3d7e9092 2003-10-14 devnull return attrbuf;
53 3d7e9092 2003-10-14 devnull }
54 3d7e9092 2003-10-14 devnull
55 3d7e9092 2003-10-14 devnull char*
56 3d7e9092 2003-10-14 devnull plumbpackattr(Plumbattr *attr)
57 3d7e9092 2003-10-14 devnull {
58 3d7e9092 2003-10-14 devnull int n;
59 3d7e9092 2003-10-14 devnull Plumbattr *a;
60 3d7e9092 2003-10-14 devnull char *s, *t;
61 3d7e9092 2003-10-14 devnull
62 3d7e9092 2003-10-14 devnull if(attr == nil)
63 3d7e9092 2003-10-14 devnull return nil;
64 3d7e9092 2003-10-14 devnull n = 0;
65 3d7e9092 2003-10-14 devnull for(a=attr; a!=nil; a=a->next)
66 3d7e9092 2003-10-14 devnull n += Strlen(a->name) + 1 + Strlen(quote(a->value)) + 1;
67 3d7e9092 2003-10-14 devnull s = malloc(n);
68 3d7e9092 2003-10-14 devnull if(s == nil)
69 3d7e9092 2003-10-14 devnull return nil;
70 3d7e9092 2003-10-14 devnull t = s;
71 3d7e9092 2003-10-14 devnull *t = '\0';
72 3d7e9092 2003-10-14 devnull for(a=attr; a!=nil; a=a->next){
73 3d7e9092 2003-10-14 devnull if(t != s)
74 3d7e9092 2003-10-14 devnull *t++ = ' ';
75 3d7e9092 2003-10-14 devnull strcpy(t, a->name);
76 3d7e9092 2003-10-14 devnull strcat(t, "=");
77 3d7e9092 2003-10-14 devnull strcat(t, quote(a->value));
78 3d7e9092 2003-10-14 devnull t += strlen(t);
79 3d7e9092 2003-10-14 devnull }
80 3d7e9092 2003-10-14 devnull if(t > s+n)
81 3d7e9092 2003-10-14 devnull abort();
82 3d7e9092 2003-10-14 devnull return s;
83 3d7e9092 2003-10-14 devnull }
84 3d7e9092 2003-10-14 devnull
85 3d7e9092 2003-10-14 devnull char*
86 3d7e9092 2003-10-14 devnull plumblookup(Plumbattr *attr, char *name)
87 3d7e9092 2003-10-14 devnull {
88 3d7e9092 2003-10-14 devnull while(attr){
89 3d7e9092 2003-10-14 devnull if(strcmp(attr->name, name) == 0)
90 3d7e9092 2003-10-14 devnull return attr->value;
91 3d7e9092 2003-10-14 devnull attr = attr->next;
92 3d7e9092 2003-10-14 devnull }
93 3d7e9092 2003-10-14 devnull return nil;
94 3d7e9092 2003-10-14 devnull }
95 3d7e9092 2003-10-14 devnull
96 3d7e9092 2003-10-14 devnull char*
97 3d7e9092 2003-10-14 devnull plumbpack(Plumbmsg *m, int *np)
98 3d7e9092 2003-10-14 devnull {
99 3d7e9092 2003-10-14 devnull int n, ndata;
100 3d7e9092 2003-10-14 devnull char *buf, *p, *attr;
101 3d7e9092 2003-10-14 devnull
102 3d7e9092 2003-10-14 devnull ndata = m->ndata;
103 3d7e9092 2003-10-14 devnull if(ndata < 0)
104 3d7e9092 2003-10-14 devnull ndata = Strlen(m->data);
105 3d7e9092 2003-10-14 devnull attr = plumbpackattr(m->attr);
106 3d7e9092 2003-10-14 devnull n = Strlen(m->src)+1 + Strlen(m->dst)+1 + Strlen(m->wdir)+1 +
107 3d7e9092 2003-10-14 devnull Strlen(m->type)+1 + Strlen(attr)+1 + 16 + ndata;
108 3d7e9092 2003-10-14 devnull buf = malloc(n+1); /* +1 for '\0' */
109 3d7e9092 2003-10-14 devnull if(buf == nil){
110 3d7e9092 2003-10-14 devnull free(attr);
111 3d7e9092 2003-10-14 devnull return nil;
112 3d7e9092 2003-10-14 devnull }
113 3d7e9092 2003-10-14 devnull p = Strcpy(buf, m->src);
114 3d7e9092 2003-10-14 devnull *p++ = '\n';
115 3d7e9092 2003-10-14 devnull p = Strcpy(p, m->dst);
116 3d7e9092 2003-10-14 devnull *p++ = '\n';
117 3d7e9092 2003-10-14 devnull p = Strcpy(p, m->wdir);
118 3d7e9092 2003-10-14 devnull *p++ = '\n';
119 3d7e9092 2003-10-14 devnull p = Strcpy(p, m->type);
120 3d7e9092 2003-10-14 devnull *p++ = '\n';
121 3d7e9092 2003-10-14 devnull p = Strcpy(p, attr);
122 3d7e9092 2003-10-14 devnull *p++ = '\n';
123 3d7e9092 2003-10-14 devnull p += sprint(p, "%d\n", ndata);
124 3d7e9092 2003-10-14 devnull memmove(p, m->data, ndata);
125 3d7e9092 2003-10-14 devnull *np = (p-buf)+ndata;
126 3d7e9092 2003-10-14 devnull buf[*np] = '\0'; /* null terminate just in case */
127 3d7e9092 2003-10-14 devnull if(*np >= n+1)
128 3d7e9092 2003-10-14 devnull abort();
129 3d7e9092 2003-10-14 devnull free(attr);
130 3d7e9092 2003-10-14 devnull return buf;
131 3d7e9092 2003-10-14 devnull }
132 3d7e9092 2003-10-14 devnull
133 3d7e9092 2003-10-14 devnull static int
134 3d7e9092 2003-10-14 devnull plumbline(char **linep, char *buf, int i, int n, int *bad)
135 3d7e9092 2003-10-14 devnull {
136 3d7e9092 2003-10-14 devnull int starti;
137 3d7e9092 2003-10-14 devnull char *p;
138 3d7e9092 2003-10-14 devnull
139 3d7e9092 2003-10-14 devnull if(*bad)
140 3d7e9092 2003-10-14 devnull return i;
141 3d7e9092 2003-10-14 devnull starti = i;
142 3d7e9092 2003-10-14 devnull while(i<n && buf[i]!='\n')
143 3d7e9092 2003-10-14 devnull i++;
144 3d7e9092 2003-10-14 devnull if(i == n)
145 3d7e9092 2003-10-14 devnull *bad = 1;
146 3d7e9092 2003-10-14 devnull else{
147 3d7e9092 2003-10-14 devnull p = malloc((i-starti) + 1);
148 3d7e9092 2003-10-14 devnull if(p == nil)
149 3d7e9092 2003-10-14 devnull *bad = 1;
150 3d7e9092 2003-10-14 devnull else{
151 3d7e9092 2003-10-14 devnull memmove(p, buf+starti, i-starti);
152 3d7e9092 2003-10-14 devnull p[i-starti] = '\0';
153 3d7e9092 2003-10-14 devnull }
154 3d7e9092 2003-10-14 devnull *linep = p;
155 3d7e9092 2003-10-14 devnull i++;
156 3d7e9092 2003-10-14 devnull }
157 3d7e9092 2003-10-14 devnull return i;
158 3d7e9092 2003-10-14 devnull }
159 3d7e9092 2003-10-14 devnull
160 3d7e9092 2003-10-14 devnull void
161 3d7e9092 2003-10-14 devnull plumbfree(Plumbmsg *m)
162 3d7e9092 2003-10-14 devnull {
163 3d7e9092 2003-10-14 devnull Plumbattr *a, *next;
164 3d7e9092 2003-10-14 devnull
165 3d7e9092 2003-10-14 devnull free(m->src);
166 3d7e9092 2003-10-14 devnull free(m->dst);
167 3d7e9092 2003-10-14 devnull free(m->wdir);
168 3d7e9092 2003-10-14 devnull free(m->type);
169 3d7e9092 2003-10-14 devnull for(a=m->attr; a!=nil; a=next){
170 3d7e9092 2003-10-14 devnull next = a->next;
171 3d7e9092 2003-10-14 devnull free(a->name);
172 3d7e9092 2003-10-14 devnull free(a->value);
173 3d7e9092 2003-10-14 devnull free(a);
174 3d7e9092 2003-10-14 devnull }
175 3d7e9092 2003-10-14 devnull free(m->data);
176 3d7e9092 2003-10-14 devnull free(m);
177 3d7e9092 2003-10-14 devnull }
178 3d7e9092 2003-10-14 devnull
179 3d7e9092 2003-10-14 devnull Plumbattr*
180 3d7e9092 2003-10-14 devnull plumbunpackattr(char *p)
181 3d7e9092 2003-10-14 devnull {
182 3d7e9092 2003-10-14 devnull Plumbattr *attr, *prev, *a;
183 3d7e9092 2003-10-14 devnull char *q, *v;
184 3d7e9092 2003-10-14 devnull int c, quoting;
185 3d7e9092 2003-10-14 devnull
186 3d7e9092 2003-10-14 devnull attr = prev = nil;
187 3d7e9092 2003-10-14 devnull while(*p!='\0' && *p!='\n'){
188 3d7e9092 2003-10-14 devnull while(*p==' ' || *p=='\t')
189 3d7e9092 2003-10-14 devnull p++;
190 3d7e9092 2003-10-14 devnull if(*p == '\0')
191 3d7e9092 2003-10-14 devnull break;
192 3d7e9092 2003-10-14 devnull for(q=p; *q!='\0' && *q!='\n' && *q!=' ' && *q!='\t'; q++)
193 3d7e9092 2003-10-14 devnull if(*q == '=')
194 3d7e9092 2003-10-14 devnull break;
195 3d7e9092 2003-10-14 devnull if(*q != '=')
196 3d7e9092 2003-10-14 devnull break; /* malformed attribute */
197 3d7e9092 2003-10-14 devnull a = malloc(sizeof(Plumbattr));
198 3d7e9092 2003-10-14 devnull if(a == nil)
199 3d7e9092 2003-10-14 devnull break;
200 3d7e9092 2003-10-14 devnull a->name = malloc(q-p+1);
201 3d7e9092 2003-10-14 devnull if(a->name == nil){
202 3d7e9092 2003-10-14 devnull free(a);
203 3d7e9092 2003-10-14 devnull break;
204 3d7e9092 2003-10-14 devnull }
205 3d7e9092 2003-10-14 devnull memmove(a->name, p, q-p);
206 3d7e9092 2003-10-14 devnull a->name[q-p] = '\0';
207 3d7e9092 2003-10-14 devnull /* process quotes in value */
208 3d7e9092 2003-10-14 devnull q++; /* skip '=' */
209 3d7e9092 2003-10-14 devnull v = attrbuf;
210 3d7e9092 2003-10-14 devnull quoting = 0;
211 3d7e9092 2003-10-14 devnull while(*q!='\0' && *q!='\n'){
212 3d7e9092 2003-10-14 devnull if(v >= attrbuf+sizeof attrbuf)
213 3d7e9092 2003-10-14 devnull break;
214 3d7e9092 2003-10-14 devnull c = *q++;
215 3d7e9092 2003-10-14 devnull if(quoting){
216 3d7e9092 2003-10-14 devnull if(c == '\''){
217 3d7e9092 2003-10-14 devnull if(*q == '\'')
218 3d7e9092 2003-10-14 devnull q++;
219 3d7e9092 2003-10-14 devnull else{
220 3d7e9092 2003-10-14 devnull quoting = 0;
221 3d7e9092 2003-10-14 devnull continue;
222 3d7e9092 2003-10-14 devnull }
223 3d7e9092 2003-10-14 devnull }
224 3d7e9092 2003-10-14 devnull }else{
225 3d7e9092 2003-10-14 devnull if(c==' ' || c=='\t')
226 3d7e9092 2003-10-14 devnull break;
227 3d7e9092 2003-10-14 devnull if(c == '\''){
228 3d7e9092 2003-10-14 devnull quoting = 1;
229 3d7e9092 2003-10-14 devnull continue;
230 3d7e9092 2003-10-14 devnull }
231 3d7e9092 2003-10-14 devnull }
232 3d7e9092 2003-10-14 devnull *v++ = c;
233 3d7e9092 2003-10-14 devnull }
234 3d7e9092 2003-10-14 devnull a->value = malloc(v-attrbuf+1);
235 3d7e9092 2003-10-14 devnull if(a->value == nil){
236 3d7e9092 2003-10-14 devnull free(a->name);
237 3d7e9092 2003-10-14 devnull free(a);
238 3d7e9092 2003-10-14 devnull break;
239 3d7e9092 2003-10-14 devnull }
240 3d7e9092 2003-10-14 devnull memmove(a->value, attrbuf, v-attrbuf);
241 3d7e9092 2003-10-14 devnull a->value[v-attrbuf] = '\0';
242 3d7e9092 2003-10-14 devnull a->next = nil;
243 3d7e9092 2003-10-14 devnull if(prev == nil)
244 3d7e9092 2003-10-14 devnull attr = a;
245 3d7e9092 2003-10-14 devnull else
246 3d7e9092 2003-10-14 devnull prev->next = a;
247 3d7e9092 2003-10-14 devnull prev = a;
248 3d7e9092 2003-10-14 devnull p = q;
249 3d7e9092 2003-10-14 devnull }
250 3d7e9092 2003-10-14 devnull return attr;
251 3d7e9092 2003-10-14 devnull }
252 3d7e9092 2003-10-14 devnull
253 3d7e9092 2003-10-14 devnull Plumbattr*
254 3d7e9092 2003-10-14 devnull plumbaddattr(Plumbattr *attr, Plumbattr *new)
255 3d7e9092 2003-10-14 devnull {
256 3d7e9092 2003-10-14 devnull Plumbattr *l;
257 3d7e9092 2003-10-14 devnull
258 3d7e9092 2003-10-14 devnull l = attr;
259 3d7e9092 2003-10-14 devnull if(l == nil)
260 3d7e9092 2003-10-14 devnull return new;
261 3d7e9092 2003-10-14 devnull while(l->next != nil)
262 3d7e9092 2003-10-14 devnull l = l->next;
263 3d7e9092 2003-10-14 devnull l->next = new;
264 3d7e9092 2003-10-14 devnull return attr;
265 3d7e9092 2003-10-14 devnull }
266 3d7e9092 2003-10-14 devnull
267 3d7e9092 2003-10-14 devnull Plumbattr*
268 3d7e9092 2003-10-14 devnull plumbdelattr(Plumbattr *attr, char *name)
269 3d7e9092 2003-10-14 devnull {
270 3d7e9092 2003-10-14 devnull Plumbattr *l, *prev;
271 3d7e9092 2003-10-14 devnull
272 3d7e9092 2003-10-14 devnull prev = nil;
273 3d7e9092 2003-10-14 devnull for(l=attr; l!=nil; l=l->next){
274 3d7e9092 2003-10-14 devnull if(strcmp(name, l->name) == 0)
275 3d7e9092 2003-10-14 devnull break;
276 3d7e9092 2003-10-14 devnull prev = l;
277 3d7e9092 2003-10-14 devnull }
278 3d7e9092 2003-10-14 devnull if(l == nil)
279 3d7e9092 2003-10-14 devnull return nil;
280 3d7e9092 2003-10-14 devnull if(prev)
281 3d7e9092 2003-10-14 devnull prev->next = l->next;
282 3d7e9092 2003-10-14 devnull else
283 3d7e9092 2003-10-14 devnull attr = l->next;
284 3d7e9092 2003-10-14 devnull free(l->name);
285 3d7e9092 2003-10-14 devnull free(l->value);
286 3d7e9092 2003-10-14 devnull free(l);
287 3d7e9092 2003-10-14 devnull return attr;
288 3d7e9092 2003-10-14 devnull }
289 3d7e9092 2003-10-14 devnull
290 3d7e9092 2003-10-14 devnull Plumbmsg*
291 3d7e9092 2003-10-14 devnull plumbunpackpartial(char *buf, int n, int *morep)
292 3d7e9092 2003-10-14 devnull {
293 3d7e9092 2003-10-14 devnull Plumbmsg *m;
294 3d7e9092 2003-10-14 devnull int i, bad;
295 3d7e9092 2003-10-14 devnull char *ntext, *attr;
296 3d7e9092 2003-10-14 devnull
297 3d7e9092 2003-10-14 devnull m = malloc(sizeof(Plumbmsg));
298 3d7e9092 2003-10-14 devnull if(m == nil)
299 3d7e9092 2003-10-14 devnull return nil;
300 3d7e9092 2003-10-14 devnull memset(m, 0, sizeof(Plumbmsg));
301 3d7e9092 2003-10-14 devnull if(morep != nil)
302 3d7e9092 2003-10-14 devnull *morep = 0;
303 3d7e9092 2003-10-14 devnull bad = 0;
304 3d7e9092 2003-10-14 devnull i = plumbline(&m->src, buf, 0, n, &bad);
305 3d7e9092 2003-10-14 devnull i = plumbline(&m->dst, buf, i, n, &bad);
306 3d7e9092 2003-10-14 devnull i = plumbline(&m->wdir, buf, i, n, &bad);
307 3d7e9092 2003-10-14 devnull i = plumbline(&m->type, buf, i, n, &bad);
308 3d7e9092 2003-10-14 devnull i = plumbline(&attr, buf, i, n, &bad);
309 3d7e9092 2003-10-14 devnull m->attr = plumbunpackattr(attr);
310 3d7e9092 2003-10-14 devnull free(attr);
311 3d7e9092 2003-10-14 devnull i = plumbline(&ntext, buf, i, n, &bad);
312 3d7e9092 2003-10-14 devnull m->ndata = atoi(ntext);
313 3d7e9092 2003-10-14 devnull if(m->ndata != n-i){
314 3d7e9092 2003-10-14 devnull bad = 1;
315 3d7e9092 2003-10-14 devnull if(morep!=nil && m->ndata>n-i)
316 3d7e9092 2003-10-14 devnull *morep = m->ndata - (n-i);
317 3d7e9092 2003-10-14 devnull }
318 3d7e9092 2003-10-14 devnull free(ntext);
319 3d7e9092 2003-10-14 devnull if(!bad){
320 3d7e9092 2003-10-14 devnull m->data = malloc(n-i+1); /* +1 for '\0' */
321 3d7e9092 2003-10-14 devnull if(m->data == nil)
322 3d7e9092 2003-10-14 devnull bad = 1;
323 3d7e9092 2003-10-14 devnull else{
324 3d7e9092 2003-10-14 devnull memmove(m->data, buf+i, m->ndata);
325 3d7e9092 2003-10-14 devnull m->ndata = n-i;
326 3d7e9092 2003-10-14 devnull /* null-terminate in case it's text */
327 3d7e9092 2003-10-14 devnull m->data[m->ndata] = '\0';
328 3d7e9092 2003-10-14 devnull }
329 3d7e9092 2003-10-14 devnull }
330 3d7e9092 2003-10-14 devnull if(bad){
331 3d7e9092 2003-10-14 devnull plumbfree(m);
332 3d7e9092 2003-10-14 devnull m = nil;
333 3d7e9092 2003-10-14 devnull }
334 3d7e9092 2003-10-14 devnull return m;
335 3d7e9092 2003-10-14 devnull }
336 3d7e9092 2003-10-14 devnull
337 3d7e9092 2003-10-14 devnull Plumbmsg*
338 3d7e9092 2003-10-14 devnull plumbunpack(char *buf, int n)
339 3d7e9092 2003-10-14 devnull {
340 3d7e9092 2003-10-14 devnull return plumbunpackpartial(buf, n, nil);
341 3d7e9092 2003-10-14 devnull }
342 3d7e9092 2003-10-14 devnull