strbuf: introduce strbuf_getline_{lf,nul}()
authorJunio C Hamano <gitster@pobox.com>
Wed, 13 Jan 2016 23:31:17 +0000 (15:31 -0800)
committerJunio C Hamano <gitster@pobox.com>
Fri, 15 Jan 2016 18:12:51 +0000 (10:12 -0800)
commit8f309aeb8225a9c26f20c0dbc031f1ea8df75d49
treecc953334bfd3b2a0252a7e30154462ddaafcc4bc
parentc8aa9fdf5dc15e2c508acb22df03d431983569ed
strbuf: introduce strbuf_getline_{lf,nul}()

The strbuf_getline() interface allows a byte other than LF or NUL as
the line terminator, but this is only because I wrote these
codepaths anticipating that there might be a value other than NUL
and LF that could be useful when I introduced line_termination long
time ago.  No useful caller that uses other value has emerged.

By now, it is clear that the interface is overly broad without a
good reason.  Many codepaths have hardcoded preference to read
either LF terminated or NUL terminated records from their input, and
then call strbuf_getline() with LF or NUL as the third parameter.

This step introduces two thin wrappers around strbuf_getline(),
namely, strbuf_getline_lf() and strbuf_getline_nul(), and
mechanically rewrites these call sites to call either one of
them.  The changes contained in this patch are:

 * introduction of these two functions in strbuf.[ch]

 * mechanical conversion of all callers to strbuf_getline() with
   either '\n' or '\0' as the third parameter to instead call the
   respective thin wrapper.

After this step, output from "git grep 'strbuf_getline('" would
become a lot smaller.  An interim goal of this series is to make
this an empty set, so that we can have strbuf_getline_crlf() take
over the shorter name strbuf_getline().

Signed-off-by: Junio C Hamano <gitster@pobox.com>
36 files changed:
bisect.c
builtin/am.c
builtin/cat-file.c
builtin/check-mailmap.c
builtin/clean.c
builtin/clone.c
builtin/column.c
builtin/commit.c
builtin/fetch-pack.c
builtin/grep.c
builtin/hash-object.c
builtin/notes.c
builtin/pull.c
builtin/repack.c
builtin/rev-parse.c
builtin/send-pack.c
compat/terminal.c
credential-cache--daemon.c
credential-store.c
credential.c
daemon.c
fast-import.c
ident.c
mailinfo.c
remote-curl.c
remote-testsvn.c
remote.c
sequencer.c
sha1_file.c
shell.c
strbuf.c
strbuf.h
test-sha1-array.c
transport-helper.c
walker.c
wt-status.c