aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2011-01-21 23:52:36 +0000
committerTiago Cunha <tcunha@gmx.com>2011-01-21 23:52:36 +0000
commit43f8d62f6a1d65d5e5b1ae7c8ace37a5e9f60297 (patch)
treeb6766753ce797fa00c812e8a05f1dcbf95ed16c1
parenta880639f487bf43d3ce3c458719f87a98b8d609f (diff)
downloadrtmux-43f8d62f6a1d65d5e5b1ae7c8ace37a5e9f60297.tar.gz
rtmux-43f8d62f6a1d65d5e5b1ae7c8ace37a5e9f60297.tar.bz2
rtmux-43f8d62f6a1d65d5e5b1ae7c8ace37a5e9f60297.zip
Sync OpenBSD patchset 840:
Fix next and previous session functions to actually work.
-rw-r--r--session.c20
1 files changed, 7 insertions, 13 deletions
diff --git a/session.c b/session.c
index 22572016..b915f69f 100644
--- a/session.c
+++ b/session.c
@@ -1,4 +1,4 @@
-/* $Id: session.c,v 1.85 2011-01-03 23:27:54 tcunha Exp $ */
+/* $Id: session.c,v 1.86 2011-01-21 23:52:36 tcunha Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -180,12 +180,9 @@ session_next_session(struct session *s)
if (RB_EMPTY(&sessions) || !session_alive(s))
return (NULL);
- s2 = s;
- do {
- s2 = RB_NEXT(sessions, &sessions, s2);
- if (s2 == NULL)
- s2 = RB_MIN(sessions, &sessions);
- } while (s2 != s);
+ s2 = RB_NEXT(sessions, &sessions, s2);
+ if (s2 == NULL)
+ s2 = RB_MIN(sessions, &sessions);
if (s2 == s)
return (NULL);
return (s2);
@@ -200,12 +197,9 @@ session_previous_session(struct session *s)
if (RB_EMPTY(&sessions) || !session_alive(s))
return (NULL);
- s2 = s;
- do {
- s2 = RB_PREV(sessions, &sessions, s2);
- if (s2 == NULL)
- s2 = RB_MAX(sessions, &sessions);
- } while (s2 != s);
+ s2 = RB_PREV(sessions, &sessions, s2);
+ if (s2 == NULL)
+ s2 = RB_MAX(sessions, &sessions);
if (s2 == s)
return (NULL);
return (s2);