X-Git-Url: https://git.distorted.org.uk/~mdw/fwd/blobdiff_plain/9155ea97b695b6eb5fca1ee79f57b334f6c4ef53..d105b00f8fd71a064353bc17192fc4985726721a:/file.c diff --git a/file.c b/file.c index 47b4943..88b7666 100644 --- a/file.c +++ b/file.c @@ -230,7 +230,7 @@ static void file_fspec(fspec *f, scanner *sc) error(sc, "parse error, expected file descriptor"); } else { dstr d = DSTR_INIT; - conf_name(sc, '/', &d); + conf_fname(sc, &d); f->type = FTYPE_NAME; f->u.name = xstrdup(d.buf); dstr_destroy(&d); @@ -242,13 +242,15 @@ static void file_fspec(fspec *f, scanner *sc) static void file_read(fdata *f, scanner *sc) { file_fspec(&f->in, sc); - if (sc->t != ',') { + if (sc->t == ',') { + token(sc); + file_fspec(&f->out, sc); + } else { f->out = f->in; if (f->out.type == FTYPE_FD && f->out.u.fd == rstdin) f->out.u.fd = rstdout; - } else { - token(sc); - file_fspec(&f->out, sc); + else if (f->out.type == FTYPE_NAME) + f->out.u.name = xstrdup(f->in.u.name); } f->fa = fattr_global; f->fo = file_opts; @@ -488,7 +490,7 @@ static void fsource_attach(source *s, scanner *sc, target *t) ee->ops->close(ee); goto tidy; } - endpt_join(e, ee); + endpt_join(e, ee, fs->s.desc); /* --- Dispose of the source and target now --- */