X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fprop%2Fbinding%2Fbinding.cpp;h=86318139673a72bb71d6f89010361519c7284a5c;hp=7d38cb4629b5498c5d9cd0bc92dd4982909b8177;hb=e8d009288de28cb194bc7964f96677c2baf900c9;hpb=479bcabe6b4d0b1f51984085d9944ce6b03ed07c diff --git a/pv/prop/binding/binding.cpp b/pv/prop/binding/binding.cpp index 7d38cb46..86318139 100644 --- a/pv/prop/binding/binding.cpp +++ b/pv/prop/binding/binding.cpp @@ -18,17 +18,77 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ +#include + +#include + +#include + #include "binding.h" +using std::shared_ptr; + namespace pv { namespace prop { namespace binding { -const std::vector< boost::shared_ptr >& Binding::properties() +const std::vector< std::shared_ptr >& Binding::properties() { return _properties; } +void Binding::commit() +{ + for (shared_ptr p : _properties) { + assert(p); + p->commit(); + } +} + +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; +} + +QString Binding::print_gvariant(Glib::VariantBase gvar) +{ + QString s; + + if (!gvar.gobj()) + s = QString::fromStdString("(null)"); + else if (gvar.is_of_type(Glib::VariantType("s"))) + s = QString::fromStdString( + Glib::VariantBase::cast_dynamic>( + gvar).get()); + else + s = QString::fromStdString(gvar.print()); + + return s; +} + } // binding } // prop } // pv