On 12/02/10 00:05, Pádraig Brady wrote:
I had been trying this which seems to handle both:
grep -E " {2,6}-.*[^.] [A-Z][a-z]" *.c
Searching man files allows us to take advantage of the extra
formatting to catch all cases (even though there currently any
extra found by this):
grep -E '^\\fB\\-' -A1 man/*.1 | grep '\.1.[A-Z][a-z]'
I'll play around with it some more and come up with something.
I've added a syntax-check rule to grep the man pages
for --options with descriptions with initial uppercase letters
in the attached.
cheers,
Pádraig.
>From f8e1a2005ef5f23d9b381080944f1385a3b60e4b Mon Sep 17 00:00:00 2001
From: =?utf-8?q?P=C3=A1draig=20Brady?= <p...@draigbrady.com>
Date: Fri, 12 Feb 2010 15:19:15 +0000
Subject: [PATCH] doc: fix inconsistent capitalization in --help output
* src/base64.c (usage): Don't capitalize the first character
in an --option description.
* src/stdbuf.c (usage): Likewise.
* src/truncate.c (usage): Likewise.
* cfg.mk (sc_option_desc_uppercase): A new syntax check to
stop this happening in future.
* man/Makefile.am (sc_option_desc_uppercase): Ensure all
man pages are generated and search for erroneous uppercase chars.
* src/Makefile.am (sc_option_desc_uppercase): Ensure all
commands are built so that all man pages can be generated.
---
cfg.mk | 8 ++++++++
man/Makefile.am | 7 +++++++
src/Makefile.am | 5 +++++
src/base64.c | 6 +++---
src/stdbuf.c | 6 +++---
src/truncate.c | 2 +-
6 files changed, 27 insertions(+), 7 deletions(-)
diff --git a/cfg.mk b/cfg.mk
index b5a21c3..dd6da25 100644
--- a/cfg.mk
+++ b/cfg.mk
@@ -171,6 +171,14 @@ ALL_RECURSIVE_TARGETS += sc_check-AUTHORS
sc_check-AUTHORS:
@$(MAKE) -C src $@
+# Option descriptions should not start with a capital letter
+# One could grep source directly as follows:
+# grep -E " {2,6}-.*[^.] [A-Z][a-z]" $$($(VC_LIST_EXCEPT) | grep '\.c$$')
+# but that would miss descriptions not on the same line as the -option.
+sc_option_desc_uppercase:
+ @$(MAKE) -C src $@
+ @$(MAKE) -C man $@
+
# Perl-based tests used to exec perl from a #!/bin/sh script.
# Now they all start with #!/usr/bin/perl and the portability
# infrastructure is in tests/Makefile.am. Make sure no old-style
diff --git a/man/Makefile.am b/man/Makefile.am
index 904b302..7cebbf1 100644
--- a/man/Makefile.am
+++ b/man/Makefile.am
@@ -173,6 +173,13 @@ mapped_name = `echo $*|sed 's/^install$$/ginstall/; s/^test$$/[/'`
;; \
esac
+# Option descriptions should not start with a capital letter
+.PHONY: sc_option_desc_uppercase
+sc_option_desc_uppercase: $(dist_man1_MANS) $(NO_INSTALL_PROGS_DEFAULT:%=%.1)
+ @grep '^\\fB\\-' -A1 *.1 | LC_ALL=C grep '\.1.[A-Z][a-z]' && \
+ { echo 1>&2 '$(ME): found initial capitals in --help'; \
+ exit 1; } || :;
+
distcheck-hook: check-x-vs-1 check-programs-vs-x
# Sort in traditional ASCII order, regardless of the current locale;
diff --git a/src/Makefile.am b/src/Makefile.am
index c73f7dc..b6d5926 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -665,6 +665,11 @@ check-README:
check-duplicate-no-install: tr
$(AM_V_GEN)test -z "`echo '$(EXTRA_PROGRAMS)'| ./tr ' ' '\n' | uniq -d`"
+# Ensure that all programs are built so that
+# we can later check all man pages.
+.PHONY: sc_option_desc_uppercase
+sc_option_desc_uppercase: $(all_programs)
+
# Ensure that the list of programs and author names is accurate.
# We need a UTF8 locale. If a lack of locale support or a missing
# translation inhibits printing of UTF-8 names, just skip this test.
diff --git a/src/base64.c b/src/base64.c
index ce58f2f..34569ec 100644
--- a/src/base64.c
+++ b/src/base64.c
@@ -61,9 +61,9 @@ Usage: %s [OPTION]... [FILE]\n\
Base64 encode or decode FILE, or standard input, to standard output.\n\
\n"), program_name);
fputs (_("\
- -d, --decode Decode data\n\
- -i, --ignore-garbage When decoding, ignore non-alphabet characters\n\
- -w, --wrap=COLS Wrap encoded lines after COLS character (default 76).\n\
+ -d, --decode decode data\n\
+ -i, --ignore-garbage when decoding, ignore non-alphabet characters\n\
+ -w, --wrap=COLS wrap encoded lines after COLS character (default 76).\n\
Use 0 to disable line wrapping\n\
\n\
"), stdout);
diff --git a/src/stdbuf.c b/src/stdbuf.c
index de3f515..d9d6f17 100644
--- a/src/stdbuf.c
+++ b/src/stdbuf.c
@@ -98,9 +98,9 @@ Run COMMAND, with modified buffering operations for its standard streams.\n\
Mandatory arguments to long options are mandatory for short options too.\n\
"), stdout);
fputs (_("\
- -i, --input=MODE Adjust standard input stream buffering\n\
- -o, --output=MODE Adjust standard output stream buffering\n\
- -e, --error=MODE Adjust standard error stream buffering\n\
+ -i, --input=MODE adjust standard input stream buffering\n\
+ -o, --output=MODE adjust standard output stream buffering\n\
+ -e, --error=MODE adjust standard error stream buffering\n\
"), stdout);
fputs (HELP_OPTION_DESCRIPTION, stdout);
fputs (VERSION_OPTION_DESCRIPTION, stdout);
diff --git a/src/truncate.c b/src/truncate.c
index 5085d2c..70573cc 100644
--- a/src/truncate.c
+++ b/src/truncate.c
@@ -117,7 +117,7 @@ Mandatory arguments to long options are mandatory for short options too.\n\
-c, --no-create do not create any files\n\
"), stdout);
fputs (_("\
- -o, --io-blocks Treat SIZE as number of IO blocks instead of bytes\n\
+ -o, --io-blocks treat SIZE as number of IO blocks instead of bytes\n\
"), stdout);
fputs (_("\
-r, --reference=FILE use this FILE's size\n\
--
1.6.2.5