055396
--- netkit-telnet-0.17-pre-20000204/telnet/commands.c.env	Thu Apr  8 19:30:20 1999
055396
+++ netkit-telnet-0.17-pre-20000204/telnet/commands.c	Tue May 16 17:19:47 2000
055396
@@ -1815,11 +1815,11 @@
055396
 }
055396
 
055396
 	unsigned char *
055396
-env_getvalue(unsigned char *var)
055396
+env_getvalue(unsigned char *var, int exported_only)
055396
 {
055396
-	struct env_lst *ep;
055396
+	struct env_lst *ep = env_find(var);
055396
 
055396
-	if ((ep = env_find(var)))
055396
+	if (ep && (!exported_only || ep->export))
055396
 		return(ep->value);
055396
 	return(NULL);
055396
 }
055396
--- netkit-telnet-0.17-pre-20000204/telnet/telnet.c.env	Tue May 16 17:19:47 2000
055396
+++ netkit-telnet-0.17-pre-20000204/telnet/telnet.c	Tue May 16 17:19:47 2000
055396
@@ -438,7 +438,7 @@
055396
 #endif
055396
 
055396
 	    case TELOPT_XDISPLOC:	/* X Display location */
055396
-		if (env_getvalue((unsigned char *)"DISPLAY"))
055396
+		if (env_getvalue((unsigned char *)"DISPLAY", 0))
055396
 		    new_state_ok = 1;
055396
 		break;
055396
 
055396
@@ -693,7 +693,7 @@
055396
 		resettermname = 0;
055396
 		if (tnamep && tnamep != unknown)
055396
 			free(tnamep);
055396
-		if ((tname = (char *)env_getvalue((unsigned char *)"TERM")) &&
055396
+		if ((tname = (char *)env_getvalue((unsigned char *)"TERM", 0)) &&
055396
 				(setupterm(tname, 1, &errret) == 0)) {
055396
 			tnamep = mklist(ttytype, tname);
055396
 		} else {
055396
@@ -870,7 +870,7 @@
055396
 	    unsigned char temp[50], *dp;
055396
 	    int len;
055396
 
055396
-	    if ((dp = env_getvalue((unsigned char *)"DISPLAY")) == NULL) {
055396
+	    if ((dp = env_getvalue((unsigned char *)"DISPLAY", 0)) == NULL) {
055396
 		/*
055396
 		 * Something happened, we no longer have a DISPLAY
055396
 		 * variable.  So, turn off the option.
055396
@@ -1527,7 +1527,7 @@
055396
 			env_opt_add(ep);
055396
 		return;
055396
 	}
055396
-	vp = env_getvalue(ep);
055396
+	vp = env_getvalue(ep, 1);
055396
 	if (opt_replyp + (vp ? strlen((char *)vp) : 0) +
055396
 				strlen((char *)ep) + 6 > opt_replyend)
055396
 	{
055396
@@ -2170,7 +2170,7 @@
055396
 	send_will(TELOPT_LINEMODE, 1);
055396
 	send_will(TELOPT_NEW_ENVIRON, 1);
055396
 	send_do(TELOPT_STATUS, 1);
055396
-	if (env_getvalue((unsigned char *)"DISPLAY"))
055396
+	if (env_getvalue((unsigned char *)"DISPLAY", 0))
055396
 	    send_will(TELOPT_XDISPLOC, 1);
055396
 	if (binary)
055396
 	    tel_enter_binary(binary);
055396
--- netkit-telnet-0.17-pre-20000204/telnet/externs.h.env	Mon Feb  8 15:56:11 1999
055396
+++ netkit-telnet-0.17-pre-20000204/telnet/externs.h	Tue May 16 17:19:47 2000
055396
@@ -203,7 +203,7 @@
055396
 void env_send (unsigned char *);
055396
 void env_list (void);
055396
 unsigned char * env_default(int init, int welldefined);
055396
-unsigned char * env_getvalue(unsigned char *var);
055396
+unsigned char * env_getvalue(unsigned char *var, int exported_only);
055396
 
055396
 void set_escape_char(char *s);
055396
 unsigned long sourceroute(char *arg, char **cpp, int *lenp);
055396
@@ -335,7 +335,7 @@
055396
 void     env_opt_end (int);
055396
 
055396
 unsigned char     *env_default (int, int);
055396
-unsigned char     *env_getvalue (unsigned char *);
055396
+unsigned char     *env_getvalue (unsigned char *, int);
055396
 
055396
 int get_status (void);
055396
 int dosynch (void);