X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Fwx%2Fservers_list_dialog.cc;h=37a14338431f3f44dea91f44314aa2ef55d2edf6;hp=13c6df70729746ba40d7556e14fa2e5d8fdd3c5f;hb=386e25f3b9d3fa59cbdeed458d9b3e0d21e338b8;hpb=e60bb3e51bd1508b149e6b8f6608f09b5196ae26 diff --git a/src/wx/servers_list_dialog.cc b/src/wx/servers_list_dialog.cc index 13c6df707..37a143384 100644 --- a/src/wx/servers_list_dialog.cc +++ b/src/wx/servers_list_dialog.cc @@ -1,26 +1,29 @@ /* Copyright (C) 2013-2015 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -#include -#include "lib/server_finder.h" #include "servers_list_dialog.h" #include "wx_util.h" +#include "lib/encode_server_finder.h" +#include "lib/encode_server_description.h" +#include +#include using std::list; using std::string; @@ -32,7 +35,7 @@ ServersListDialog::ServersListDialog (wxWindow* parent) wxBoxSizer* s = new wxBoxSizer (wxVERTICAL); SetSizer (s); - _list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxSize (400, 200), wxLC_REPORT | wxLC_SINGLE_SEL); + _list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxSize (500, 200), wxLC_REPORT | wxLC_SINGLE_SEL); { wxListItem ip; @@ -46,7 +49,7 @@ ServersListDialog::ServersListDialog (wxWindow* parent) wxListItem ip; ip.SetId (1); ip.SetText (_("Threads")); - ip.SetWidth (100); + ip.SetWidth (150); _list->InsertColumn (1, ip); } @@ -61,19 +64,30 @@ ServersListDialog::ServersListDialog (wxWindow* parent) s->Layout (); s->SetSizeHints (this); - _server_finder_connection = ServerFinder::instance()->connect (boost::bind (&ServersListDialog::server_found, this, _1)); + _server_finder_connection = EncodeServerFinder::instance()->ServersListChanged.connect ( + boost::bind (&ServersListDialog::servers_list_changed, this) + ); + servers_list_changed (); } void -ServersListDialog::server_found (ServerDescription s) +ServersListDialog::servers_list_changed () { - wxListItem list_item; - int const n = _list->GetItemCount (); - list_item.SetId (n); - _list->InsertItem (list_item); - - _list->SetItem (n, 0, std_to_wx (s.host_name ())); - _list->SetItem (n, 1, std_to_wx (lexical_cast (s.threads ()))); - - _servers.push_back (s); + _list->DeleteAllItems (); + + int n = 0; + + BOOST_FOREACH (EncodeServerDescription i, EncodeServerFinder::instance()->servers()) { + wxListItem list_item; + list_item.SetId (n); + _list->InsertItem (list_item); + + _list->SetItem (n, 0, std_to_wx (i.host_name ())); + if (i.current_link_version()) { + _list->SetItem (n, 1, std_to_wx (lexical_cast (i.threads ()))); + } else { + _list->SetItem (n, 1, _("Incorrect version")); + } + ++n; + } }