match_parens [filename] |
-h | print this help and exit |
-H,--help | print full documentation and exit |
-V,--version | print version and exit |
-l,--latex | convert ``...'' to “...” before testing |
-n,--number=N | set number of mismatching characters shown to N (default: 10) |
-p,--pairs=S | set matching pairs to S (default: {}[]()“”«»‘’""'') |
--test | do an internal test and exit |
:!%
. By default, the following pairs are tested:
() | round brackets or parentheses |
{} | curly brackets or braces |
[] | square brackets |
<> | angle brackets (within html text only) |
"" | ASCII double quotes |
“” | Unicode double quotation marks |
'' | ASCII single quotes |
‘’ | Unicode single quotation marks |
The exit value of the script is 0 when there are no mismatches, 1 otherwise.
Angle brackets are only looked for inside HTML text, where HTML is supposed to start with <html>
or =begin␣rdoc
and to end with </html>
or =end
.
-h,--help | |
print short help information and exit. | |
-H,--Help | |
print full documentation via less and exit. | |
-V,--version | |
print this script's version and exit. | |
-l,--latex | |
convert ``...'' to “...” before testing. | |
-n,--number=N | |
Set number of mismatching characters shown to N. By default, only the first 10 are shown. | |
-p,--pairs=S | |
Set matching pairs to S (default: {}[]()“”''«»""‘’ ). For example, if you want to look for mismatching ASCII single quotes only, use --pairs="''" . Or, if you want to match braces and guillemets only, use -p␣«» . Note that if html is detected in your text, <> is automatically added to the pairs list. So by default, <...> is tested only in html, but you can test that in other text by specifying the <> pair in the --pairs option. | |
--test | |
do an internal test and exit. Note that if, with the --pairs option, you specify an other pairs list than the default, the test will probably fail, but you can still see the effects of your pairs list on the test data. |
good
and bad
, containing these texts:
good: | |
This is a (simple) test without mismatches |
bad: | |
This is a (simple test containing mismatches |
then here are some usage examples. First a simple test on these files:
$ matchparens good 1 || This is a (simple) test 2 || without mismatches $ echo $? 0 $ matchparens bad 1 | (| This is a (simple test 2 | (| containing mismatches $ echo $? 1
Just report if there are mismatches:
$ matchparens good >/dev/null && echo fine || echo problems fine $ matchparens bad >/dev/null && echo fine || echo problems problems
Report all tex files with mismatches in the current directory:
$ for i in *.tex; do matchparens $i >/dev/null || echo $i; done
Matches must be in correct order:
$ echo -e "This is a ([simple)] test\n" | match_parens 1 ([)]This is a ([simple)] test 2 ([)]