X-Git-Url: http://git.code-monkey.de/?a=blobdiff_plain;ds=sidebyside;f=pv%2Fprop%2Fbinding%2Fbinding.cpp;h=1a5eb5ec097a32994d04e3057db5090bd41aee77;hb=d9aecf1fcd9af471db3b59de7efc65b9632a6d79;hp=3c9bba5aee16483c14596def207d5ca6d0b0249b;hpb=8481fbdf89e8f26a0d5ef0b69e32d25be5e2f6e4;p=pulseview.git diff --git a/pv/prop/binding/binding.cpp b/pv/prop/binding/binding.cpp index 3c9bba5..1a5eb5e 100644 --- a/pv/prop/binding/binding.cpp +++ b/pv/prop/binding/binding.cpp @@ -18,15 +18,13 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ -#include - #include #include #include "binding.h" -using namespace boost; +using boost::shared_ptr; namespace pv { namespace prop { @@ -39,26 +37,54 @@ const std::vector< boost::shared_ptr >& Binding::properties() void Binding::commit() { - BOOST_FOREACH(shared_ptr p, _properties) { + for (shared_ptr p : _properties) { assert(p); p->commit(); } } -QWidget* Binding::get_property_form(QWidget *parent) const +void Binding::add_properties_to_form(QFormLayout *layout, + bool auto_commit) const +{ + assert(layout); + + for (shared_ptr p : _properties) + { + assert(p); + + QWidget *const widget = p->get_widget(layout->parentWidget(), + auto_commit); + if (p->labeled_widget()) + layout->addRow(widget); + else + layout->addRow(p->name(), widget); + } +} + +QWidget* Binding::get_property_form(QWidget *parent, + bool auto_commit) const { QWidget *const form = new QWidget(parent); QFormLayout *const layout = new QFormLayout(form); form->setLayout(layout); + add_properties_to_form(layout, auto_commit); + return form; +} - BOOST_FOREACH(shared_ptr p, _properties) +QString Binding::print_gvariant(GVariant *const gvar) +{ + QString s; + + if (g_variant_is_of_type(gvar, G_VARIANT_TYPE("s"))) + s = QString::fromUtf8(g_variant_get_string(gvar, NULL)); + else { - assert(p); - const QString label = p->labeled_widget() ? QString() : p->name(); - layout->addRow(label, p->get_widget(form)); + gchar *const text = g_variant_print(gvar, FALSE); + s = QString::fromUtf8(text); + g_free(text); } - return form; + return s; } } // binding