1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-01 05:16:05 +01:00

45791 (tweaked): FAQ: Explain how to binary search one's dotfiles

This commit is contained in:
Daniel Shahaf 2020-05-07 21:23:51 +00:00
parent aa58afd68f
commit d3cc1fd33c
3 changed files with 109 additions and 3 deletions

View file

@ -1,5 +1,8 @@
2020-06-07 Daniel Shahaf <d.s@daniel.shahaf.name> 2020-06-07 Daniel Shahaf <d.s@daniel.shahaf.name>
* 45791 (tweaked): Etc/FAQ.yo, Util/zyodl.vim: FAQ: Explain
how to binary search one's dotfiles
* unposted: Etc/FAQ.yo: FAQ: Update section number in links to * unposted: Etc/FAQ.yo: FAQ: Update section number in links to
the "The future of zsh" section. the "The future of zsh" section.

View file

@ -49,16 +49,22 @@ def(item)(2)(
ARG1: ARG2)\ ARG1: ARG2)\
def(nofill)(1)(ARG1)\ def(nofill)(1)(ARG1)\
def(uref)(1)(url(ARG1)(ARG1))\ def(uref)(1)(url(ARG1)(ARG1))\
COMMENT(TODO: make this expand to a Unicode em dash (U+2014) in HTML output)\
def(emdash)(0)(\
whenlatex(---)\
whenhtml(---)\
whenman(--)whenms(--)whensgml(--)\
whentxt(--))\
def(LPAR)(0)(CHAR(40))\ def(LPAR)(0)(CHAR(40))\
def(RPAR)(1)(CHAR(41)) def(RPAR)(1)(CHAR(41))
myreport(Z-Shell Frequently-Asked Questions)(Peter Stephenson)(2010/02/15) myreport(Z-Shell Frequently-Asked Questions)(Peter Stephenson)(2010/02/15)
COMMENT(-- the following are for Usenet and must appear first)\ COMMENT(-- the following are for Usenet and must appear first)\
description(\ description(\
mydit(Archive-Name:) unix-faq/shell/zsh mydit(Archive-Name:) unix-faq/shell/zsh
mydit(Last-Modified:) 2015/05/31 mydit(Last-Modified:) 2020/05/06
mydit(Submitted-By:) email(coordinator@zsh.org (Peter Stephenson)) mydit(Submitted-By:) email(coordinator@zsh.org (Peter Stephenson))
mydit(Posting-Frequency:) Monthly mydit(Posting-Frequency:) Monthly
mydit(Copyright:) (C) P.W. Stephenson, 1995--2016 (see end of document) mydit(Copyright:) (C) P.W. Stephenson, 1995--2020 (see end of document)
) )
This document contains a list of frequently-asked (or otherwise This document contains a list of frequently-asked (or otherwise
@ -150,6 +156,7 @@ Chapter 6: The future of zsh
6.2. Where do I report bugs, get more info / who's working on zsh? 6.2. Where do I report bugs, get more info / who's working on zsh?
6.3. What's on the wish-list? 6.3. What's on the wish-list?
6.4. Did zsh have problems in the year 2000? 6.4. Did zsh have problems in the year 2000?
6.5. When reporting a bug, how do I reduce my mytt(.zshrc) into a minimal reproduction recipe?
Acknowledgments Acknowledgments
@ -2527,6 +2534,98 @@ sect(Did zsh have problems in the year 2000?)
show problems here. show problems here.
sect(When reporting a bug, how do I reduce my mytt(.zshrc) into a minimal reproduction recipe?)
When reporting a bug, the gold standard is to include with the bug
a myem(minimal reproduction recipe), with which anyone who reads the bug
report can url(reproduce the bug for themselves)
(https://www.chiark.greenend.org.uk/~sgtatham/bugs.html#showmehow)
at will.
When you run into a bug in the shell, particularly during interactive
use, a reproduction recipe would ideally start by running tt(zsh -f)
and then, within that instance of the shell, run a minimal short
sequence of commands that reproduces the bug. A good way to devise
such recipes is the following:
COMMENT(For reference, here's Vim's write-up of a similar process:
https://github.com/chrisbra/vim_faq/blob/de424bd8e08bcf0e6b1e0563ee49514dfed926ae/vim_faq.txt#L1153-L1228)
enumeration(
myeit() First, ensure the bug is reproducible. To do this, start
a new instance of the shell emdash() for example, open a new tab in
your terminal emulator emdash() and reproduce the bug there.
myeit() Start a new instance of the shell by running the
command mytt(zsh -f) from your regular shell prompt, and reproduce the
bug there. (The mytt(-f) flag inhibits mytt(.zshenv),
mytt(/etc/zprofile), mytt(.zprofile), mytt(/etc/zshrc), and
mytt(.zshrc) from being sourced.)
If you succeeded in reproducing the bug in mytt(zsh -f), copy the
commands you used and their outputs (from the mytt(zsh -f) invocation
to the point the bug occurred) and include them in your bug report.
Skip the remaining steps of this procedure.
If, however, the bug happens in your regular shell but not in mytt(zsh
-f), read the next steps.
myeit() Make a backup of your tt(.zshrc) file.
myeit() Delete your tt(.zshrc) file, start a new instance of zsh, and confirm
that the problem does em(not) reproduce there. (If the problem
does reproduce there, it's caused by something in mytt(.zshenv),
mytt(.zprofile), mytt(/etc/zprofile), or mytt(/etc/zshrc), so apply
this procedure from the top to those files rather than to your
mytt(.zshrc).)
COMMENT(Note that mytt(/etc/zshenv) is not mentioned, since by this
point we have established the bug does not occur under mytt(zsh -f),
which sources mytt(/etc/zshenv).)
COMMENT(mytt(.zlogout) and mytt(/etc/zlogout) aren't mentioned because
they're unlikely to be relevant to most readers.)
myeit() At this point, you know that the problem is caused by
something in your mytt(.zshrc) file, but not what line exactly.
To find the responsible line, we will use
a url(variation)(https://en.wikipedia.org/wiki/Delta_debugging)
of the url(binary search)(https://en.wikipedia.org/wiki/Binary_search)
algorithm, as follows:
Suppose your mytt(.zshrc) file has 200 lines. To start, copy
the em(first) half of your mytt(.zshrc) emdash() that is, lines
1 through 100 emdash() from the backup copy to your live mytt(.zshrc)
file, and check whether the bug reproduces then. Now, empty the live
mytt(.zshrc) file again, and copy the em(second) half of your
mytt(.zshrc) file from the backup to the live mytt(.zshrc) file
emdash() the live file should now contain lines 101 through 200, only
emdash() and see whether the problem reproduces.
Normally, the bug will reproduce em(either) with lines 1 through 100
em(or) with lines 101 through 200, but not in both cases. To isolate
the specific line that causes the bug, repeat the above process on the
relevant half of the file: for example, if you've determined that the
bug reproduces when only lines 101 through 200 are installed, check
whether the bug reproduces (a) when only lines 101 through 150 are
installed, and (b) when only lines 151 through 200 are installed.
Repeat the process until the resulting mytt(.zshrc) is minimal.
It is not important to break the file into two halves exactly.
Breaking the file into two parts sized one-third and two-thirds, for
example, will work equally well. You can even try restoring one line
at a time, but this is impractical for all but the shortest
mytt(.zshrc) files.
myeit() Include the minimal set of lines you devised in the previous
step, along with the commands you used and their outputs, in your bug
report.
myeit() Restore your mytt(.zshrc) from backup.
)
Bug reports should be emailed to the mytt(zsh-workers@zsh.org) public
mailing list; see link(6.2)(62) for details.
nsect(Acknowledgments:) nsect(Acknowledgments:)
Thanks to zsh-list, in particular Bart Schaefer, for suggestions Thanks to zsh-list, in particular Bart Schaefer, for suggestions
@ -2542,7 +2641,7 @@ Wischnowsky).
nsect(Copyright Information:) nsect(Copyright Information:)
This document is copyright (C) P.W. Stephenson, 1995, 1996, 1997, This document is copyright (C) P.W. Stephenson, 1995, 1996, 1997,
1998, 1999, 2000, 2012. This text originates in the U.K. and the author 1998, 1999, 2000, 2012, 2020. This text originates in the U.K. and the author
asserts his moral rights under the Copyrights, Designs and Patents Act, asserts his moral rights under the Copyrights, Designs and Patents Act,
1988. 1988.

View file

@ -83,6 +83,7 @@ syn match zyodlSpecial "\<DASH()-" conceal cchar=—
syn match zyodlSpecial "+\?LPAR()" conceal cchar=( syn match zyodlSpecial "+\?LPAR()" conceal cchar=(
syn match zyodlSpecial "+\?RPAR()" conceal cchar=) syn match zyodlSpecial "+\?RPAR()" conceal cchar=)
syn match zyodlSpecial "+\?PLUS()" conceal cchar=+ syn match zyodlSpecial "+\?PLUS()" conceal cchar=+
syn match zyodlFAQDash "+\?\<emdash()" conceal cchar=
"" Highlight groups: "" Highlight groups:
hi def link zyodlTt Constant hi def link zyodlTt Constant
@ -104,6 +105,9 @@ hi def link zyodlSItemArg2 Underlined
hi def link zyodlLineJoiner Special hi def link zyodlLineJoiner Special
hi def link zyodlNote Todo hi def link zyodlNote Todo
"" Derived highlighting groups:
hi def link zyodlFAQDash zyodlSpecial
let b:current_syntax = "zyodl" let b:current_syntax = "zyodl"
let &cpo = s:cpo_save let &cpo = s:cpo_save
unlet s:cpo_save unlet s:cpo_save