Re: [PATCH] Choose 'cmtt' font for code snippets in targets 'msnt' and 'mstx'

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Mar 22, 2017 at 07:04:45AM +0900, Akira Yokosawa wrote:
> On 2017/03/22 3:35, Paul E. McKenney wrote:
> > On Mon, Mar 20, 2017 at 01:58:15PM +0900, Akira Yokosawa wrote:
> >> >From 25fb5aea63049454a5df2c923dac59285fe40720 Mon Sep 17 00:00:00 2001
> >> From: Akira Yokosawa <akiyks@xxxxxxxxx>
> >> Date: Mon, 20 Mar 2017 13:10:38 +0900
> >> Subject: [PATCH] Choose 'cmtt' font for code snippets in targets 'msnt' and 'mstx'
> >>
> >> By specifying "cmtt" (Computer Modern Teletype) font as \ttdefault
> >> in verbatim, verbbox, table, tabular, tabulary, and minipage
> >> environments, we can improve consistency of looks independent of
> >> monospace font choice for main text. cmtt font is more than suitable
> >> for listing of code snippet and program output.
> >>
> >> However, when mixed used with Times Roman (clone) font, cmtt's
> >> slightly lower x-height than Times Roman, and its similar thickness
> >> as Times Roman, it is not distinctive enough as can be seen in
> >> "mslm" target.
> >>
> >> In this respect, "txtt" and its enhanced version "newtxtt" fonts
> >> are more suitable as is described in [1].
> >>
> >> This commit enables the font choice of cmtt for code snippets in
> >> targets "msnt" and "mstx".
> >>
> >> Help messages in Makefile are updated accordingly.
> >>
> >> Any feedback on the font choice is welcome.
> >>
> >> [1] Excerpt from newtxtt documentation:
> >>
> >>     This package provides an interface to another alternative---the
> >>     typewriter fonts provided with txfonts, with some enhancements.
> >>     They have the same widths as cmtt, but are taller, heavier,
> >>     more geometric and less shapely, with very low contrast, and
> >>     are more suited to match Roman fonts of height and weight
> >>     approximating that of Times.
> >>
> >> Signed-off-by: Akira Yokosawa <akiyks@xxxxxxxxx>
> > 
> > Queued and pushed, thank you!
> > 
> > I did remove some trailing whitespace that this patch added to
> > perfbook.tex.  Please let me know if this whitespace was needed for
> > some reason.
> 
> My bad. And thanks for the fix.
> 
> Is there any config option to flag trailing whitespaces at "git add"?

There is!

You can create a pre-commit hook, which is a script that lives in your
.git/hooks/pre-commit file.  I believe that the default hook checks for
trailing whitespace.  You need to make the script executable.  To make
the commit fail, make the script exit non-zero.  If you want to force the
commit despite the script complaining, give "git commit" the "-n" flag.

It has been years since I set mine up, so I am probably forgetting
something, but there is always:

	https://git-scm.com/book/en/v2/Customizing-Git-Git-Hooks

> And please try the modified targets and see if you really want to promote
> "msnt" as the default font choice.

Now that you mention it, I get this:

	! LaTeX Error: File `newtxtt.sty' not found.

I downloaded this file from:

	ftp://ftp.dante.de/tex-archive/fonts/newtxtt/tex/newtxtt.sty

and it was much happier.  But I bet that I should put it somewhere
other than in the main perfbook directory, given that I don't want
"git status" to gripe about it forever.  Any advice on location?

One thing I am not all that happy with is that it is hard for me
to distinguish the inline fixed-width font from the normal font.
Or is that the fault of my setup?

						Thanx, Paul

							Thanx, Paul

> >> ---
> >>  Makefile     | 17 +++++++++++------
> >>  perfbook.tex | 13 +++++++++++++
> >>  2 files changed, 24 insertions(+), 6 deletions(-)
> >>
> >> diff --git a/Makefile b/Makefile
> >> index 2c88e6c..e5f620c 100644
> >> --- a/Makefile
> >> +++ b/Makefile
> >> @@ -110,7 +110,8 @@ perfbook-msns.tex: perfbook.tex
> >>  	sed -e 's/\[scaled=\.94\]{couriers}/{courier}/' < $< > $@
> >>
> >>  perfbook-mstx.tex: perfbook.tex
> >> -	sed -e 's/usepackage\[scaled=\.94\]{couriers}/renewcommand*\\ttdefault{txtt}/' < $< > $@
> >> +	sed -e 's/usepackage\[scaled=\.94\]{couriers}/renewcommand*\\ttdefault{txtt}/' \
> >> +	    -e 's/setboolean{cmttforcode}{false}/setboolean{cmttforcode}{true}/' < $< > $@
> >>
> >>  perfbook-msr.tex: perfbook.tex
> >>  	sed -e 's/\[scaled=\.94\]{couriers}/[scaled=.94]{nimbusmono}/' < $< > $@
> >> @@ -121,8 +122,10 @@ perfbook-msn.tex: perfbook.tex
> >>  	@echo "## This target requires font package nimbus15. ##"
> >>
> >>  perfbook-msnt.tex: perfbook.tex
> >> -	sed -e 's/\[scaled=\.94\]{couriers}/[zerostyle=a]{newtxtt}/' < $< > $@
> >> +	sed -e 's/\[scaled=\.94\]{couriers}/[zerostyle=a]{newtxtt}/' \
> >> +	    -e 's/setboolean{cmttforcode}{false}/setboolean{cmttforcode}{true}/' < $< > $@
> >>  	@echo "## This target requires font package newtxtt. ##"
> >> +	@echo "## If build fails, try target 'mstx' instead. ##"
> >>
> >>  perfbook-mslm.tex: perfbook.tex
> >>  	sed -e 's/%\\usepackage{lmodern}/\\usepackage{lmodern}/' \
> >> @@ -181,17 +184,19 @@ help:
> >>  	@echo
> >>  	@echo "Experimental targets:"
> >>  	@echo "  Full,              Abbr."
> >> -	@echo "  perfbook-msr.pdf,  msr:  2c with regular thickness courier clone"
> >> -	@echo "  perfbook-msn.pdf,  msn:  2c with narrow courier clone"
> >> -	@echo "  perfbook-mstx.pdf, mstx: 2c with txtt as monospace"
> >>  	@echo "  perfbook-msnt.pdf, msnt: 2c with newtxtt as monospace (non-slashed 0)"
> >> +	@echo "  perfbook-mstx.pdf, mstx: 2c with txtt as monospace"
> >>  	@echo "  perfbook-mslm.pdf, mslm: 2c with lmtt (Latin Modern Typewriter) as monospace"
> >>  	@echo "       (Latin Modern is a clone of Computer Modern with additional type faces)"
> >> +	@echo "  perfbook-msr.pdf,  msr:  2c with regular thickness courier clone"
> >> +	@echo "  perfbook-msn.pdf,  msn:  2c with narrow courier clone"
> >> +
> >>  	@echo "  perfbook-1csf.pdf, 1csf: 1c with sans serif font"
> >>  	@echo "  perfbook-msns.pdf, msns: 2c with non-scaled courier"
> >> +	@echo "  \"msnt\" requires \"newtxtt\". \"mstx\" is fallback target for older TeX env."
> >> +	@echo "  \"msnt\" and \"mstx\" use \"cmtt\" font for code snippet."
> >>  	@echo "  \"msr\" and \"msn\" require \"nimbus15\"."
> >>  	@echo "  \"msn\" doesn't cover bold face for monospace."
> >> -	@echo "  \"msnt\" requires \"newtxtt\"."
> >>  	@echo "  \"1csf\" requires recent version (>=1.3i) of \"mathastext\"."
> >>
> >>  clean:
> >> diff --git a/perfbook.tex b/perfbook.tex
> >> index e8234c4..94f2f4b 100644
> >> --- a/perfbook.tex
> >> +++ b/perfbook.tex
> >> @@ -15,6 +15,7 @@
> >>  % Improves the text layout
> >>  \usepackage{microtype}
> >>  \UseMicrotypeSet[protrusion]{basicmath} % disable protrusion for tt fonts
> >> +\usepackage{etoolbox}
> >>
> >>  \usepackage{lscape}
> >>  \usepackage{epsfig}
> >> @@ -64,6 +65,9 @@
> >>  \newboolean{sansserif}
> >>  \setboolean{sansserif}{false}
> >>  \newcommand{\IfSansSerif}[2]{\ifthenelse{\boolean{sansserif}}{#1}{#2}}
> >> +\newboolean{cmttforcode}
> >> +\setboolean{cmttforcode}{false}
> >> +\newcommand{\IfCmttForCode}[2]{\ifthenelse{\boolean{cmttforcode}}{#1}{#2}}
> >>
> >>  \newcommand{\OneColumnHSpace}[1]{\IfTwoColumn{}{\hspace*{#1}}}
> >>
> >> @@ -74,6 +78,15 @@
> >>  \renewcommand{\path}[1]{\nolinkurl{#1}} % workaround of interference with mathastext
> >>  }{}
> >>
> >> +\IfCmttForCode{
> >> +\AtBeginEnvironment{verbatim}{\renewcommand{\ttdefault}{cmtt}}
> >> +\AtBeginEnvironment{verbbox}{\renewcommand{\ttdefault}{cmtt}}
> >> +\AtBeginEnvironment{table}{\renewcommand{\ttdefault}{cmtt}}
> >> +\AtBeginEnvironment{tabular}{\renewcommand{\ttdefault}{cmtt}}
> >> +\AtBeginEnvironment{tabulary}{\renewcommand{\ttdefault}{cmtt}}
> >> +\AtBeginEnvironment{minipage}{\renewcommand{\ttdefault}{cmtt}}
> >> +}{}
> >> +                   
> >>  \begin{document}
> >>
> >>  %%HTMLSKIP
> >> -- 
> >> 2.7.4
> >>
> > 
> > 
> 

--
To unsubscribe from this list: send the line "unsubscribe perfbook" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux