All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
To: Akira Yokosawa <akiyks@gmail.com>
Cc: perfbook@vger.kernel.org
Subject: Re: [PATCH] Choose 'cmtt' font for code snippets in targets 'msnt' and 'mstx'
Date: Tue, 21 Mar 2017 15:41:20 -0700	[thread overview]
Message-ID: <20170321224120.GS3637@linux.vnet.ibm.com> (raw)
In-Reply-To: <35f08b5e-cd04-897a-647a-caac9dbf59a1@gmail.com>

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@gmail.com>
> >> 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@gmail.com>
> > 
> > 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
> >>
> > 
> > 
> 


  reply	other threads:[~2017-03-21 22:41 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-03-20  4:58 [PATCH] Choose 'cmtt' font for code snippets in targets 'msnt' and 'mstx' Akira Yokosawa
2017-03-21 18:35 ` Paul E. McKenney
2017-03-21 22:04   ` Akira Yokosawa
2017-03-21 22:41     ` Paul E. McKenney [this message]
2017-03-21 22:54       ` Akira Yokosawa
2017-03-22 11:05         ` Akira Yokosawa
2017-03-23 12:00           ` Akira Yokosawa
2017-03-23 12:50             ` Paul E. McKenney
2017-03-23 13:57               ` Akira Yokosawa

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20170321224120.GS3637@linux.vnet.ibm.com \
    --to=paulmck@linux.vnet.ibm.com \
    --cc=akiyks@gmail.com \
    --cc=perfbook@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.