* [PATCH] Update documentation for stripspace @ 2011-12-12 1:59 Conrad Irwin 2011-12-12 6:41 ` Junio C Hamano 0 siblings, 1 reply; 6+ messages in thread From: Conrad Irwin @ 2011-12-12 1:59 UTC (permalink / raw) To: git; +Cc: Conrad Irwin Tell the user what this command is intended for, and expand the description of what it does. Stop referring to the input as <stream>, as this command reads the entire input into memory before processing it. Signed-off-by: Conrad Irwin <conrad.irwin@gmail.com> --- Documentation/git-stripspace.txt | 26 ++++++++++++++++++++------ builtin/stripspace.c | 2 +- 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/Documentation/git-stripspace.txt b/Documentation/git-stripspace.txt index b78f031..6667d25 100644 --- a/Documentation/git-stripspace.txt +++ b/Documentation/git-stripspace.txt @@ -3,26 +3,40 @@ git-stripspace(1) NAME ---- -git-stripspace - Filter out empty lines +git-stripspace - Remove unnecessary whitespace SYNOPSIS -------- [verse] -'git stripspace' [-s | --strip-comments] < <stream> +'git stripspace' [-s | --strip-comments] < input DESCRIPTION ----------- -Remove multiple empty lines, and empty lines at beginning and end. + +Normalizes input in the manner used by 'git' for user-provided metadata such +as commit messages, notes, tags and branch descriptions. + +When run with no arguments this: + +- removes trailing whitespace from all lines +- collapses multiple consecutive empty lines into one empty line +- removes blank lines from the beginning and end of the input +- ensures the last line ends with exactly one '\n'. + +In the case where the input consists entirely of whitespace characters, no +output will be produced. + +*NOTE*: This is intended for cleaning metadata, prefer the `--whitespace=fix` +mode of linkgit:git-apply[1] for correcting whitespace of patches or files in +the repository. OPTIONS ------- -s:: --strip-comments:: - In addition to empty lines, also strip lines starting with '#'. + Also remove all lines starting with '#'. -<stream>:: - Byte stream to act on. GIT --- diff --git a/builtin/stripspace.c b/builtin/stripspace.c index 1288ffc..f16986c 100644 --- a/builtin/stripspace.c +++ b/builtin/stripspace.c @@ -75,7 +75,7 @@ int cmd_stripspace(int argc, const char **argv, const char *prefix) !strcmp(argv[1], "--strip-comments"))) strip_comments = 1; else if (argc > 1) - usage("git stripspace [-s | --strip-comments] < <stream>"); + usage("git stripspace [-s | --strip-comments] < input"); if (strbuf_read(&buf, 0, 1024) < 0) die_errno("could not read the input"); -- 1.7.8.164.g00d7e ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] Update documentation for stripspace 2011-12-12 1:59 [PATCH] Update documentation for stripspace Conrad Irwin @ 2011-12-12 6:41 ` Junio C Hamano 2011-12-12 22:28 ` [PATCH v2] " Conrad Irwin 0 siblings, 1 reply; 6+ messages in thread From: Junio C Hamano @ 2011-12-12 6:41 UTC (permalink / raw) To: Conrad Irwin; +Cc: git Conrad Irwin <conrad.irwin@gmail.com> writes: > Tell the user what this command is intended for, and expand the > description of what it does. Thanks. > Stop referring to the input as <stream>, as this command reads the > entire input into memory before processing it. Which can change to stream, but calling it as input would not invalidate the new wording, so "input" is fine. From the caller's point of view, the current implementation (or streaming implementation) can read from an unseekable input stream (i.e. pipe), so the original wording is equally valid, by the way. So in that sense, it does not make any difference either way to me (it is not even worth rerolling this patch to only remove this part of the change). > Signed-off-by: Conrad Irwin <conrad.irwin@gmail.com> > --- > Documentation/git-stripspace.txt | 26 ++++++++++++++++++++------ > builtin/stripspace.c | 2 +- > 2 files changed, 21 insertions(+), 7 deletions(-) > > diff --git a/Documentation/git-stripspace.txt b/Documentation/git-stripspace.txt > index b78f031..6667d25 100644 > --- a/Documentation/git-stripspace.txt > +++ b/Documentation/git-stripspace.txt > @@ -3,26 +3,40 @@ git-stripspace(1) > > NAME > ---- > -git-stripspace - Filter out empty lines > +git-stripspace - Remove unnecessary whitespace > > > SYNOPSIS > -------- > [verse] > -'git stripspace' [-s | --strip-comments] < <stream> > +'git stripspace' [-s | --strip-comments] < input > > DESCRIPTION > ----------- > -Remove multiple empty lines, and empty lines at beginning and end. > + > +Normalizes input in the manner used by 'git' for user-provided metadata such > +as commit messages, notes, tags and branch descriptions. The original says "remove" and new one says "normalize*s*". I think we tend to say things in imperative mood (i.e. without the trailing "s"). I do not think 'user-provided metadata' is a good wording. This is just a simple text clean-up filter and you can use it to clean your text files that you mean to store in the repository as well. > +When run with no arguments this: > + > +- removes trailing whitespace from all lines > +- collapses multiple consecutive empty lines into one empty line > +- removes blank lines from the beginning and end of the input > +- ensures the last line ends with exactly one '\n'. Thanks for a nicely written bulleted list. It clarifies what the command does quite a bit. The last one is a bit funny, though. By definition, you cannot end the last line with more than one '\n' (upon seeing the second '\n', you would realize immediately that the line you saw was _not_ the last line). I think you meant the file does not end with an incomplete line, i.e. "ensures the output does not end with an incomplete line by adding '\n' at the end if needed". > +In the case where the input consists entirely of whitespace characters, no > +output will be produced. > + > +*NOTE*: This is intended for cleaning metadata, prefer the `--whitespace=fix` > +mode of linkgit:git-apply[1] for correcting whitespace of patches or files in > +the repository. I can tell that these three lines were the _primary_ thing you wanted to add with this patch, having never seen anybody got confused between the whitespace breakage fix and text cleaning, I wonder if this is adding clarity or giving users an impression that git can do too many things than they can wrap their mind around and forcing them to wonder if they have to learn everything git can do for them. > OPTIONS > ------- > -s:: > --strip-comments:: > - In addition to empty lines, also strip lines starting with '#'. > + Also remove all lines starting with '#'. With the resulting text (with the rules clarified with your above 4-bullet points) of this manual page, can a user tell what the command does to this input (I added line numbers, vertical bars and dollar signs to show where the beginning and the end of lines are): 1 | $ 2 |a b c$ 3 |$ 4 |# comment line$ 5 |$ 6 |d e f$ The original text at least allows the user to guess correctly, as it hints that a comment line is treated pretty much like an empty line, and the "consecutive empty lines are squashed into one" in your bulleted list would mean that ll 3-5 will become a single blank line. The new text however gives a wrong hint by saying "Also"; it can be read as if all the rules in the bullted list are applied first to leave blank lines at 3 and 5 and then comment line is removed from the result, which would leave two blank lines in the result. If I were touching this description, I probably would say something like "Treat lines starting with a '#' as if they are empty lines". ^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2] Update documentation for stripspace 2011-12-12 6:41 ` Junio C Hamano @ 2011-12-12 22:28 ` Conrad Irwin 2011-12-12 23:41 ` Junio C Hamano 2011-12-13 6:28 ` [PATCH v2] " Frans Klaver 0 siblings, 2 replies; 6+ messages in thread From: Conrad Irwin @ 2011-12-12 22:28 UTC (permalink / raw) To: Junio C Hamano; +Cc: git, Conrad Irwin On Sun, Dec 11, 2011 at 10:41 PM, Junio C Hamano <gitster@pobox.com> wrote: > Conrad Irwin <conrad.irwin@gmail.com> writes: > > The original says "remove" and new one says "normalize*s*". I think we > tend to say things in imperative mood (i.e. without the trailing "s"). Good point, fixed. > > I do not think 'user-provided metadata' is a good wording. This is just a > simple text clean-up filter and you can use it to clean your text files > that you mean to store in the repository as well. Changed just to "text", as that seems simpler. I've left the example uses as is, they were the prime reason for that sentence existing. > > The last one is a bit funny, though. > > By definition, you cannot end the last line with more than one '\n' (upon > seeing the second '\n', you would realize immediately that the line you > saw was _not_ the last line). I think you meant the file does not end with > an incomplete line, i.e. "ensures the output does not end with an > incomplete line by adding '\n' at the end if needed". Hmm, I'm not sure that's the best way of describing it — I've gone with: "add a missing '\n' to the last line if necessary.". > >> +In the case where the input consists entirely of whitespace characters, no >> +output will be produced. >> + >> +*NOTE*: This is intended for cleaning metadata, prefer the `--whitespace=fix` >> +mode of linkgit:git-apply[1] for correcting whitespace of patches or files in >> +the repository. > > I can tell that these three lines were the _primary_ thing you wanted to > add with this patch, having never seen anybody got confused between the > whitespace breakage fix and text cleaning, I wonder if this is adding > clarity or giving users an impression that git can do too many things than > they can wrap their mind around and forcing them to wonder if they have to > learn everything git can do for them. The motivation for this patch was an old post to the Cairo mailing list [1]. There they were using (previously undocumented) behaviour of git stripspace, instead of git apply --whitespace=fix (it may be that --whitespace=fix didn't exist at that point?). I've moved the *NOTE* into a SEE ALSO section where I think it reads less opinionatedly — is that better? > >> OPTIONS >> ------- >> -s:: >> --strip-comments:: >> - In addition to empty lines, also strip lines starting with '#'. >> + Also remove all lines starting with '#'. [snip] > > If I were touching this description, I probably would say something like > "Treat lines starting with a '#' as if they are empty lines". > If only it were that simple! If you have a commented line between two non-commented lines, then no empty line results. I've added an example to the re-rolled patch that show-cases the behaviour of comment stripping in both cases. I went with "skip and remove" as the verb, to imply that the lines are ignored by the previous transformations. Thanks for the detailed feedback. Conrad [1] http://lists.freedesktop.org/archives/cairo/2006-June/007062.html ----8<---- Tell the user what this command is intended for, and expand the description of what it does. Signed-off-by: Conrad Irwin <conrad.irwin@gmail.com> --- Documentation/git-stripspace.txt | 69 ++++++++++++++++++++++++++++++++++--- builtin/stripspace.c | 2 +- 2 files changed, 64 insertions(+), 7 deletions(-) diff --git a/Documentation/git-stripspace.txt b/Documentation/git-stripspace.txt index b78f031..a0a6ea4 100644 --- a/Documentation/git-stripspace.txt +++ b/Documentation/git-stripspace.txt @@ -3,26 +3,83 @@ git-stripspace(1) NAME ---- -git-stripspace - Filter out empty lines +git-stripspace - Remove unnecessary whitespace SYNOPSIS -------- [verse] -'git stripspace' [-s | --strip-comments] < <stream> +'git stripspace' [-s | --strip-comments] < input DESCRIPTION ----------- -Remove multiple empty lines, and empty lines at beginning and end. + +Clean the input in the manner used by 'git' for text such as commit +messages, notes, tags and branch descriptions. + +With no arguments, this will: + +- remove trailing whitespace from all lines +- collapse multiple consecutive empty lines into one empty line +- remove blank lines from the beginning and end of the input +- add a missing '\n' to the last line if necessary. + +In the case where the input consists entirely of whitespace characters, no +output will be produced. OPTIONS ------- -s:: --strip-comments:: - In addition to empty lines, also strip lines starting with '#'. + Skip and remove all lines starting with '#'. + +EXAMPLES +-------- + +Given the following noisy input with '$' indicating the end of a line: + +-------- +|A brief introduction $ +| $ +|$ +|A new paragraph$ +|# with a commented-out line $ +|explaining lots of stuff.$ +|$ +|# An old paragraph, also commented-out. $ +| $ +|The end.$ +| $ +--------- + +Use 'git stripspace' with no arguments to obtain: + +-------- +|A brief introduction$ +|$ +|A new paragraph$ +|# with a commented-out line$ +|explaining lots of stuff.$ +|$ +|# An old paragraph, also commented-out.$ +|$ +|The end.$ +--------- -<stream>:: - Byte stream to act on. +Use 'git stripspace --strip-comments' to obtain: + +-------- +|A brief introduction$ +|$ +|A new paragraph$ +|explaining lots of stuff.$ +|$ +|The end.$ +--------- + +SEE ALSO +-------- +The `--whitespace=fix` mode of linkgit:git-apply[1]. GIT --- diff --git a/builtin/stripspace.c b/builtin/stripspace.c index 1288ffc..f16986c 100644 --- a/builtin/stripspace.c +++ b/builtin/stripspace.c @@ -75,7 +75,7 @@ int cmd_stripspace(int argc, const char **argv, const char *prefix) !strcmp(argv[1], "--strip-comments"))) strip_comments = 1; else if (argc > 1) - usage("git stripspace [-s | --strip-comments] < <stream>"); + usage("git stripspace [-s | --strip-comments] < input"); if (strbuf_read(&buf, 0, 1024) < 0) die_errno("could not read the input"); -- 1.7.8.164.g00d7e ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH v2] Update documentation for stripspace 2011-12-12 22:28 ` [PATCH v2] " Conrad Irwin @ 2011-12-12 23:41 ` Junio C Hamano 2011-12-12 23:52 ` [PATCH] " Conrad Irwin 2011-12-13 6:28 ` [PATCH v2] " Frans Klaver 1 sibling, 1 reply; 6+ messages in thread From: Junio C Hamano @ 2011-12-12 23:41 UTC (permalink / raw) To: Conrad Irwin; +Cc: Junio C Hamano, git Conrad Irwin <conrad.irwin@gmail.com> writes: > ... > I've moved the *NOTE* into a SEE ALSO section where I think it reads > less opinionatedly ― is that better? I think it looks a lot worse. At least your original hinted that some people may confuse the two and the NOTE was there for such people; other people who would not even dream of such a confusion won't find the existence of the note a "Huh?". But the updated patch with a link in SEE ALSO section without any explanation would be a definite "Huh?" for those of us who find that stripspace does not have anything to do with what "apply --whitespace=fix" does. The new example section looks good. Perhaps we can just drop the extra SEE ALSO and resurrect the *NOTE* from your v1 patch. Thanks. ^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH] Update documentation for stripspace 2011-12-12 23:41 ` Junio C Hamano @ 2011-12-12 23:52 ` Conrad Irwin 0 siblings, 0 replies; 6+ messages in thread From: Conrad Irwin @ 2011-12-12 23:52 UTC (permalink / raw) To: Junio C Hamano; +Cc: git, Conrad Irwin 2011/12/12 Junio C Hamano <gitster@pobox.com>: > Conrad Irwin <conrad.irwin@gmail.com> writes: >> I've moved the *NOTE* into a SEE ALSO section where I think it reads >> less opinionatedly ― is that better? > > I think it looks a lot worse. [snip] > > The new example section looks good. Perhaps we can just drop the extra SEE > ALSO and resurrect the *NOTE* from your v1 patch. > > Thanks. Done. Conrad ---8<--- Tell the user what this command is intended for, and expand the description of what it does. Signed-off-by: Conrad Irwin <conrad.irwin@gmail.com> --- Documentation/git-stripspace.txt | 69 ++++++++++++++++++++++++++++++++++--- builtin/stripspace.c | 2 +- 2 files changed, 64 insertions(+), 7 deletions(-) diff --git a/Documentation/git-stripspace.txt b/Documentation/git-stripspace.txt index b78f031..a548444 100644 --- a/Documentation/git-stripspace.txt +++ b/Documentation/git-stripspace.txt @@ -3,26 +3,83 @@ git-stripspace(1) NAME ---- -git-stripspace - Filter out empty lines +git-stripspace - Remove unnecessary whitespace SYNOPSIS -------- [verse] -'git stripspace' [-s | --strip-comments] < <stream> +'git stripspace' [-s | --strip-comments] < input DESCRIPTION ----------- -Remove multiple empty lines, and empty lines at beginning and end. + +Clean the input in the manner used by 'git' for text such as commit +messages, notes, tags and branch descriptions. + +With no arguments, this will: + +- remove trailing whitespace from all lines +- collapse multiple consecutive empty lines into one empty line +- remove empty lines from the beginning and end of the input +- add a missing '\n' to the last line if necessary. + +In the case where the input consists entirely of whitespace characters, no +output will be produced. + +*NOTE*: This is intended for cleaning metadata, prefer the `--whitespace=fix` +mode of linkgit:git-apply[1] for correcting whitespace of patches or files in +the repository. OPTIONS ------- -s:: --strip-comments:: - In addition to empty lines, also strip lines starting with '#'. + Skip and remove all lines starting with '#'. + +EXAMPLES +-------- + +Given the following noisy input with '$' indicating the end of a line: -<stream>:: - Byte stream to act on. +-------- +|A brief introduction $ +| $ +|$ +|A new paragraph$ +|# with a commented-out line $ +|explaining lots of stuff.$ +|$ +|# An old paragraph, also commented-out. $ +| $ +|The end.$ +| $ +--------- + +Use 'git stripspace' with no arguments to obtain: + +-------- +|A brief introduction$ +|$ +|A new paragraph$ +|# with a commented-out line$ +|explaining lots of stuff.$ +|$ +|# An old paragraph, also commented-out.$ +|$ +|The end.$ +--------- + +Use 'git stripspace --strip-comments' to obtain: + +-------- +|A brief introduction$ +|$ +|A new paragraph$ +|explaining lots of stuff.$ +|$ +|The end.$ +--------- GIT --- diff --git a/builtin/stripspace.c b/builtin/stripspace.c index 1288ffc..f16986c 100644 --- a/builtin/stripspace.c +++ b/builtin/stripspace.c @@ -75,7 +75,7 @@ int cmd_stripspace(int argc, const char **argv, const char *prefix) !strcmp(argv[1], "--strip-comments"))) strip_comments = 1; else if (argc > 1) - usage("git stripspace [-s | --strip-comments] < <stream>"); + usage("git stripspace [-s | --strip-comments] < input"); if (strbuf_read(&buf, 0, 1024) < 0) die_errno("could not read the input"); -- 1.7.8.164.g00d7e ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH v2] Update documentation for stripspace 2011-12-12 22:28 ` [PATCH v2] " Conrad Irwin 2011-12-12 23:41 ` Junio C Hamano @ 2011-12-13 6:28 ` Frans Klaver 1 sibling, 0 replies; 6+ messages in thread From: Frans Klaver @ 2011-12-13 6:28 UTC (permalink / raw) To: Junio C Hamano, Conrad Irwin; +Cc: git On Mon, 12 Dec 2011 23:28:29 +0100, Conrad Irwin <conrad.irwin@gmail.com> wrote: >> an incomplete line, i.e. "ensures the output does not end with an >> incomplete line by adding '\n' at the end if needed". > > Hmm, I'm not sure that's the best way of describing it — I've gone with: > "add a missing '\n' to the last line if necessary.". In most editors/IDE's I know and that support this, this is called "ensure new-line at end of file". I find this wording clearer than the above two options. Cheers, Frans ^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2011-12-13 6:28 UTC | newest] Thread overview: 6+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2011-12-12 1:59 [PATCH] Update documentation for stripspace Conrad Irwin 2011-12-12 6:41 ` Junio C Hamano 2011-12-12 22:28 ` [PATCH v2] " Conrad Irwin 2011-12-12 23:41 ` Junio C Hamano 2011-12-12 23:52 ` [PATCH] " Conrad Irwin 2011-12-13 6:28 ` [PATCH v2] " Frans Klaver
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).