summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--Src/init.c7
2 files changed, 8 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 898aef16b..10c17d8b5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,7 +1,10 @@
2013-04-29 Bart Schaefer <schaefer@zsh.org>
+ * 31361: Src/init.c: handle negative optno ("no" prefix used)
+ when storing options with parseopts_insert() for sticky contexts
+
* 31353: Src/math.c: fix handling of floating point in ternary
-
+
* 31350: Src/init.c, Src/input.c, Src/signals.h, Src/utils.c,
Src/Zle/zle_main.c: block SIGWINCH nearly all the time, except
when about to calculate prompts or do synchronous read, so
diff --git a/Src/init.c b/Src/init.c
index f4fb3bee4..01a969df4 100644
--- a/Src/init.c
+++ b/Src/init.c
@@ -281,9 +281,10 @@ parseargs(char **argv, char **runscript)
/**/
static void
-parseopts_insert(LinkList optlist, void *ptr)
+parseopts_insert(LinkList optlist, void *base, int optno)
{
LinkNode node;
+ void *ptr = base + (optno < 0 ? -optno : optno);
for (node = firstnode(optlist); node; incnode(node)) {
if (ptr < getdata(node)) {
@@ -390,7 +391,7 @@ parseopts(char *nam, char ***argvp, char *new_opts, char **cmdp,
if (dosetopt(optno, action, !nam, new_opts) && nam) {
WARN_OPTION("can't change option: %s", *argv);
} else if (optlist) {
- parseopts_insert(optlist, new_opts+optno);
+ parseopts_insert(optlist, new_opts, optno);
}
}
break;
@@ -415,7 +416,7 @@ parseopts(char *nam, char ***argvp, char *new_opts, char **cmdp,
if (dosetopt(optno, action, !nam, new_opts) && nam) {
WARN_OPTION("can't change option: -%c", **argv);
} else if (optlist) {
- parseopts_insert(optlist, new_opts+optno);
+ parseopts_insert(optlist, new_opts, optno);
}
}
}