X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fserver_dialog.cc;h=abad589891231e0de8e876039df6b03424e43855;hb=9001a63be211fd8e97431f8fc07c66af01554f5a;hp=a0f1f04aea49098fd53492d270d9f4a452c686cd;hpb=74a8d26a8907c6e00e29f054178a3425f44e38ed;p=dcpomatic.git diff --git a/src/wx/server_dialog.cc b/src/wx/server_dialog.cc index a0f1f04ae..abad58989 100644 --- a/src/wx/server_dialog.cc +++ b/src/wx/server_dialog.cc @@ -1,83 +1,56 @@ /* Copyright (C) 2012 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 "lib/server.h" +#include "lib/encode_server.h" #include "server_dialog.h" #include "wx_util.h" +using std::string; using boost::shared_ptr; +using boost::optional; -ServerDialog::ServerDialog (wxWindow* parent, shared_ptr server) - : wxDialog (parent, wxID_ANY, _("Server")) +ServerDialog::ServerDialog (wxWindow* parent) + : TableDialog (parent, _("Server"), 2, 1, true) { - if (server) { - _server = server; - } else { - _server.reset (new ServerDescription (wx_to_std (N_("localhost")), 1)); - } - - wxFlexGridSizer* table = new wxFlexGridSizer (2, DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); - table->AddGrowableCol (1, 1); - - add_label_to_sizer (table, this, _("Host name or IP address"), true); - _host = new wxTextCtrl (this, wxID_ANY); - table->Add (_host, 1, wxEXPAND); - - add_label_to_sizer (table, this, _("Threads to use"), true); - _threads = new wxSpinCtrl (this, wxID_ANY); - table->Add (_threads, 1, wxEXPAND); - - _host->Bind (wxEVT_COMMAND_TEXT_UPDATED, boost::bind (&ServerDialog::host_changed, this)); - _threads->SetRange (0, 256); - _threads->Bind (wxEVT_COMMAND_SPINCTRL_UPDATED, boost::bind (&ServerDialog::threads_changed, this)); - - _host->SetValue (std_to_wx (_server->host_name ())); - _threads->SetValue (_server->threads ()); + wxClientDC dc (parent); + /* XXX: bit of a mystery why we need such a long string here */ + wxSize size = dc.GetTextExtent (wxT ("255.255.255.255.255.255.255.255")); + size.SetHeight (-1); - wxBoxSizer* overall_sizer = new wxBoxSizer (wxVERTICAL); - overall_sizer->Add (table, 1, wxEXPAND | wxALL, 6); + wxTextValidator validator (wxFILTER_INCLUDE_CHAR_LIST); + wxArrayString list; - wxSizer* buttons = CreateSeparatedButtonSizer (wxOK); - if (buttons) { - overall_sizer->Add (buttons, wxSizerFlags().Expand().DoubleBorder()); - } + add (_("Host name or IP address"), true); + _host = add (new wxTextCtrl (this, wxID_ANY, wxT (""), wxDefaultPosition, size)); - SetSizer (overall_sizer); - overall_sizer->Layout (); - overall_sizer->SetSizeHints (this); + layout (); } void -ServerDialog::host_changed () +ServerDialog::set (string server) { - _server->set_host_name (wx_to_std (_host->GetValue ())); + _host->SetValue (std_to_wx (server)); } -void -ServerDialog::threads_changed () +optional +ServerDialog::get () const { - _server->set_threads (_threads->GetValue ()); + return wx_to_std (_host->GetValue ()); } - -shared_ptr -ServerDialog::server () const -{ - return _server; -} -