Moved GroupButtons to gtkmm2ext

Fixed stacktrace.cc compilation.


git-svn-id: svn://localhost/ardour2/trunk@1403 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
Taybin Rutkin
2007-02-01 13:17:04 +00:00
parent 43a063d8c6
commit b05c4dc540
7 changed files with 4 additions and 6 deletions

View File

@@ -40,6 +40,7 @@ click_box.cc
dndtreeview.cc
fastmeter.cc
focus_entry.cc
grouped_buttons.cc
gtk_ui.cc
hexentry.cc
idle_adjustment.cc

View File

@@ -0,0 +1,96 @@
/*
Copyright (C) 2001 Paul Davis
This program 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,
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.
$Id$
*/
#include <gtkmm.h>
#include <gtkmm2ext/grouped_buttons.h>
using namespace std;
GroupedButtons::GroupedButtons (vector<Gtk::ToggleButton *>& buttonset)
{
uint32_t n = 0;
buttons = buttonset;
for (vector<Gtk::ToggleButton *>::iterator i = buttons.begin(); i != buttons.end(); ++i, ++n) {
if ((*i)->get_active()) {
current_active = n;
}
(*i)->signal_clicked().connect (sigc::bind (mem_fun (*this, &GroupedButtons::one_clicked), n));
}
}
GroupedButtons::GroupedButtons (uint32_t nbuttons, uint32_t first_active)
{
buttons.reserve (nbuttons);
current_active = first_active;
for (uint32_t n = 0; n < nbuttons; ++n) {
Gtk::ToggleButton *button;
button = manage (new (Gtk::ToggleButton));
if (n == current_active) {
button->set_active (true);
}
button->signal_clicked().connect (sigc::bind (mem_fun (*this, &GroupedButtons::one_clicked), n));
buttons.push_back (button);
}
}
static gint
reactivate_button (void *arg)
{
Gtk::ToggleButton *b = (Gtk::ToggleButton *) arg;
b->set_active (true);
return FALSE;
}
void
GroupedButtons::one_clicked (uint32_t which)
{
if (buttons[which]->get_active()) {
if (which != current_active) {
uint32_t old = current_active;
current_active = which;
buttons[old]->set_active (false);
}
} else if (which == current_active) {
/* Someobody tried to unset the current active
button by clicking on it. This caused
set_active (false) to be called. We don't
allow that, so just reactivate it.
Don't try this right here, because of some
design glitches with GTK+ toggle buttons.
Setting the button back to active from
within the signal emission that marked
it as inactive causes a segfault ...
*/
gtk_idle_add (reactivate_button, buttons[which]);
}
}

View File

@@ -0,0 +1,49 @@
/*
Copyright (C) 2001 Paul Davis
This program 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,
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.
$Id$
*/
#ifndef __gtkmm2ext_grouped_buttons_h__
#define __gtkmm2ext_grouped_buttons_h__
#include <stdint.h>
#include <vector>
#include <sigc++/signal.h>
namespace Gtk {
class ToggleButton;
};
class GroupedButtons : public sigc::trackable
{
public:
GroupedButtons (uint32_t nbuttons, uint32_t first_active);
GroupedButtons (std::vector<Gtk::ToggleButton *>&);
Gtk::ToggleButton& button (uint32_t which) {
return *buttons[which];
}
private:
std::vector<Gtk::ToggleButton *> buttons;
uint32_t current_active;
void one_clicked (uint32_t which);
};
#endif /* __gtkmm2ext_grouped_buttons_h__ */

View File

@@ -42,7 +42,7 @@ PBD::stacktrace (std::ostream& out, int levels)
void
c_stacktrace ()
{
PBD::stacktrace (cout);
PBD::stacktrace (std::cout);
}
#endif /* HAVE_EXECINFO */