diff options
author | Drew DeVault <sir@cmpwn.com> | 2016-06-05 18:24:12 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2016-06-05 18:24:12 -0400 |
commit | cb14f5f5765a71630ea3c4bd2143fcc1cd4a2e57 (patch) | |
tree | c77118e96612dad70c00d4c0528b4f3815105b04 /common/readline.c | |
parent | 17dbcb40dc3d2063efbb99ae17e8d1cc58e5b16e (diff) | |
parent | 230591fa4e4911ffbb38da2ee79650e62d98415f (diff) |
Merge pull request #699 from roosemberth/master
Sway: Configuration: Support for escaping line breaks.
Diffstat (limited to 'common/readline.c')
-rw-r--r-- | common/readline.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/common/readline.c b/common/readline.c index 76ed6926..5106172c 100644 --- a/common/readline.c +++ b/common/readline.c @@ -5,17 +5,24 @@ char *read_line(FILE *file) { size_t length = 0, size = 128; char *string = malloc(size); + char lastChar = '\0'; if (!string) { return NULL; } while (1) { int c = getc(file); + if (c == '\n' && lastChar == '\\'){ + --length; // Ignore last character. + lastChar = '\0'; + continue; + } if (c == EOF || c == '\n' || c == '\0') { break; } if (c == '\r') { continue; } + lastChar = c; if (length == size) { char *new_string = realloc(string, size *= 2); if (!new_string) { |