diff options
author | Eric Andersen | 2004-05-26 10:03:33 +0000 |
---|---|---|
committer | Eric Andersen | 2004-05-26 10:03:33 +0000 |
commit | 9855548a77af4a5da971bed0632d21a141b84616 (patch) | |
tree | 0c4122fbd85c76c5bc244653a4eb82156c19f07f /editors/sed.c | |
parent | d4d01d2b9bc1452c6417864ea5b300d34088c19a (diff) | |
download | busybox-9855548a77af4a5da971bed0632d21a141b84616.zip busybox-9855548a77af4a5da971bed0632d21a141b84616.tar.gz |
Rob Landley writes:
add sed -r support.
I bumped into a couple of things that want to use extended regular expressions
in sed, and it really isn't that hard to add. Can't say I've extensively
tested it, but it's small and isn't going to break anything that doesn't use
it, so...
Rob
Diffstat (limited to 'editors/sed.c')
-rw-r--r-- | editors/sed.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/editors/sed.c b/editors/sed.c index 45574e8..3d68716 100644 --- a/editors/sed.c +++ b/editors/sed.c @@ -112,7 +112,7 @@ typedef struct sed_cmd_s { /* globals */ /* options */ -static int be_quiet = 0, in_place=0; +static int be_quiet = 0, in_place=0, regex_type=0; FILE *nonstdout; char *outname; @@ -298,7 +298,7 @@ static int get_address(char *my_str, int *linenum, regex_t ** regex) temp=copy_parsing_slashn(pos,next); *regex = (regex_t *) xmalloc(sizeof(regex_t)); - xregcomp(*regex, temp, REG_NEWLINE); + xregcomp(*regex, temp, regex_type|REG_NEWLINE); free(temp); /* Move position to next character after last delimiter */ pos+=(next+1); @@ -326,7 +326,7 @@ static int parse_file_cmd(sed_cmd_t * sed_cmd, const char *filecmdstr, char **re static int parse_subst_cmd(sed_cmd_t * const sed_cmd, char *substr) { - int cflags = 0; + int cflags = regex_type; char *match; int idx = 0; @@ -1115,12 +1115,15 @@ extern int sed_main(int argc, char **argv) #endif /* do normal option parsing */ - while ((opt = getopt(argc, argv, "ine:f:")) > 0) { + while ((opt = getopt(argc, argv, "irne:f:")) > 0) { switch (opt) { case 'i': in_place++; atexit(cleanup_outname); break; + case 'r': + regex_type|=REG_EXTENDED; + break; case 'n': be_quiet++; break; |