1
0
mirror of https://git.FreeBSD.org/ports.git synced 2025-01-29 10:18:30 +00:00

Fix a long-term problem: shell-mode would not open a new shell fo

shell-mode on FreeBSD once a number of ttys were taken, it wouldn't
find the next free one where xterm and everybody else would.

Teach it to walk the list of possible FreeBSD ttys correctly.

This code is evil, I'm only doing it because emacs-21 is *really* evil
and I didn't port all of my .emacs to xemacs yet...
This commit is contained in:
Martin Cracauer 2003-07-01 21:59:54 +00:00
parent a1494810f4
commit c964d29e95
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=84010

View File

@ -0,0 +1,42 @@
--- src/process.c.orig Tue Jul 1 16:24:08 2003
+++ src/process.c Tue Jul 1 16:24:42 2003
@@ -400,6 +400,14 @@
#ifdef HAVE_PTYS
+char to_tty_char(int i)
+{
+ if (i < 10)
+ return '0' + i;
+ else
+ return 'a' + i - 10;
+}
+
/* Open an available pty, returning a file descriptor.
Return -1 on failure.
The file name of the terminal corresponding to the pty
@@ -423,13 +431,13 @@
PTY_ITERATION
#else
for (c = FIRST_PTY_LETTER; c <= 'z'; c++)
- for (i = 0; i < 16; i++)
+ for (i = 0; i < 'z' - 'a' + 1 + 10; i++)
#endif
{
#ifdef PTY_NAME_SPRINTF
PTY_NAME_SPRINTF
#else
- sprintf (pty_name, "/dev/pty%c%x", c, i);
+ sprintf (pty_name, "/dev/pty%c%c", c, to_tty_char(i));
#endif /* no PTY_NAME_SPRINTF */
#ifdef PTY_OPEN
@@ -466,7 +474,7 @@
#ifdef PTY_TTY_NAME_SPRINTF
PTY_TTY_NAME_SPRINTF
#else
- sprintf (pty_name, "/dev/tty%c%x", c, i);
+ sprintf (pty_name, "/dev/tty%c%c", c, to_tty_char(i));
#endif /* no PTY_TTY_NAME_SPRINTF */
#ifndef UNIPLUS
if (access (pty_name, 6) != 0)