diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2010-08-16 16:26:33 +0200 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-08-16 16:26:33 +0200 |
commit | 0d555fc951fa09b2f7efb4b445a468a4bcc262f1 (patch) | |
tree | 3354dfd48bd61168fb4245338cce00776341e266 | |
parent | f2860bf6d332cbbfd2d4d9afadb0148cf061fad2 (diff) | |
download | busybox-w32-0d555fc951fa09b2f7efb4b445a468a4bcc262f1.tar.gz busybox-w32-0d555fc951fa09b2f7efb4b445a468a4bcc262f1.tar.bz2 busybox-w32-0d555fc951fa09b2f7efb4b445a468a4bcc262f1.zip |
sed: make N command behave as in GNU sed
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | editors/sed.c | 14 | ||||
-rwxr-xr-x | testsuite/sed.tests | 14 |
2 files changed, 22 insertions, 6 deletions
diff --git a/editors/sed.c b/editors/sed.c index 7d6e7e79f..6cf54afe9 100644 --- a/editors/sed.c +++ b/editors/sed.c | |||
@@ -992,6 +992,8 @@ static void process_files(void) | |||
992 | } | 992 | } |
993 | 993 | ||
994 | /* actual sedding */ | 994 | /* actual sedding */ |
995 | //bb_error_msg("pattern_space:'%s' next_line:'%s' cmd:%c", | ||
996 | //pattern_space, next_line, sed_cmd->cmd); | ||
995 | switch (sed_cmd->cmd) { | 997 | switch (sed_cmd->cmd) { |
996 | 998 | ||
997 | /* Print line number */ | 999 | /* Print line number */ |
@@ -1118,10 +1120,16 @@ static void process_files(void) | |||
1118 | { | 1120 | { |
1119 | int len; | 1121 | int len; |
1120 | /* If no next line, jump to end of script and exit. */ | 1122 | /* If no next line, jump to end of script and exit. */ |
1123 | /* http://www.gnu.org/software/sed/manual/sed.html: | ||
1124 | * "Most versions of sed exit without printing anything | ||
1125 | * when the N command is issued on the last line of | ||
1126 | * a file. GNU sed prints pattern space before exiting | ||
1127 | * unless of course the -n command switch has been | ||
1128 | * specified. This choice is by design." | ||
1129 | */ | ||
1121 | if (next_line == NULL) { | 1130 | if (next_line == NULL) { |
1122 | free(next_line); | 1131 | //goto discard_line; |
1123 | next_line = NULL; | 1132 | goto discard_commands; /* GNU behavior */ |
1124 | goto discard_line; | ||
1125 | } | 1133 | } |
1126 | /* Append next_line, read new next_line. */ | 1134 | /* Append next_line, read new next_line. */ |
1127 | len = strlen(pattern_space); | 1135 | len = strlen(pattern_space); |
diff --git a/testsuite/sed.tests b/testsuite/sed.tests index 880fc2118..61551e31c 100755 --- a/testsuite/sed.tests +++ b/testsuite/sed.tests | |||
@@ -80,10 +80,18 @@ test x"$SKIP_KNOWN_BUGS" = x"" && { | |||
80 | # Query: how does this interact with no newline at EOF? | 80 | # Query: how does this interact with no newline at EOF? |
81 | testing "sed n (flushes pattern space, terminates early)" "sed -e 'n;p'" \ | 81 | testing "sed n (flushes pattern space, terminates early)" "sed -e 'n;p'" \ |
82 | "a\nb\nb\nc\n" "" "a\nb\nc\n" | 82 | "a\nb\nb\nc\n" "" "a\nb\nc\n" |
83 | # N does _not_ flush pattern space, therefore c is still in there @ script end. | ||
84 | testing "sed N (doesn't flush pattern space when terminating)" "sed -e 'N;p'" \ | ||
85 | "a\nb\na\nb\nc\n" "" "a\nb\nc\n" | ||
86 | } | 83 | } |
84 | # non-GNU sed: N does _not_ flush pattern space, therefore c is eaten @ script end | ||
85 | # GNU sed: N flushes pattern space, therefore c is printed too @ script end | ||
86 | testing "sed N (flushes pattern space (GNU behavior))" "sed -e 'N;p'" \ | ||
87 | "a\nb\na\nb\nc\n" "" "a\nb\nc\n" | ||
88 | |||
89 | testing "sed N test2" "sed ':a;N;s/\n/ /;ta'" \ | ||
90 | "a b c\n" "" "a\nb\nc\n" | ||
91 | |||
92 | testing "sed N test3" "sed 'N;s/\n/ /'" \ | ||
93 | "a b\nc\n" "" "a\nb\nc\n" | ||
94 | |||
87 | testing "sed address match newline" 'sed "/b/N;/b\\nc/i woo"' \ | 95 | testing "sed address match newline" 'sed "/b/N;/b\\nc/i woo"' \ |
88 | "a\nwoo\nb\nc\nd\n" "" "a\nb\nc\nd\n" | 96 | "a\nwoo\nb\nc\nd\n" "" "a\nb\nc\nd\n" |
89 | 97 | ||