1
0
mirror of https://github.com/irssi/irssi.git synced 2025-01-03 14:56:47 -05:00
This commit is contained in:
ailin-nemui 2016-12-20 21:33:51 +01:00
parent 9004265e54
commit 03f5dc63fe

View File

@ -59,19 +59,17 @@ static int window_get_new_refnum(void)
int refnum; int refnum;
refnum = 1; refnum = 1;
for (iter = windows_seq_begin(), iter = windows_seq_begin();
end = windows_seq_end(); end = windows_seq_end();
iter != end;
refnum++,
iter = g_sequence_iter_next(iter)) {
while (iter != end) {
win = g_sequence_get(iter); win = g_sequence_get(iter);
if (refnum != win->refnum) { if (refnum != win->refnum)
return refnum; return refnum;
}
refnum++;
iter = g_sequence_iter_next(iter);
} }
return refnum; return refnum;
@ -141,7 +139,7 @@ static void windows_pack(int removed_refnum)
int refnum; int refnum;
GSequenceIter *iter, *end; GSequenceIter *iter, *end;
refnum = removed_refnum+1; refnum = removed_refnum + 1;
end = windows_seq_end(); end = windows_seq_end();
iter = windows_seq_refnum_lookup(refnum); iter = windows_seq_refnum_lookup(refnum);
if (iter == NULL) return; if (iter == NULL) return;
@ -152,7 +150,7 @@ static void windows_pack(int removed_refnum)
if (window == NULL || window->sticky_refnum || window->refnum != refnum) if (window == NULL || window->sticky_refnum || window->refnum != refnum)
break; break;
window_set_refnum0(window, refnum-1); window_set_refnum0(window, refnum - 1);
windows_seq_changed(iter); windows_seq_changed(iter);
} }
} }
@ -468,14 +466,19 @@ WINDOW_REC *window_find_item(SERVER_REC *server, const char *name)
return window_item_window(item); return window_item_window(item);
} }
/* search to the numerically right iterator of refnum */
static GSequenceIter *windows_seq_refnum_search_right(int refnum) static GSequenceIter *windows_seq_refnum_search_right(int refnum)
{ {
return g_sequence_search(windows_seq, GINT_TO_POINTER(refnum), (GCompareDataFunc)window_refnum_lookup, NULL); return g_sequence_search(windows_seq, GINT_TO_POINTER(refnum), (GCompareDataFunc)window_refnum_lookup, NULL);
} }
/* we want to find the numerically left iterator of refnum, so we
search the right of the previous refnum. but we need to figure out
the case where the iterator is already at the beginning, i.e
iter->refnum >= refnum */
static GSequenceIter *windows_seq_refnum_search_left(int refnum) static GSequenceIter *windows_seq_refnum_search_left(int refnum)
{ {
GSequenceIter *iter = windows_seq_refnum_search_right(refnum-1); GSequenceIter *iter = windows_seq_refnum_search_right(refnum - 1);
return iter == windows_seq_begin() ? NULL : g_sequence_iter_prev(iter); return iter == windows_seq_begin() ? NULL : g_sequence_iter_prev(iter);
} }