diff options
author | Tiago Cunha <tcunha@gmx.com> | 2011-01-21 23:52:36 +0000 |
---|---|---|
committer | Tiago Cunha <tcunha@gmx.com> | 2011-01-21 23:52:36 +0000 |
commit | 43f8d62f6a1d65d5e5b1ae7c8ace37a5e9f60297 (patch) | |
tree | b6766753ce797fa00c812e8a05f1dcbf95ed16c1 | |
parent | a880639f487bf43d3ce3c458719f87a98b8d609f (diff) | |
download | rtmux-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.c | 20 |
1 files changed, 7 insertions, 13 deletions
@@ -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); |