Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
PATCH: make PROMPT_SP end-of-line marker configurable
- X-seq: zsh-workers 26964
- From: Greg Klanderman <gak@xxxxxxxxxxxxxx>
- To: Zsh list <zsh-workers@xxxxxxxxxx>
- Subject: PATCH: make PROMPT_SP end-of-line marker configurable
- Date: Sun, 17 May 2009 00:55:35 -0400
- Mailing-list: contact zsh-workers-help@xxxxxxxxxx; run by ezmlm
- Reply-to: gak@xxxxxxxxxxxxxx
Hi,
This adds a parameter, EOLMARK, which allows configuring the
end-of-line marker used by the PROMPT_SP option.
I also cleaned up the doc for PS1 slightly.
thanks,
Greg
Index: Src/utils.c
===================================================================
RCS file: /cvsroot/zsh/zsh/Src/utils.c,v
retrieving revision 1.221
diff -u -r1.221 utils.c
--- Src/utils.c 6 Apr 2009 09:06:36 -0000 1.221
+++ Src/utils.c 17 May 2009 04:31:42 -0000
@@ -1216,12 +1216,16 @@
* Unfortunately it interacts badly with ZLE displaying message
* when ^D has been pressed. So just disable PROMPT_SP logic in
* this case */
+ char *eolmark = getsparam("EOLMARK");
char *str;
- int percents = opts[PROMPTPERCENT];
+ int percents = opts[PROMPTPERCENT], w = 0;
+ if (!eolmark || !*eolmark)
+ eolmark = "%B%S%#%s%b";
opts[PROMPTPERCENT] = 1;
- str = promptexpand("%B%S%#%s%b", 0, NULL, NULL, NULL);
+ str = promptexpand(eolmark, 1, NULL, NULL, NULL);
+ countprompt(str, &w, 0, -1);
opts[PROMPTPERCENT] = percents;
- fprintf(shout, "%s%*s\r", str, (int)columns - 1 - !hasxn, "");
+ fprintf(shout, "%s%*s\r", str, (int)columns - w - !hasxn, "");
free(str);
}
Index: Doc/Zsh/options.yo
===================================================================
RCS file: /cvsroot/zsh/zsh/Doc/Zsh/options.yo,v
retrieving revision 1.81
diff -u -r1.81 options.yo
--- Doc/Zsh/options.yo 6 Apr 2009 09:06:36 -0000 1.81
+++ Doc/Zsh/options.yo 17 May 2009 04:31:42 -0000
@@ -1307,16 +1307,18 @@
item(tt(PROMPT_SP) <D>)(
Attempt to preserve a partial line (i.e. a line that did not end with a
newline) that would otherwise be covered up by the command prompt due to
-the PROMPT_CR option. This works by outputting some cursor-control
+the tt(PROMPT_CR) option. This works by outputting some cursor-control
characters, including a series of spaces, that should make the terminal
wrap to the next line when a partial line is present (note that this is
only successful if your terminal has automatic margins, which is typical).
-When a partial line is preserved, you will see an inverse+bold character at
-the end of the partial line: a "%" for a normal user or a "#" for root.
+When a partial line is preserved, by default you will see an inverse+bold
+character at the end of the partial line: a "%" for a normal user or
+a "#" for root. If set, the shell parameter tt(EOLMARK) can be used to
+customize how the end of partial lines are shown.
-NOTE: if the PROMPT_CR option is not set, enabling this option will have no
-effect. This option is on by default.
+NOTE: if the tt(PROMPT_CR) option is not set, enabling this option will
+have no effect. This option is on by default.
)
pindex(PROMPT_PERCENT)
pindex(NO_PROMPT_PERCENT)
Index: Doc/Zsh/params.yo
===================================================================
RCS file: /cvsroot/zsh/zsh/Doc/Zsh/params.yo,v
retrieving revision 1.54
diff -u -r1.54 params.yo
--- Doc/Zsh/params.yo 24 Apr 2009 09:00:37 -0000 1.54
+++ Doc/Zsh/params.yo 17 May 2009 04:31:42 -0000
@@ -823,6 +823,14 @@
arithmetic expansion before being interpreted as a pathname. Note that
tt(ENV) is em(not) used unless zsh is emulating bf(sh) or bf(ksh).
)
+vindex(EOLMARK)
+item(tt(EOLMARK))(
+When the tt(PROMPT_CR) and tt(PROMPT_SP) options are set, the tt(EOLMARK)
+parameter can be used to customize how the end of partial lines are shown.
+This parameter undergoes prompt expansion, with the tt(PROMPT_PERCENT)
+option set. If not set or empty, the default behavior is equivalent to
+the value `tt(%B%S%#%s%b)'.
+)
vindex(FCEDIT)
item(tt(FCEDIT))(
The default editor for the tt(fc) builtin. If tt(FCEDIT) is not set,
@@ -1046,10 +1054,10 @@
vindex(PS1)
item(tt(PS1) <S>)(
The primary prompt string, printed before a command is read.
-the default is `tt(%m%# )'. It undergoes a special form of expansion
+It undergoes a special form of expansion
before being displayed; see
ifzman(EXPANSION OF PROMPT SEQUENCES in zmanref(zshmisc))\
-ifnzman(noderef(Prompt Expansion)).
+ifnzman(noderef(Prompt Expansion)). The default is `tt(%m%# )'.
)
vindex(PS2)
item(tt(PS2) <S>)(
Messages sorted by:
Reverse Date,
Date,
Thread,
Author