From 369ae8cdd0a26f8e07dd744deca598d7be88a493 Mon Sep 17 00:00:00 2001 From: Eric Bollengier Date: Mon, 19 Oct 2009 09:38:59 +0000 Subject: [PATCH] fix status slots command when SD slots are mixed --- bacula/src/dird/ua_label.c | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/bacula/src/dird/ua_label.c b/bacula/src/dird/ua_label.c index 0c5a7d0c08..08d022096f 100644 --- a/bacula/src/dird/ua_label.c +++ b/bacula/src/dird/ua_label.c @@ -893,13 +893,28 @@ static vol_list_t *get_vol_list_from_SD(UAContext *ua, bool scan) vl->next = vol_list; vol_list = vl; } else { - /* Add new entry to end of list */ + vol_list_t *prev=vol_list; + /* Add new entry to the right place in the list */ for (vol_list_t *tvl=vol_list; tvl; tvl=tvl->next) { + if (tvl->Slot > vl->Slot) { + /* no previous item, update vol_list directly */ + if (prev == vol_list) { + vl->next = vol_list; + vol_list = vl; + + } else { /* replace the previous pointer */ + prev->next = vl; + vl->next = tvl; + } + break; + } + /* we are at the end */ if (!tvl->next) { tvl->next = vl; vl->next = NULL; break; } + prev = tvl; } } } @@ -1218,7 +1233,6 @@ void status_slots(UAContext *ua, STORE *store_r) } ua->send_msg(_(" Slot | Volume Name | Status | Media Type | Pool |\n")); ua->send_msg(_("------+------------------+-----------+----------------------+--------------------|\n")); - /* Walk through the list getting the media records */ for (vl=vol_list; vl; vl=vl->next) { -- 2.39.5