summaryrefslogtreecommitdiff
path: root/usr/src
diff options
context:
space:
mode:
authorcf46844 <none@none>2006-04-27 13:49:52 -0700
committercf46844 <none@none>2006-04-27 13:49:52 -0700
commitf2f278521a1d65f81d30778b7bd252147b2d325f (patch)
treea1b7c97bd83c9af57f863d421e51395982330fab /usr/src
parent0f5425cb42b31e85aca5bc0a76a35e0f7c250d88 (diff)
downloadillumos-joyent-f2f278521a1d65f81d30778b7bd252147b2d325f.tar.gz
6409995 vi causes core dump if .exrc is world or group writable; vi_01.sh in VSC dumps core
Diffstat (limited to 'usr/src')
-rw-r--r--usr/src/cmd/vi/port/ex_cmds2.c22
1 files changed, 15 insertions, 7 deletions
diff --git a/usr/src/cmd/vi/port/ex_cmds2.c b/usr/src/cmd/vi/port/ex_cmds2.c
index 9757a03663..57ed96b723 100644
--- a/usr/src/cmd/vi/port/ex_cmds2.c
+++ b/usr/src/cmd/vi/port/ex_cmds2.c
@@ -2,9 +2,8 @@
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
- * Common Development and Distribution License, Version 1.0 only
- * (the "License"). You may not use this file except in compliance
- * with the License.
+ * Common Development and Distribution License (the "License").
+ * You may not use this file except in compliance with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
@@ -20,7 +19,7 @@
* CDDL HEADER END
*/
/*
- * Copyright 2005 Sun Microsystems, Inc. All rights reserved.
+ * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
@@ -283,9 +282,18 @@ error1(unsigned char *str)
setlastchar('\n');
if (inexrc) {
- lprintf(gettext("Error detected in .exrc.[Hit return to continue] "), 0);
- putNFL();
- getkey();
+ /*
+ * Set inexrc to 0 so that this error is printed only
+ * once (eg. when stdin is redirected from /dev/null and
+ * vi prints "Input read error" because it is unable to
+ * read() the <CR>).
+ */
+ inexrc = 0;
+ lprintf(gettext(
+ "Error detected in .exrc.[Hit return to continue] "),
+ 0);
+ putNFL();
+ getkey();
}
while ((lastchar() != '\n') && (lastchar() != EOF))