diff options
author | J. Bruce Fields <bfields@citi.umich.edu> | 2007-12-16 17:31:38 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-12-16 22:07:20 +0100 |
commit | 1020999a981e0dadedc475c41e33e20fd7832019 (patch) | |
tree | 0b0e1a7b4bb78e160a35ea9e2a2d10d8a081598d | |
parent | whitespace: fix off-by-one error in non-space-in-indent checking (diff) | |
download | git-1020999a981e0dadedc475c41e33e20fd7832019.tar.xz git-1020999a981e0dadedc475c41e33e20fd7832019.zip |
whitespace: reorganize initial-indent check
Reorganize to emphasize the most complicated part of the code (the tab
case).
Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r-- | ws.c | 15 |
1 files changed, 7 insertions, 8 deletions
@@ -146,16 +146,15 @@ unsigned check_and_emit_line(const char *line, int len, unsigned ws_rule, /* Check for space before tab in initial indent. */ for (i = 0; i < len; i++) { - if (line[i] == '\t') { - if ((ws_rule & WS_SPACE_BEFORE_TAB) && - (leading_space != -1)) - result |= WS_SPACE_BEFORE_TAB; - break; - } - else if (line[i] == ' ') + if (line[i] == ' ') { leading_space = i; - else + continue; + } + if (line[i] != '\t') break; + if ((ws_rule & WS_SPACE_BEFORE_TAB) && (leading_space != -1)) + result |= WS_SPACE_BEFORE_TAB; + break; } /* Check for indent using non-tab. */ |