summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: d511bd3)
raw | patch | inline | side by side (parent: d511bd3)
author | Chris Webb <chris@arachsys.com> | |
Fri, 2 Apr 2010 23:37:30 +0000 (00:37 +0100) | ||
committer | Junio C Hamano <gitster@pobox.com> | |
Sun, 4 Apr 2010 21:21:54 +0000 (14:21 -0700) |
If tab-in-indent is set, --whitespace=fix will ensure that any stray tabs in
the initial indent are expanded to the correct number of space characters.
Signed-off-by: Chris Webb <chris@arachsys.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
the initial indent are expanded to the correct number of space characters.
Signed-off-by: Chris Webb <chris@arachsys.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
ws.c | patch | blob | history |
index 897ff56a5fcdd0cb0ce8ca849763df0d29424dbb..d7b8c33f14195ba7ebe86bdbca2fea8f1b22ad37 100644 (file)
--- a/ws.c
+++ b/ws.c
@@ -360,6 +360,20 @@ void ws_fix_copy(struct strbuf *dst, const char *src, int len, unsigned ws_rule,
len -= last;
src += last;
fixed = 1;
+ } else if ((ws_rule & WS_TAB_IN_INDENT) && last_tab_in_indent >= 0) {
+ /* Expand tabs into spaces */
+ int last = last_tab_in_indent + 1;
+ for (i = 0; i < last; i++) {
+ if (src[i] == '\t')
+ do {
+ strbuf_addch(dst, ' ');
+ } while (dst->len % 8);
+ else
+ strbuf_addch(dst, src[i]);
+ }
+ len -= last;
+ src += last;
+ fixed = 1;
}
strbuf_add(dst, src, len);