]> sigrok.org Git - libsigrok.git/blobdiff - bindings/cxx/classes.cpp
C++: Make value get accessors const
[libsigrok.git] / bindings / cxx / classes.cpp
index a00f2967e45161e56b0d2df829cfa9c915ede926..960ac39bc0524a5f0ae7f59604f1fa24eeefcee6 100644 (file)
@@ -39,19 +39,16 @@ static void check(int result)
 }
 
 /** Helper function to obtain valid strings from possibly null input. */
-static const char *valid_string(const char *input)
+static inline const char *valid_string(const char *input)
 {
-       if (input != NULL)
-               return input;
-       else
-               return "";
+       return (input) ? input : "";
 }
 
 /** Helper function to convert between map<string, VariantBase> and GHashTable */
 static GHashTable *map_to_hash_variant(const map<string, Glib::VariantBase> &input)
 {
-       auto output = g_hash_table_new_full(
-               g_str_hash, g_str_equal, g_free, (GDestroyNotify) g_variant_unref);
+       auto output = g_hash_table_new_full(g_str_hash, g_str_equal, g_free,
+                       reinterpret_cast<GDestroyNotify>(&g_variant_unref));
        for (auto entry : input)
                g_hash_table_insert(output,
                        g_strdup(entry.first.c_str()),
@@ -63,12 +60,12 @@ Error::Error(int result) : result(result)
 {
 }
 
-const char *Error::what() const throw()
+const char *Error::what() const noexcept
 {
        return sr_strerror(result);
 }
 
-Error::~Error() throw()
+Error::~Error() noexcept
 {
 }
 
@@ -77,7 +74,7 @@ ResourceReader::~ResourceReader()
 }
 
 SR_PRIV int ResourceReader::open_callback(struct sr_resource *res,
-               const char *name, void *cb_data)
+               const char *name, void *cb_data) noexcept
 {
        try {
                auto *const reader = static_cast<ResourceReader*>(cb_data);
@@ -90,7 +87,8 @@ SR_PRIV int ResourceReader::open_callback(struct sr_resource *res,
        return SR_OK;
 }
 
-SR_PRIV int ResourceReader::close_callback(struct sr_resource *res, void *cb_data)
+SR_PRIV int ResourceReader::close_callback(struct sr_resource *res,
+               void *cb_data) noexcept
 {
        try {
                auto *const reader = static_cast<ResourceReader*>(cb_data);
@@ -104,7 +102,7 @@ SR_PRIV int ResourceReader::close_callback(struct sr_resource *res, void *cb_dat
 }
 
 SR_PRIV ssize_t ResourceReader::read_callback(const struct sr_resource *res,
-               void *buf, size_t count, void *cb_data)
+               void *buf, size_t count, void *cb_data) noexcept
 {
        try {
                auto *const reader = static_cast<ResourceReader*>(cb_data);
@@ -123,7 +121,7 @@ shared_ptr<Context> Context::create()
 
 Context::Context() :
        UserOwned(_structure),
-       _session(NULL)
+       _session(nullptr)
 {
        check(sr_init(&_structure));
 
@@ -201,7 +199,7 @@ Context::~Context()
        check(sr_exit(_structure));
 }
 
-const LogLevel *Context::log_level()
+const LogLevel *Context::log_level() const
 {
        return LogLevel::get(sr_log_loglevel_get());
 }
@@ -211,22 +209,17 @@ void Context::set_log_level(const LogLevel *level)
        check(sr_log_loglevel_set(level->id()));
 }
 
-static int call_log_callback(void *cb_data, int loglevel, const char *format, va_list args)
+static int call_log_callback(void *cb_data, int loglevel,
+               const char *format, va_list args) noexcept
 {
-       va_list args_copy;
-       va_copy(args_copy, args);
-       int length = vsnprintf(NULL, 0, format, args_copy);
-       va_end(args_copy);
-       char *buf = (char *) g_malloc(length + 1);
-       vsprintf(buf, format, args);
-       string message(buf, length);
-       g_free(buf);
+       const unique_ptr<char, decltype(&g_free)>
+               message {g_strdup_vprintf(format, args), &g_free};
 
-       LogCallbackFunction callback = *((LogCallbackFunction *) cb_data);
+       auto *const callback = static_cast<LogCallbackFunction *>(cb_data);
 
        try
        {
-               callback(LogLevel::get(loglevel), message);
+               (*callback)(LogLevel::get(loglevel), message.get());
        }
        catch (Error e)
        {
@@ -332,9 +325,9 @@ shared_ptr<Packet> Context::create_analog_packet(
        for (auto channel : channels)
                meaning->channels = g_slist_append(meaning->channels, channel->_structure);
        analog->num_samples = num_samples;
-       meaning->mq = (sr_mq)mq->id();
-       meaning->unit = (sr_unit)unit->id();
-       meaning->mqflags = (sr_mqflag)QuantityFlag::mask_from_flags(mqflags);
+       meaning->mq = static_cast<sr_mq>(mq->id());
+       meaning->unit = static_cast<sr_unit>(unit->id());
+       meaning->mqflags = static_cast<sr_mqflag>(QuantityFlag::mask_from_flags(mqflags));
        analog->data = data_pointer;
        auto packet = g_new(struct sr_datafeed_packet, 1);
        packet->type = SR_DF_ANALOG;
@@ -375,23 +368,24 @@ shared_ptr<Input> Context::open_stream(string header)
                new Input(shared_from_this(), input), Input::Deleter());
 }
 
-map<string, string> Context::serials(shared_ptr<Driver> driver)
+map<string, string> Context::serials(shared_ptr<Driver> driver) const
 {
-       GSList *serial_list = sr_serial_list(driver ? driver->_structure : NULL);
+       GSList *serial_list = sr_serial_list(driver ? driver->_structure : nullptr);
        map<string, string> serials;
 
        for (GSList *serial = serial_list; serial; serial = serial->next) {
-               struct sr_serial_port *port = (sr_serial_port *) serial->data;
+               auto *const port = static_cast<sr_serial_port *>(serial->data);
                serials[string(port->name)] = string(port->description);
        }
 
-       g_slist_free_full(serial_list, (GDestroyNotify)sr_serial_free);
+       g_slist_free_full(serial_list,
+               reinterpret_cast<GDestroyNotify>(&sr_serial_free));
        return serials;
 }
 
 Driver::Driver(struct sr_dev_driver *structure) :
        ParentOwned(structure),
-       Configurable(structure, NULL, NULL),
+       Configurable(structure, nullptr, nullptr),
        _initialized(false)
 {
 }
@@ -400,12 +394,12 @@ Driver::~Driver()
 {
 }
 
-string Driver::name()
+string Driver::name() const
 {
        return valid_string(_structure->name);
 }
 
-string Driver::long_name()
+string Driver::long_name() const
 {
        return valid_string(_structure->longname);
 }
@@ -421,7 +415,7 @@ vector<shared_ptr<HardwareDevice>> Driver::scan(
        }
 
        /* Translate scan options to GSList of struct sr_config pointers. */
-       GSList *option_list = NULL;
+       GSList *option_list = nullptr;
        for (auto entry : options)
        {
                auto key = entry.first;
@@ -443,7 +437,7 @@ vector<shared_ptr<HardwareDevice>> Driver::scan(
        vector<shared_ptr<HardwareDevice>> result;
        for (GSList *device = device_list; device; device = device->next)
        {
-               auto sdi = (struct sr_dev_inst *) device->data;
+               auto *const sdi = static_cast<struct sr_dev_inst *>(device->data);
                result.push_back(shared_ptr<HardwareDevice>(
                        new HardwareDevice(shared_from_this(), sdi),
                        HardwareDevice::Deleter()));
@@ -469,7 +463,7 @@ Configurable::~Configurable()
 {
 }
 
-Glib::VariantBase Configurable::config_get(const ConfigKey *key)
+Glib::VariantBase Configurable::config_get(const ConfigKey *key) const
 {
        GVariant *data;
        check(sr_config_get(
@@ -485,7 +479,7 @@ void Configurable::config_set(const ConfigKey *key, const Glib::VariantBase &val
                key->id(), const_cast<GVariant*>(value.gobj())));
 }
 
-Glib::VariantContainerBase Configurable::config_list(const ConfigKey *key)
+Glib::VariantContainerBase Configurable::config_list(const ConfigKey *key) const
 {
        GVariant *data;
        check(sr_config_list(
@@ -505,8 +499,8 @@ map<const ConfigKey *, set<Capability>> Configurable::config_keys(const ConfigKe
                config_driver, config_sdi, config_channel_group,
                key->id(), &gvar_opts));
 
-       opts = (const uint32_t *) g_variant_get_fixed_array(
-               gvar_opts, &num_opts, sizeof(uint32_t));
+       opts = static_cast<const uint32_t *>(g_variant_get_fixed_array(
+               gvar_opts, &num_opts, sizeof(uint32_t)));
 
        for (gsize i = 0; i < num_opts; i++)
        {
@@ -527,7 +521,7 @@ map<const ConfigKey *, set<Capability>> Configurable::config_keys(const ConfigKe
 }
 
 bool Configurable::config_check(const ConfigKey *key,
-       const ConfigKey *index_key)
+       const ConfigKey *index_key) const
 {
        GVariant *gvar_opts;
        gsize num_opts;
@@ -537,12 +531,12 @@ bool Configurable::config_check(const ConfigKey *key,
                        index_key->id(), &gvar_opts) != SR_OK)
                return false;
 
-       opts = (const uint32_t *) g_variant_get_fixed_array(
-               gvar_opts, &num_opts, sizeof(uint32_t));
+       opts = static_cast<const uint32_t *>(g_variant_get_fixed_array(
+               gvar_opts, &num_opts, sizeof(uint32_t)));
 
        for (gsize i = 0; i < num_opts; i++)
        {
-               if ((opts[i] & SR_CONF_MASK) == (uint32_t) key->id())
+               if ((opts[i] & SR_CONF_MASK) == unsigned(key->id()))
                {
                        g_variant_unref(gvar_opts);
                        return true;
@@ -555,18 +549,18 @@ bool Configurable::config_check(const ConfigKey *key,
 }
 
 Device::Device(struct sr_dev_inst *structure) :
-       Configurable(sr_dev_inst_driver_get(structure), structure, NULL),
+       Configurable(sr_dev_inst_driver_get(structure), structure, nullptr),
        _structure(structure)
 {
        for (GSList *entry = sr_dev_inst_channels_get(structure); entry; entry = entry->next)
        {
-               auto channel = (struct sr_channel *) entry->data;
+               auto *const channel = static_cast<struct sr_channel *>(entry->data);
                _channels[channel] = new Channel(channel);
        }
 
        for (GSList *entry = sr_dev_inst_channel_groups_get(structure); entry; entry = entry->next)
        {
-               auto group = (struct sr_channel_group *) entry->data;
+               auto *const group = static_cast<struct sr_channel_group *>(entry->data);
                _channel_groups[group->name] = new ChannelGroup(this, group);
        }
 }
@@ -579,27 +573,27 @@ Device::~Device()
                delete entry.second;
 }
 
-string Device::vendor()
+string Device::vendor() const
 {
        return valid_string(sr_dev_inst_vendor_get(_structure));
 }
 
-string Device::model()
+string Device::model() const
 {
        return valid_string(sr_dev_inst_model_get(_structure));
 }
 
-string Device::version()
+string Device::version() const
 {
        return valid_string(sr_dev_inst_version_get(_structure));
 }
 
-string Device::serial_number()
+string Device::serial_number() const
 {
        return valid_string(sr_dev_inst_sernum_get(_structure));
 }
 
-string Device::connection_id()
+string Device::connection_id() const
 {
        return valid_string(sr_dev_inst_connid_get(_structure));
 }
@@ -607,10 +601,10 @@ string Device::connection_id()
 vector<shared_ptr<Channel>> Device::channels()
 {
        vector<shared_ptr<Channel>> result;
-       for (auto channel = sr_dev_inst_channels_get(_structure); channel; channel = channel->next)
-               result.push_back(
-                       _channels[(struct sr_channel *) channel->data]->get_shared_pointer(
-                               get_shared_from_this()));
+       for (auto channel = sr_dev_inst_channels_get(_structure); channel; channel = channel->next) {
+               auto *const ch = static_cast<struct sr_channel *>(channel->data);
+               result.push_back(_channels[ch]->get_shared_pointer(get_shared_from_this()));
+       }
        return result;
 }
 
@@ -685,11 +679,10 @@ shared_ptr<Channel> UserDevice::add_channel(unsigned int index,
 {
        check(sr_dev_inst_channel_add(Device::_structure,
                index, type->id(), name.c_str()));
-       struct sr_channel *structure = (struct sr_channel *)
-                       g_slist_last(sr_dev_inst_channels_get(Device::_structure))->data;
-       Channel *channel = new Channel(structure);
-       _channels[structure] = channel;
-       return get_channel(structure);
+       GSList *const last = g_slist_last(sr_dev_inst_channels_get(Device::_structure));
+       auto *const ch = static_cast<struct sr_channel *>(last->data);
+       _channels[ch] = new Channel(ch);
+       return get_channel(ch);
 }
 
 Channel::Channel(struct sr_channel *structure) :
@@ -702,7 +695,7 @@ Channel::~Channel()
 {
 }
 
-string Channel::name()
+string Channel::name() const
 {
        return valid_string(_structure->name);
 }
@@ -712,12 +705,12 @@ void Channel::set_name(string name)
        check(sr_dev_channel_name_set(_structure, name.c_str()));
 }
 
-const ChannelType *Channel::type()
+const ChannelType *Channel::type() const
 {
        return ChannelType::get(_structure->type);
 }
 
-bool Channel::enabled()
+bool Channel::enabled() const
 {
        return _structure->enabled;
 }
@@ -727,7 +720,7 @@ void Channel::set_enabled(bool value)
        check(sr_dev_channel_enable(_structure, value));
 }
 
-unsigned int Channel::index()
+unsigned int Channel::index() const
 {
        return _structure->index;
 }
@@ -737,15 +730,17 @@ ChannelGroup::ChannelGroup(Device *device,
        ParentOwned(structure),
        Configurable(sr_dev_inst_driver_get(device->_structure), device->_structure, structure)
 {
-       for (GSList *entry = structure->channels; entry; entry = entry->next)
-               _channels.push_back(device->_channels[(struct sr_channel *)entry->data]);
+       for (GSList *entry = structure->channels; entry; entry = entry->next) {
+               auto *const ch = static_cast<struct sr_channel *>(entry->data);
+               _channels.push_back(device->_channels[ch]);
+       }
 }
 
 ChannelGroup::~ChannelGroup()
 {
 }
 
-string ChannelGroup::name()
+string ChannelGroup::name() const
 {
        return valid_string(_structure->name);
 }
@@ -764,7 +759,7 @@ Trigger::Trigger(shared_ptr<Context> context, string name) :
 {
        for (auto stage = _structure->stages; stage; stage = stage->next)
                _stages.push_back(
-                       new TriggerStage((struct sr_trigger_stage *) stage->data));
+                       new TriggerStage(static_cast<struct sr_trigger_stage *>(stage->data)));
 }
 
 Trigger::~Trigger()
@@ -775,7 +770,7 @@ Trigger::~Trigger()
        sr_trigger_free(_structure);
 }
 
-string Trigger::name()
+string Trigger::name() const
 {
        return _structure->name;
 }
@@ -806,7 +801,7 @@ TriggerStage::~TriggerStage()
                delete match;
 }
        
-int TriggerStage::number()
+int TriggerStage::number() const
 {
        return _structure->stage;
 }
@@ -824,9 +819,10 @@ void TriggerStage::add_match(shared_ptr<Channel> channel,
 {
        check(sr_trigger_match_add(_structure,
                channel->_structure, type->id(), value));
+       GSList *const last = g_slist_last(_structure->matches);
        _matches.push_back(new TriggerMatch(
-               (struct sr_trigger_match *) g_slist_last(
-                       _structure->matches)->data, move(channel)));
+               static_cast<struct sr_trigger_match *>(last->data),
+               move(channel)));
 }
 
 void TriggerStage::add_match(shared_ptr<Channel> channel,
@@ -851,12 +847,12 @@ shared_ptr<Channel> TriggerMatch::channel()
        return _channel;
 }
 
-const TriggerMatchType *TriggerMatch::type()
+const TriggerMatchType *TriggerMatch::type() const
 {
        return TriggerMatchType::get(_structure->match);
 }
 
-float TriggerMatch::value()
+float TriggerMatch::value() const
 {
        return _structure->value;
 }
@@ -907,9 +903,8 @@ Session::Session(shared_ptr<Context> context, string filename) :
        check(sr_session_load(_context->_structure, _filename.c_str(), &_structure));
        GSList *dev_list;
        check(sr_session_dev_list(_structure, &dev_list));
-       for (GSList *dev = dev_list; dev; dev = dev->next)
-       {
-               auto sdi = (struct sr_dev_inst *) dev->data;
+       for (GSList *dev = dev_list; dev; dev = dev->next) {
+               auto *const sdi = static_cast<struct sr_dev_inst *>(dev->data);
                _owned_devices[sdi] = new SessionDevice(sdi);
        }
        _context->_session = this;
@@ -949,9 +944,8 @@ vector<shared_ptr<Device>> Session::devices()
        GSList *dev_list;
        check(sr_session_dev_list(_structure, &dev_list));
        vector<shared_ptr<Device>> result;
-       for (GSList *dev = dev_list; dev; dev = dev->next)
-       {
-               auto sdi = (struct sr_dev_inst *) dev->data;
+       for (GSList *dev = dev_list; dev; dev = dev->next) {
+               auto *const sdi = static_cast<struct sr_dev_inst *>(dev->data);
                result.push_back(get_device(sdi));
        }
        return result;
@@ -986,7 +980,7 @@ bool Session::is_running() const
        return (ret != 0);
 }
 
-static void session_stopped_callback(void *data)
+static void session_stopped_callback(void *data) noexcept
 {
        auto *const callback = static_cast<SessionStoppedCallback*>(data);
        (*callback)();
@@ -1004,12 +998,12 @@ void Session::set_stopped_callback(SessionStoppedCallback callback)
 }
 
 static void datafeed_callback(const struct sr_dev_inst *sdi,
-       const struct sr_datafeed_packet *pkt, void *cb_data)
+       const struct sr_datafeed_packet *pkt, void *cb_data) noexcept
 {
        auto callback = static_cast<DatafeedCallbackData *>(cb_data);
        callback->run(sdi, pkt);
 }
-       
+
 void Session::add_datafeed_callback(DatafeedCallbackFunction callback)
 {
        auto cb_data = new DatafeedCallbackData(this, move(callback));
@@ -1035,13 +1029,13 @@ void Session::set_trigger(shared_ptr<Trigger> trigger)
 {
        if (!trigger)
                // Set NULL trigger, i.e. remove any trigger from the session.
-               check(sr_session_trigger_set(_structure, NULL));
+               check(sr_session_trigger_set(_structure, nullptr));
        else
                check(sr_session_trigger_set(_structure, trigger->_structure));
        _trigger = move(trigger);
 }
 
-string Session::filename()
+string Session::filename() const
 {
        return _filename;
 }
@@ -1090,7 +1084,7 @@ Packet::~Packet()
                delete _payload;
 }
 
-const PacketType *Packet::type()
+const PacketType *Packet::type() const
 {
        return PacketType::get(_structure->type);
 }
@@ -1127,12 +1121,12 @@ shared_ptr<PacketPayload> Header::get_shared_pointer(Packet *_parent)
                ParentOwned::get_shared_pointer(_parent));
 }
 
-int Header::feed_version()
+int Header::feed_version() const
 {
        return _structure->feed_version;
 }
 
-Glib::TimeVal Header::start_time()
+Glib::TimeVal Header::start_time() const
 {
        return Glib::TimeVal(
                _structure->starttime.tv_sec,
@@ -1155,12 +1149,11 @@ shared_ptr<PacketPayload> Meta::get_shared_pointer(Packet *_parent)
                ParentOwned::get_shared_pointer(_parent));
 }
 
-map<const ConfigKey *, Glib::VariantBase> Meta::config()
+map<const ConfigKey *, Glib::VariantBase> Meta::config() const
 {
        map<const ConfigKey *, Glib::VariantBase> result;
-       for (auto l = _structure->config; l; l = l->next)
-       {
-               auto config = (struct sr_config *) l->data;
+       for (auto l = _structure->config; l; l = l->next) {
+               auto *const config = static_cast<struct sr_config *>(l->data);
                result[ConfigKey::get(config->key)] = Glib::VariantBase(config->data);
        }
        return result;
@@ -1187,12 +1180,12 @@ void *Logic::data_pointer()
        return _structure->data;
 }
 
-size_t Logic::data_length()
+size_t Logic::data_length() const
 {
        return _structure->length;
 }
 
-unsigned int Logic::unit_size()
+unsigned int Logic::unit_size() const
 {
        return _structure->unitsize;
 }
@@ -1218,7 +1211,7 @@ void *Analog::data_pointer()
        return _structure->data;
 }
 
-unsigned int Analog::num_samples()
+unsigned int Analog::num_samples() const
 {
        return _structure->num_samples;
 }
@@ -1226,23 +1219,24 @@ unsigned int Analog::num_samples()
 vector<shared_ptr<Channel>> Analog::channels()
 {
        vector<shared_ptr<Channel>> result;
-       for (auto l = _structure->meaning->channels; l; l = l->next)
-               result.push_back(_parent->_device->get_channel(
-                       (struct sr_channel *)l->data));
+       for (auto l = _structure->meaning->channels; l; l = l->next) {
+               auto *const ch = static_cast<struct sr_channel *>(l->data);
+               result.push_back(_parent->_device->get_channel(ch));
+       }
        return result;
 }
 
-const Quantity *Analog::mq()
+const Quantity *Analog::mq() const
 {
        return Quantity::get(_structure->meaning->mq);
 }
 
-const Unit *Analog::unit()
+const Unit *Analog::unit() const
 {
        return Unit::get(_structure->meaning->unit);
 }
 
-vector<const QuantityFlag *> Analog::mq_flags()
+vector<const QuantityFlag *> Analog::mq_flags() const
 {
        return QuantityFlag::flags_from_mask(_structure->meaning->mqflags);
 }
@@ -1256,17 +1250,17 @@ InputFormat::~InputFormat()
 {
 }
 
-string InputFormat::name()
+string InputFormat::name() const
 {
        return valid_string(sr_input_id_get(_structure));
 }
 
-string InputFormat::description()
+string InputFormat::description() const
 {
        return valid_string(sr_input_description_get(_structure));
 }
 
-vector<string> InputFormat::extensions()
+vector<string> InputFormat::extensions() const
 {
        vector<string> exts;
        for (const char *const *e = sr_input_extensions_get(_structure);
@@ -1322,7 +1316,7 @@ shared_ptr<InputDevice> Input::device()
 
 void Input::send(void *data, size_t length)
 {
-       auto gstr = g_string_new_len((gchar *)data, length);
+       auto gstr = g_string_new_len(static_cast<char *>(data), length);
        auto ret = sr_input_send(_structure, gstr);
        g_string_free(gstr, false);
        check(ret);
@@ -1368,31 +1362,33 @@ Option::~Option()
 {
 }
 
-string Option::id()
+string Option::id() const
 {
        return valid_string(_structure->id);
 }
 
-string Option::name()
+string Option::name() const
 {
        return valid_string(_structure->name);
 }
 
-string Option::description()
+string Option::description() const
 {
        return valid_string(_structure->desc);
 }
 
-Glib::VariantBase Option::default_value()
+Glib::VariantBase Option::default_value() const
 {
        return Glib::VariantBase(_structure->def, true);
 }
 
-vector<Glib::VariantBase> Option::values()
+vector<Glib::VariantBase> Option::values() const
 {
        vector<Glib::VariantBase> result;
-       for (auto l = _structure->values; l; l = l->next)
-               result.push_back(Glib::VariantBase((GVariant *) l->data, true));
+       for (auto l = _structure->values; l; l = l->next) {
+               auto *const var = static_cast<GVariant *>(l->data);
+               result.push_back(Glib::VariantBase(var, true));
+       }
        return result;
 }
 
@@ -1405,17 +1401,17 @@ OutputFormat::~OutputFormat()
 {
 }
 
-string OutputFormat::name()
+string OutputFormat::name() const
 {
        return valid_string(sr_output_id_get(_structure));
 }
 
-string OutputFormat::description()
+string OutputFormat::description() const
 {
        return valid_string(sr_output_description_get(_structure));
 }
 
-vector<string> OutputFormat::extensions()
+vector<string> OutputFormat::extensions() const
 {
        vector<string> exts;
        for (const char *const *e = sr_output_extensions_get(_structure);
@@ -1455,7 +1451,7 @@ shared_ptr<Output> OutputFormat::create_output(string filename,
                Output::Deleter());
 }
 
-bool OutputFormat::test_flag(const OutputFlag *flag)
+bool OutputFormat::test_flag(const OutputFlag *flag) const
 {
        return sr_output_test_flag(_structure, flag->id());
 }
@@ -1463,7 +1459,7 @@ bool OutputFormat::test_flag(const OutputFlag *flag)
 Output::Output(shared_ptr<OutputFormat> format,
                shared_ptr<Device> device, const map<string, Glib::VariantBase> &options) :
        UserOwned(sr_output_new(format->_structure,
-               map_to_hash_variant(options), device->_structure, NULL)),
+               map_to_hash_variant(options), device->_structure, nullptr)),
        _format(move(format)),
        _device(move(device)),
        _options(options)