Don't treat newline as pipe separator when processing substitutions.
This commit is contained in:
parent
19ec9ee91e
commit
20a3069ec0
5
hush.c
5
hush.c
@ -2010,7 +2010,10 @@ int parse_stream(o_string *dest, struct p_context *ctx,
|
|||||||
} else {
|
} else {
|
||||||
if (m==2) { /* unquoted IFS */
|
if (m==2) { /* unquoted IFS */
|
||||||
done_word(dest, ctx);
|
done_word(dest, ctx);
|
||||||
if (ch=='\n') done_pipe(ctx,PIPE_SEQ);
|
/* If we aren't performing a substitution, treat a newline as a
|
||||||
|
* command separator. */
|
||||||
|
if (end_trigger != '\0' && ch=='\n')
|
||||||
|
done_pipe(ctx,PIPE_SEQ);
|
||||||
}
|
}
|
||||||
if (ch == end_trigger && !dest->quote && ctx->w==RES_NONE) {
|
if (ch == end_trigger && !dest->quote && ctx->w==RES_NONE) {
|
||||||
debug_printf("leaving parse_stream\n");
|
debug_printf("leaving parse_stream\n");
|
||||||
|
@ -2010,7 +2010,10 @@ int parse_stream(o_string *dest, struct p_context *ctx,
|
|||||||
} else {
|
} else {
|
||||||
if (m==2) { /* unquoted IFS */
|
if (m==2) { /* unquoted IFS */
|
||||||
done_word(dest, ctx);
|
done_word(dest, ctx);
|
||||||
if (ch=='\n') done_pipe(ctx,PIPE_SEQ);
|
/* If we aren't performing a substitution, treat a newline as a
|
||||||
|
* command separator. */
|
||||||
|
if (end_trigger != '\0' && ch=='\n')
|
||||||
|
done_pipe(ctx,PIPE_SEQ);
|
||||||
}
|
}
|
||||||
if (ch == end_trigger && !dest->quote && ctx->w==RES_NONE) {
|
if (ch == end_trigger && !dest->quote && ctx->w==RES_NONE) {
|
||||||
debug_printf("leaving parse_stream\n");
|
debug_printf("leaving parse_stream\n");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user