X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fsystem_font_dialog.cc;h=84285de12e35c6d0e6f09a4f5f0bff7dc3e10ed5;hb=8a04d3d74cdb756baa399cc7693393285b064c59;hp=167f7f75d58729e91fb48e3e19b03572313c6941;hpb=ad5c8849fc3ef5aad88201f28db5474a60db4436;p=dcpomatic.git diff --git a/src/wx/system_font_dialog.cc b/src/wx/system_font_dialog.cc index 167f7f75d..84285de12 100644 --- a/src/wx/system_font_dialog.cc +++ b/src/wx/system_font_dialog.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2015 Carl Hetherington + Copyright (C) 2015-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,43 +18,42 @@ */ + #include "system_font_dialog.h" #include "wx_util.h" +#include +#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: dcp::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 ("")); @@ -62,11 +61,11 @@ 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()); } @@ -79,25 +78,27 @@ SystemFontDialog::SystemFontDialog (wxWindow* parent) 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); }