ref: 6bb619c8db2867ddd9cd19c0aec05065f5ee0cae
dir: /emu/port/env.c/
#include "dat.h" #include "fns.h" #include "error.h" Egrp* newegrp(void) { Egrp *e; e = smalloc(sizeof(Egrp)); if (e == nil) error(Enomem); e->r.ref = 1; return e; } void closeegrp(Egrp *e) { Evalue *el, *nl; if(e == nil || decref(&e->r) != 0) return; for (el = e->entries; el != nil; el = nl) { free(el->var); if (el->val) free(el->val); nl = el->next; free(el); } free(e); } void egrpcpy(Egrp *to, Egrp *from) { Evalue *e, *ne, **last; last = &to->entries; qlock(&from->l); for (e = from->entries; e != nil; e = e->next) { ne = smalloc(sizeof(Evalue)); ne->var = smalloc(strlen(e->var)+1); strcpy(ne->var, e->var); if (e->val) { ne->val = smalloc(e->len); memmove(ne->val, e->val, e->len); ne->len = e->len; } ne->qid.path = ++to->path; *last = ne; last = &ne->next; } qunlock(&from->l); } void ksetenv(char *var, char *val, int conf) { Chan *c; char buf[2*KNAMELEN]; USED(conf); snprint(buf, sizeof(buf), "#e/%s", var); if(waserror()) return; c = namec(buf, Acreate, OWRITE, 0600); poperror(); if(!waserror()){ if(!waserror()){ devtab[c->type]->write(c, val, strlen(val), 0); poperror(); } poperror(); } cclose(c); }