On 2016/09/13 23:08, Paul E. McKenney wrote: > On Tue, Sep 13, 2016 at 09:09:36PM +0900, Akira Yokosawa wrote: >> On 2016/09/13 8:28, Paul E. McKenney wrote: >>> On Tue, Sep 13, 2016 at 07:12:34AM +0900, Akira Yokosawa wrote: >>>> On 2016/09/12 08:49:50 -0700, Paul E. McKenney wrote: >>>>> On Tue, Sep 13, 2016 at 12:08:11AM +0900, Akira Yokosawa wrote: >>>>>> >From 177cdd60c2cfe8798547ad260bb821feeb896133 Mon Sep 17 00:00:00 2001 >>>>>> From: Akira Yokosawa <akiyks@xxxxxxxxx> >>>>>> Date: Mon, 12 Sep 2016 23:39:22 +0900 >>>>>> Subject: [PATCH] Add scripts to check 'verbbox' env usage >>>>>> >>>>>> This commit adds scripts to search modification candidates >>>>>> for enclosing "verbbox" environment within "figure" environment. >>>>>> >>>>>> At the top of perfbook directory, the command >>>>>> >>>>>> $ sh utilities/doverbboxcheck.sh >>>>>> >>>>>> will show \begin{figure} statements to be moved ahead of >>>>>> "verbbox" environment. >>>>>> >>>>>> Signed-off-by: Akira Yokosawa <akiyks@xxxxxxxxx> >>>>>> --- >>>>>> utilities/doverbboxcheck.sh | 36 +++++++++++++++++++++++++++ >>>>>> utilities/verbboxcheck.pl | 59 +++++++++++++++++++++++++++++++++++++++++++++ >>>>>> 2 files changed, 95 insertions(+) >>>>>> create mode 100644 utilities/doverbboxcheck.sh >>>>>> create mode 100644 utilities/verbboxcheck.pl >>>>>> >>>>>> diff --git a/utilities/doverbboxcheck.sh b/utilities/doverbboxcheck.sh >>>>>> new file mode 100644 >>>>>> index 0000000..2801bf1 >>>>>> --- /dev/null >>>>>> +++ b/utilities/doverbboxcheck.sh >>>>>> @@ -0,0 +1,36 @@ >>>>>> +#!/bin/sh >>>>>> +# >>>>>> +# Apply verbboxcheck.pl for all .tex files >>>>>> +# >>>>>> +# This program is free software; you can redistribute it and/or modify >>>>>> +# it under the terms of the GNU General Public License as published by >>>>>> +# the Free Software Foundation; either version 2 of the License, or >>>>>> +# (at your option) any later version. >>>>>> +# >>>>>> +# This program is distributed in the hope that it will be useful, >>>>>> +# but WITHOUT ANY WARRANTY; without even the implied warranty of >>>>>> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>>>>> +# GNU General Public License for more details. >>>>>> +# >>>>>> +# You should have received a copy of the GNU General Public License >>>>>> +# along with this program; if not, you can access it online at >>>>>> +# http://www.gnu.org/licenses/gpl-2.0.html. >>>>>> +# >>>>>> +# Copyright (C) Akira Yokosawa, 2016 >>>>>> +# >>>>>> +# Authors: Akira Yokosawa <akiyks@xxxxxxxxx> >>>>>> + >>>>>> +# check if companion script exists >>>>>> +if ! test -e utilities/verbboxcheck.pl >>>>>> +then >>>>>> + echo "utilities/verrboxcheck.pl not found." >>>>>> + exit 1 >>>>>> +fi >>>>>> +texfiles=`find . -name '*.tex' -print` >>>>>> +for i in $texfiles >>>>>> +do >>>>>> + basename="${i%.tex}" >>>>>> +# echo $basename >>>>>> + perl ./utilities/verbboxcheck.pl $basename.tex >>>>>> +done >>>>>> + >>>>>> diff --git a/utilities/verbboxcheck.pl b/utilities/verbboxcheck.pl >>>>>> new file mode 100644 >>>>>> index 0000000..976a41f >>>>>> --- /dev/null >>>>>> +++ b/utilities/verbboxcheck.pl >>>>>> @@ -0,0 +1,59 @@ >>>>>> +#!/usr/bin/perl >>>>>> +# >>>>>> +# Check usage pattern of "verbbox" environment >>>>>> +# >>>>>> +# This program is free software; you can redistribute it and/or modify >>>>>> +# it under the terms of the GNU General Public License as published by >>>>>> +# the Free Software Foundation; either version 2 of the License, or >>>>>> +# (at your option) any later version. >>>>>> +# >>>>>> +# This program is distributed in the hope that it will be useful, >>>>>> +# but WITHOUT ANY WARRANTY; without even the implied warranty of >>>>>> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>>>>> +# GNU General Public License for more details. >>>>>> +# >>>>>> +# You should have received a copy of the GNU General Public License >>>>>> +# along with this program; if not, you can access it online at >>>>>> +# http://www.gnu.org/licenses/gpl-2.0.html. >>>>>> +# >>>>>> +# Copyright (C) Akira Yokosawa, 2016 >>>>>> +# >>>>>> +# Authors: Akira Yokosawa <akiyks@xxxxxxxxx> >>>>>> + >>>>>> +my $line_now; >>>>>> +my $line_prev; >>>>>> +my $line_prev_prev; >>>>>> +my $in_figure = 0; >>>>>> +my $interval = 0; >>>>>> +my $line_num; >>>>>> +my $fig_line; >>>>>> +my $fig_line_num; >>>>>> +my $infile = $ARGV[0]; >>>>>> + >>>>>> +$line_prev_prev = <>; >>>>>> +$line_prev = <>; >>>>>> +$line_now = <>; >>>>>> +$line_num = 3; >>>>>> + >>>>>> +while($line_now) { >>>>>> + if ($in_figure == 1) { >>>>> >>>>> Doesn't this need to be not-equal rather than equal? Or is the fact >>>>> that I haven't written perl for 20 years becoming apparent? ;-) >>>> >>>> Ah, this should have been >>>> >>>> +while($line_now) { >>>> + if ($in_figure) { >>>> >>>> Also, there remain unnecessary variables I used in a preliminary version. >>>> I'm sending a v2 of the patch. Hope it makes more sense. >>> >>> OK, please color me confused. Don't you want to list the occurrences >>> of \theverbbox that are -not- within a figure? >> >> Well, I intentionally chose the \begin{figure} lines. >> As you can see in the diff of commit 510b6afde7fb ("toyrcu: Enclose >> 'verbbox' within 'figure'"), we need to move the \begin{figure} lines. >> By listing them, we can directly jump to a line to be moved in a >> text editor. >> Doesn't this make sense? >> Maybe I need to rephrase the commit message and comment in the script >> to explain the intention. > > You know, I am just going to assume that I am suffering from jet lag. > I pulled v2 of your patch, fixed the whitespace error, and pushed it out. > > But if anyone complains about these scripts, I am sending them straight > to you. ;-) Alright! And I missed the whitespece error. My bad. > >> By the way, I made a typo in the commit message of 510b6afde7fb. >> >> The first sentence reads >> >>> Bare "verbbox" environment just after a section heading causes >>> the "afterheading"-ness of the first paragraph. >> >> This should have been >> >> Bare "verbbox" environment just after a section heading causes >> the "afterheading"-ness of the first paragraph to be lost. >> >> If it isn't too late, can you amend the commit message? > > Done and pushed. But yes, you got lucky. I have been making changes > on another branch. ;-) Thank you so much. And I'm sending a pull request of the other modification to enclose "verbbox" withing "figure" env. It's somewhat large, but utilities/doverbboxcheck.sh would be of your help I hope (as long as you trust the script...) Many thanks, Akira > > Thanx, Paul > >> Thanks, Akira >>> >>> Thanx, Paul >>> >>>>>> + if ($line_now =~ /\\theverbbox/) { >>>>>> + print "$infile:$fig_line_num:$fig_line"; >>>>>> + $in_figure = 0; >>>>>> + } >>>>>> + $interval++; >>>>>> + } >>>>>> + if ($line_now =~ /\\begin\{figure\}/) { >>>>>> + $in_figure = 1; >>>>>> + $fig_line = $line_now; >>>>>> + $fig_line_num = $line_num; >>>>>> + } >>>>>> + if ($interval > 3) { >>>>>> + $in_figure = 0; >>>>>> + $interval = 0; >>>>>> + } >>>>>> + $line_prev_prev = $line_prev; >>>>>> + $line_prev = $line_now; >>>>>> + $line_now = <>; >>>>>> + $line_num++; >>>>>> +} >>>>>> -- >>>>>> 1.9.1 >>>>>> >>>>> >>>>> >>>> >>> >>> >> > > -- 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