X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Fwx%2Fservers_list_dialog.cc;h=37a14338431f3f44dea91f44314aa2ef55d2edf6;hp=be69a14ed47a4df5900880f3a9f20205bebf76d8;hb=9106e6ed551b13e1b7c7ee2088d54ce0ae430bcf;hpb=59602b67d0637817a156b7bd0fc05f96fe41dee5 diff --git a/src/wx/servers_list_dialog.cc b/src/wx/servers_list_dialog.cc index be69a14ed..37a143384 100644 --- a/src/wx/servers_list_dialog.cc +++ b/src/wx/servers_list_dialog.cc @@ -1,26 +1,29 @@ /* - Copyright (C) 2013 Carl Hetherington + 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; @@ -31,8 +34,8 @@ 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); } @@ -60,20 +63,31 @@ ServersListDialog::ServersListDialog (wxWindow* parent) SetSizer (s); s->Layout (); s->SetSizeHints (this); - - 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->DeleteAllItems (); + + int n = 0; - _list->SetItem (n, 0, std_to_wx (s.host_name ())); - _list->SetItem (n, 1, std_to_wx (lexical_cast (s.threads ()))); + BOOST_FOREACH (EncodeServerDescription i, EncodeServerFinder::instance()->servers()) { + wxListItem list_item; + list_item.SetId (n); + _list->InsertItem (list_item); - _servers.push_back (s); + _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; + } }