ardour/gtk2_ardour/toolbar_test.cc
Robin Gareus 1698928f3d
Transmitter::Debug implementation 2/2
This also sorts switch() and listen_to() statements in order
of severity: debug, info, warning, error, fatal, throw.
2020-10-13 21:58:29 +02:00

309 lines
7.4 KiB
C++

#include <fstream>
#include <glibmm.h>
#include <gtkmm/main.h>
#include <gtkmm/box.h>
#include <gtkmm/window.h>
#include "pbd/debug.h"
#include "pbd/enumwriter.h"
#include "pbd/error.h"
#include "pbd/failed_constructor.h"
#include "pbd/pthread_utils.h"
#include "pbd/receiver.h"
#include "pbd/transmitter.h"
#include "ardour/audioengine.h"
#include "ardour/filename_extensions.h"
#include "ardour/types.h"
#include "gtkmm2ext/actions.h"
#include "gtkmm2ext/application.h"
#include "gtkmm2ext/window_title.h"
#include "gtkmm2ext/gtk_ui.h"
#include "gtkmm2ext/utils.h"
#include "canvas/types.h"
#include "canvas/canvas.h"
#include "canvas/container.h"
#include "gtkmm2ext/colors.h"
#include "canvas/debug.h"
#include "canvas/grid.h"
#include "canvas/scroll_group.h"
#include "canvas/text.h"
#include "canvas/widget.h"
#include "ardour_button.h"
#include "enums.h"
#include "ui_config.h"
#include "pbd/i18n.h"
using namespace std;
using namespace ARDOUR;
using namespace PBD;
using namespace Gtkmm2ext;
using namespace Gtk;
#include "ardour/vst_types.h"
static const char* localedir = LOCALEDIR;
int vstfx_init (void*) { return 0; }
void vstfx_exit () {}
void vstfx_destroy_editor (VSTState*) {}
class LogReceiver : public Receiver
{
protected:
void receive (Transmitter::Channel chn, const char * str);
};
static LogReceiver log_receiver;
void
LogReceiver::receive (Transmitter::Channel chn, const char * str)
{
const char *prefix = "";
switch (chn) {
case Transmitter::Debug:
/* ignore */
return;
case Transmitter::Info:
prefix = "[INFO]: ";
break;
case Transmitter::Warning:
prefix = "[WARNING]: ";
break;
case Transmitter::Error:
prefix = "[ERROR]: ";
break;
case Transmitter::Fatal:
prefix = "[FATAL]: ";
break;
case Transmitter::Throw:
/* this isn't supposed to happen */
cerr << "Game Over\n";
abort ();
}
/* note: iostreams are already thread-safe: no external
lock required.
*/
std::cout << prefix << str << std::endl;
if (chn == Transmitter::Fatal) {
::exit (9);
}
}
/* ***************************************************************************/
/* ***************************************************************************/
/* ***************************************************************************/
void
setup_action_button (ArdourButton& button, std::string const & action, ArdourWidgets::ArdourIcon::Icon icon, std::string const & button_theme_name)
{
button.set_name (button_theme_name + string (" button"));
Glib::RefPtr<Gtk::Action> act;
act = ActionManager::get_action (action.c_str());
button.set_related_action (act);
button.set_icon (icon);
}
ArdourButton*
make_action_button (std::string const & action, ArdourWidgets::ArdourIcon::Icon icon, std::string const & button_theme_name)
{
ArdourButton* button = new ArdourButton;
setup_action_button (*button, action, icon, button_theme_name);
return button;
}
class CANVAS_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr
{
public:
CANVAS_UI (int *argcp, char **argvp[], const char* localedir);
~CANVAS_UI();
private:
int starting ();
bool main_window_delete_event (GdkEventAny* ev) { finish (); return true; }
void finish () { quit (); }
Gtk::Window _main_window;
void initialize_canvas (ArdourCanvas::Canvas& canvas, std::string const & toolbar_path);
void build_toolbar (ArdourCanvas::Item* parent, std::string const& toolbar_path);
void canvas_size_request (Gtk::Requisition* req);
void canvas_size_allocated (Gtk::Allocation& alloc);
ArdourCanvas::GtkCanvas* canvas;
ArdourCanvas::Container* group;
ArdourButton test_button;
};
/* ***************************************************************************/
CANVAS_UI::CANVAS_UI (int *argcp, char **argvp[], const char* localedir)
: Gtkmm2ext::UI (PROGRAM_NAME, X_("gui"), argcp, argvp)
{
Gtkmm2ext::init (localedir);
UIConfiguration::instance().post_gui_init ();
Gtkmm2ext::WindowTitle title ("Canvas Toolbar Test");
_main_window.set_title (title.get_string());
_main_window.set_flags (CAN_FOCUS);
_main_window.signal_delete_event().connect (sigc::mem_fun (*this, &CANVAS_UI::main_window_delete_event));
canvas = new ArdourCanvas::GtkCanvas ();
initialize_canvas (*canvas, (*argvp)[1]);
canvas->signal_size_request().connect (sigc::mem_fun (*this, &CANVAS_UI::canvas_size_request));
canvas->signal_size_allocate().connect (sigc::mem_fun (*this, &CANVAS_UI::canvas_size_allocated));
_main_window.add (*canvas);
_main_window.show_all ();
}
CANVAS_UI::~CANVAS_UI ()
{
}
int
CANVAS_UI::starting ()
{
Application* app = Application::instance ();
app->ready ();
return 0;
}
void
CANVAS_UI::initialize_canvas (ArdourCanvas::Canvas& canvas, std::string const & spec_path)
{
using namespace ArdourCanvas;
canvas.set_background_color (rgba_to_color (0.0, 0.0, 0.4, 1.0));
ScrollGroup* scroll_group = new ScrollGroup (canvas.root(),
ScrollGroup::ScrollSensitivity (ScrollGroup::ScrollsVertically|ScrollGroup::ScrollsHorizontally));
build_toolbar (scroll_group, spec_path);
}
void
CANVAS_UI::build_toolbar (ArdourCanvas::Item* parent, std::string const & spec_path)
{
ArdourCanvas::Grid* grid = new ArdourCanvas::Grid (parent);
grid->set_padding (3.0);
grid->set_row_spacing (3.0);
grid->set_col_spacing (3.0);
grid->set_homogenous (true);
std::ifstream toolbar_spec;
double col = 0;
double row = 0;
toolbar_spec.open (spec_path.c_str(), ios::in);
if (!toolbar_spec) {
return;
}
while (toolbar_spec) {
string action;
string icon;
string theme_name;
toolbar_spec >> action;
if (action.empty()) {
break;
}
toolbar_spec >> icon;
if (icon.empty()) {
break;
}
toolbar_spec >> theme_name;
if (theme_name.empty()) {
break;
}
ArdourWidgets::ArdourIcon::Icon i = (ArdourWidgets::ArdourIcon::Icon) string_2_enum (string ("ArdourIcon::") + icon, i);
ArdourCanvas::Widget* w = new ArdourCanvas::Widget (canvas, *make_action_button (action, i, theme_name));
grid->place (w, col, row);
col++;
}
toolbar_spec.close ();
}
void
CANVAS_UI::canvas_size_request (Gtk::Requisition* req)
{
ArdourCanvas::Rect bbox = canvas->root()->bounding_box();
req->width = bbox.width();
req->height = bbox.height();
}
void
CANVAS_UI::canvas_size_allocated (Gtk::Allocation& alloc)
{
}
/* ***************************************************************************/
/* ***************************************************************************/
/* ***************************************************************************/
static CANVAS_UI *ui = 0;
int main (int argc, char **argv)
{
#if 0
fixup_bundle_environment (argc, argv, localedir);
load_custom_fonts();
// TODO setlocale..
#endif
if (!ARDOUR::init (false, true, localedir)) {
cerr << "Ardour failed to initialize\n" << endl;
::exit (EXIT_FAILURE);
}
if (!Glib::thread_supported()) {
Glib::thread_init();
}
pthread_setcanceltype (PTHREAD_CANCEL_ASYNCHRONOUS, 0);
log_receiver.listen_to (info);
log_receiver.listen_to (warning);
log_receiver.listen_to (error);
log_receiver.listen_to (fatal);
setup_gtk_ardour_enums ();
if (UIConfiguration::instance().pre_gui_init ()) {
error << _("Could not complete pre-GUI initialization") << endmsg;
exit (1);
}
// we could load a session here, if needed
// see ../session_utils/common.cc
ui = new CANVAS_UI (&argc, &argv, localedir);
ui->run (log_receiver);
info << "Farewell" << endmsg;
Gtkmm2ext::Application::instance()->cleanup();
delete ui;
ui = 0;
ARDOUR::cleanup ();
pthread_cancel_all ();
return 0;
}