/* Copyright (C) 2015 The giomm Development Team
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see .
*/
_CONFIGINCLUDE(giommconfig.h)
#include
_DEFS(giomm,gio)
_PINCLUDE(glibmm/private/object_p.h)
#ifndef DOXYGEN_SHOULD_SKIP_THIS
typedef struct _GSettingsSchema GSettingsSchema;
#endif
namespace Gio
{
//TODO: Translate more of the class documentation from the C docs.
/** Introspecting and controlling the loading of GSettings schemas.
*
* The SettingsSchemaSource and SettingsSchema APIs provide a
* mechanism for advanced control over the loading of schemas and a
* mechanism for introspecting their content.
*
* Plugin loading systems that wish to provide plugins a way to access
* settings face the problem of how to make the schemas for these
* settings visible to GSettings. Typically, a plugin will want to ship
* the schema along with itself and it won't be installed into the
* standard system directories for schemas.
*
* SettingsSchemaSource provides a mechanism for dealing with this by
* allowing the creation of a new 'schema source' from which schemas can
* be acquired. This schema source can then become part of the metadata
* associated with the plugin and queried whenever the plugin requires
* access to some settings.
*
* @newin{2,32}
*/
class GIOMM_API SettingsSchema final
{
_CLASS_OPAQUE_REFCOUNTED(SettingsSchema, GSettingsSchema, NONE, g_settings_schema_ref, g_settings_schema_unref, GIOMM_API)
_IS_REFCOUNTED_BOXEDTYPE
protected:
_IGNORE(g_settings_schema_ref, g_settings_schema_unref)
//Ignore internal GSettingsSchema functions.
_IGNORE(g_settings_schema_get_value, g_settings_schema_list, g_settings_schema_get_string, g_settings_schema_get_gettext_domain)
public:
_WRAP_METHOD(Glib::ustring get_id() const, g_settings_schema_get_id)
_WRAP_METHOD(Glib::ustring get_path() const, g_settings_schema_get_path)
//Note that these don't need refreturn because they seem to return a reference
//(they are documented as transfer:full)
_WRAP_METHOD(Glib::RefPtr get_key(const Glib::ustring& name), g_settings_schema_get_key)
_WRAP_METHOD(Glib::RefPtr get_key(const Glib::ustring& name) const, g_settings_schema_get_key)
_WRAP_METHOD(bool has_key(const Glib::ustring& name) const, g_settings_schema_has_key)
#m4 _CONVERSION(`gchar**',`std::vector',`Glib::ArrayHandler::array_to_vector($3, Glib::OWNERSHIP_DEEP)')
_WRAP_METHOD(std::vector list_keys() const, g_settings_schema_list_keys)
_WRAP_METHOD(std::vector list_children() const, g_settings_schema_list_children)
};
} // namespace Gio