summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoruqs <uqs@FreeBSD.org>2010-06-11 15:55:18 +0000
committeruqs <uqs@FreeBSD.org>2010-06-11 15:55:18 +0000
commitd3cd19daf567a37050e836812749daaeb075fdb2 (patch)
treeb576795f25a06263340eca3b98aea82fcce5f21e
parent693ced2a4639e406f17a09ace2b38edb38d0f194 (diff)
downloadFreeBSD-src-d3cd19daf567a37050e836812749daaeb075fdb2.zip
FreeBSD-src-d3cd19daf567a37050e836812749daaeb075fdb2.tar.gz
iMFC r208484: Fix back references in substitute command for pax(1)
pax(1) was trying to copy the back-referenced data from the match pattern, not the matched data. Approved by: re (kib)
-rw-r--r--bin/pax/pat_rep.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/bin/pax/pat_rep.c b/bin/pax/pat_rep.c
index 83e07dd..62539a2 100644
--- a/bin/pax/pat_rep.c
+++ b/bin/pax/pat_rep.c
@@ -76,7 +76,7 @@ static char * range_match(char *, int);
#ifdef NET2_REGEX
static int resub(regexp *, char *, char *, char *);
#else
-static int resub(regex_t *, regmatch_t *, char *, char *, char *);
+static int resub(regex_t *, regmatch_t *, char *, char *, char *, char *);
#endif
/*
@@ -929,7 +929,7 @@ rep_name(char *name, int *nlen, int prnt)
# ifdef NET2_REGEX
if ((res = resub(pt->rcmp,pt->nstr,outpt,endpt)) < 0) {
# else
- if ((res = resub(&(pt->rcmp),pm,pt->nstr,outpt,endpt))
+ if ((res = resub(&(pt->rcmp),pm,inpt,pt->nstr,outpt,endpt))
< 0) {
# endif
if (prnt)
@@ -1071,7 +1071,7 @@ resub(regexp *prog, char *src, char *dest, char *destend)
*/
static int
-resub(regex_t *rp, regmatch_t *pm, char *src, char *dest,
+resub(regex_t *rp, regmatch_t *pm, char *orig, char *src, char *dest,
char *destend)
{
char *spt;
@@ -1121,7 +1121,7 @@ resub(regex_t *rp, regmatch_t *pm, char *src, char *dest,
*/
if (len > (destend - dpt))
len = destend - dpt;
- if (l_strncpy(dpt, src + pmpt->rm_so, len) != len)
+ if (l_strncpy(dpt, orig + pmpt->rm_so, len) != len)
return(-1);
dpt += len;
}
OpenPOWER on IntegriCloud