X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fsystem_font_dialog.cc;h=1681dd1e3744f5e485bc3bc829acef6094e20ba6;hb=6d686ea45f5cd01a0d11f92a903ac77779ad8562;hp=3921be728b6265cdbfec00d18e92889fb3dddb35;hpb=1858190cff2f960f3d1f0a5cc02c69da86088f5b;p=dcpomatic.git diff --git a/src/wx/system_font_dialog.cc b/src/wx/system_font_dialog.cc index 3921be728..1681dd1e3 100644 --- a/src/wx/system_font_dialog.cc +++ b/src/wx/system_font_dialog.cc @@ -1,59 +1,58 @@ /* - Copyright (C) 2015 Carl Hetherington + Copyright (C) 2015-2021 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 "system_font_dialog.h" #include "wx_util.h" +#include +LIBDCP_DISABLE_WARNINGS #include +LIBDCP_ENABLE_WARNINGS #include -#include -#include -using std::cout; + using std::string; using boost::optional; + SystemFontDialog::SystemFontDialog (wxWindow* parent) : wxDialog (parent, wxID_ANY, _("Choose a font")) { - wxSizer* sizer = new wxBoxSizer (wxVERTICAL); + auto sizer = new wxBoxSizer (wxVERTICAL); boost::filesystem::path fonts = "c:\\Windows\\Fonts"; - char* windir = getenv ("windir"); + auto windir = getenv ("windir"); if (windir) { fonts = boost::filesystem::path (windir) / "Fonts"; } - for ( - boost::filesystem::directory_iterator i = boost::filesystem::directory_iterator (fonts); - i != boost::filesystem::directory_iterator (); - ++i - ) { - - string ext = i->path().extension().string (); + for (auto i: boost::filesystem::directory_iterator (fonts)) { + auto ext = i.path().extension().string(); transform (ext.begin(), ext.end(), ext.begin(), ::tolower); if (ext == ".ttf") { - _fonts.push_back (i->path()); + _fonts.push_back (i.path()); } } - sort (_fonts.begin (), _fonts.end ()); + sort (_fonts.begin(), _fonts.end()); _list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_REPORT | wxLC_NO_HEADER); _list->InsertColumn (0, wxT ("")); @@ -61,42 +60,44 @@ SystemFontDialog::SystemFontDialog (wxWindow* parent) sizer->Add (_list, 0, wxALL, DCPOMATIC_SIZER_X_GAP); int n = 0; - BOOST_FOREACH (boost::filesystem::path i, _fonts) { + for (auto i: _fonts) { _list->InsertItem (n++, std_to_wx (i.leaf().stem().string ())); } - wxSizer* buttons = CreateSeparatedButtonSizer (wxOK | wxCANCEL); + auto buttons = CreateSeparatedButtonSizer (wxOK | wxCANCEL); if (buttons) { sizer->Add (buttons, wxSizerFlags().Expand().DoubleBorder()); } SetSizerAndFit (sizer); - _list->Bind (wxEVT_COMMAND_LIST_ITEM_SELECTED, boost::bind (&SystemFontDialog::setup_sensitivity, this)); - _list->Bind (wxEVT_COMMAND_LIST_ITEM_DESELECTED, boost::bind (&SystemFontDialog::setup_sensitivity, this)); + _list->Bind (wxEVT_LIST_ITEM_SELECTED, boost::bind (&SystemFontDialog::setup_sensitivity, this)); + _list->Bind (wxEVT_LIST_ITEM_DESELECTED, boost::bind (&SystemFontDialog::setup_sensitivity, this)); setup_sensitivity (); } + optional SystemFontDialog::get_font () const { int const s = _list->GetNextItem (-1, wxLIST_NEXT_ALL, wxLIST_STATE_SELECTED); if (s == -1) { - return optional (); + return {}; } - if (s < int (_fonts.size ())) { + if (s < int(_fonts.size())) { return _fonts[s]; } - return optional (); + return {}; } + void SystemFontDialog::setup_sensitivity () { - wxButton* ok = dynamic_cast (FindWindowById (wxID_OK, this)); + auto ok = dynamic_cast (FindWindowById(wxID_OK, this)); if (ok) { ok->Enable (_list->GetNextItem (-1, wxLIST_NEXT_ALL, wxLIST_STATE_SELECTED) != -1); }