// Generated by gtkmmproc -- DO NOT MODIFY! #include #include // -*- Mode: C++; c-basic-offset: 4 -*- /* client.ccg * * Copyright (C) 2000-2002 GConfmm Development Team * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include "gconfmm/value.h" namespace { using namespace Gnome::Conf; class PrimitiveHolder { public: union { gboolean as_bool; gint as_int; gdouble as_float; char* as_string; GConfSchema* as_schema; }; ValueType type; PrimitiveHolder(ValueType t) : type(t) {} gpointer get_addr() { switch (type) { case VALUE_INT: return &as_int; break; case VALUE_STRING: return &as_string; break; case VALUE_FLOAT: return &as_float; break; case VALUE_BOOL: return &as_bool; break; case VALUE_SCHEMA: return &as_schema; break; default: g_assert_not_reached(); return NULL; /* for warnings */ break; } } GConfValue* make_value() { GConfValue* v = gconf_value_new((GConfValueType)type); switch (type) { case VALUE_INT: gconf_value_set_int(v,as_int); break; case VALUE_STRING: gconf_value_set_string(v,as_string); g_free(as_string); break; case VALUE_FLOAT: gconf_value_set_float(v,as_float); break; case VALUE_BOOL: gconf_value_set_bool(v,as_bool); break; case VALUE_SCHEMA: gconf_value_set_schema_nocopy(v,as_schema); break; default: g_assert_not_reached(); return NULL; /* for warnings */ break; } return v; } }; } //anonymous namespace namespace Gnome { namespace Conf { Glib::RefPtr Client::get_default_client() { return Glib::wrap( gconf_client_get_default() ); } Glib::RefPtr Client::get_client_for_engine(GConfEngine* engine) { return Glib::wrap( gconf_client_get_for_engine(engine) ); } guint Client::notify_add(const Glib::ustring& namespace_section, Callback callback) { CallbackHolder* pHolder = new CallbackHolder(callback); //destroyed by callback_destroy. GError* error = 0; guint iResult = gconf_client_notify_add(gobj(), namespace_section.c_str(), &CallbackHolder::call, (gpointer)pHolder, //used by GConfClient as an arg to callback_call and callback_destroy. &CallbackHolder::destroy, &error); handle_error(error); return iResult; } SListHandle_ValueFloat Client::get_float_list(const Glib::ustring& key) const { return SListHandle_ValueFloat(get_list(key,GCONF_VALUE_FLOAT),Glib::OWNERSHIP_DEEP); } SListHandle_ValueInt Client::get_int_list(const Glib::ustring& key) const { return SListHandle_ValueInt(get_list(key,GCONF_VALUE_INT),Glib::OWNERSHIP_DEEP); } SListHandle_ValueBool Client::get_bool_list(const Glib::ustring& key) const { return SListHandle_ValueBool(get_list(key,GCONF_VALUE_BOOL),Glib::OWNERSHIP_DEEP); } SListHandle_ValueSchema Client::get_schema_list(const Glib::ustring& key) const { return SListHandle_ValueSchema(get_list(key,GCONF_VALUE_SCHEMA),Glib::OWNERSHIP_DEEP); } SListHandle_ValueString Client::get_string_list(const Glib::ustring& key) const { return SListHandle_ValueString(get_list(key,GCONF_VALUE_STRING),Glib::OWNERSHIP_DEEP); } void Client::set_int_list(const Glib::ustring& key, const SListHandleInts& what) { /* debugging code: std::list testListIntFromGet = what; for(std::list::iterator iter = testListIntFromGet.begin(); iter != testListIntFromGet.end(); ++iter) { int a = *iter; g_warning("set_int_list(): %d", a); } GSList* slist = what.data(); GSList* next = slist; while(next) { g_warning("next->data: %d", *((int*)(next->data))); next = next->next; } */ GError* error = 0; gconf_client_set_list(gobj(), key.c_str(), GCONF_VALUE_INT, what.data(), &error); if(error) ::Glib::Error::throw_exception(error); } void Client::set_bool_list(const Glib::ustring& key, const SListHandleBools& what) { GError* error = 0; gconf_client_set_list(gobj(), key.c_str(), GCONF_VALUE_BOOL, what.data(), &error); if(error) ::Glib::Error::throw_exception(error); } void Client::set_float_list(const Glib::ustring& key, const SListHandleFloats& what) { GError* error = 0; gconf_client_set_list(gobj(), key.c_str(), GCONF_VALUE_FLOAT, what.data(), &error); if(error) ::Glib::Error::throw_exception(error); } void Client::set_schema_list(const Glib::ustring& key, const Glib::SListHandle& what) { GError* error = 0; gconf_client_set_list(gobj(), key.c_str(), GCONF_VALUE_SCHEMA, what.data(), &error); if(error) ::Glib::Error::throw_exception(error); } void Client::set_string_list(const Glib::ustring& key, const Glib::SListHandle& what) { GError* error = 0; gconf_client_set_list(gobj(), key.c_str(), GCONF_VALUE_STRING, what.data(), &error); if(error) ::Glib::Error::throw_exception(error); } GSList* Client::get_list(const Glib::ustring& key, GConfValueType list_type) const { GError* error = 0; GSList* list = gconf_client_get_list(const_cast(gobj()), key.c_str(), list_type, &error); handle_error(error); for(GSList *i=list;i!=NULL;i=i->next) { GConfValue* v = gconf_value_new(list_type); switch(list_type) { case GCONF_VALUE_INT: gconf_value_set_int(v, GPOINTER_TO_INT(i->data)); break; case GCONF_VALUE_BOOL: gconf_value_set_bool(v, (i->data) != 0); break; case GCONF_VALUE_FLOAT: gconf_value_set_float(v,*(gdouble*)i->data); g_free(i->data); break; case GCONF_VALUE_STRING: gconf_value_set_string(v,(char*)i->data); g_free(i->data); break; case GCONF_VALUE_SCHEMA: gconf_value_set_schema_nocopy(v,(GConfSchema*)i->data); break; default: g_assert_not_reached(); } i->data=v; } return list; } ValuePair Client::get_pair(const Glib::ustring& key, ValueTypePair types) const { PrimitiveHolder carp(types.first),cdrp(types.second); GError* error = 0; gconf_client_get_pair(const_cast(gobj()), key.c_str(), (GConfValueType)types.first, (GConfValueType)types.second, carp.get_addr(), cdrp.get_addr(), &error); handle_error(error); return ValuePair(Value(carp.make_value()), Value(cdrp.make_value())); } void Client::handle_error(GError* error) const { if(error) Glib::Error::throw_exception(error); } Entry Client::get_entry(const Glib::ustring& key, bool use_schema_default) const { GError *error = 0; Entry retvalue = Entry(gconf_client_get_entry(const_cast(gobj()), key.c_str(), 0, static_cast(use_schema_default), &(error))); if(error) ::Glib::Error::throw_exception(error); return retvalue; } } /* namespace Conf */ } /* namespace Gnome */ namespace { static void Client_signal_value_changed_callback(GConfClient* self, const gchar* p0,GConfValue* p1,void* data) { using namespace Gnome::Conf; typedef sigc::slot< void,const Glib::ustring&,const Value& > SlotType; // Do not try to call a signal on a disassociated wrapper. if(Glib::ObjectBase::_get_current_wrapper((GObject*) self)) { #ifdef GLIBMM_EXCEPTIONS_ENABLED try { #endif //GLIBMM_EXCEPTIONS_ENABLED if(sigc::slot_base *const slot = Glib::SignalProxyNormal::data_to_slot(data)) (*static_cast(slot))(Glib::convert_const_gchar_ptr_to_ustring(p0) , Value(p1, true) ); #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } static const Glib::SignalProxyInfo Client_signal_value_changed_info = { "value_changed", (GCallback) &Client_signal_value_changed_callback, (GCallback) &Client_signal_value_changed_callback }; static void Client_signal_unreturned_error_callback(GConfClient* self, GError* p0,void* data) { using namespace Gnome::Conf; typedef sigc::slot< void,const Glib::Error& > SlotType; // Do not try to call a signal on a disassociated wrapper. if(Glib::ObjectBase::_get_current_wrapper((GObject*) self)) { #ifdef GLIBMM_EXCEPTIONS_ENABLED try { #endif //GLIBMM_EXCEPTIONS_ENABLED if(sigc::slot_base *const slot = Glib::SignalProxyNormal::data_to_slot(data)) (*static_cast(slot))(Glib::Error(p0, true) ); #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } static const Glib::SignalProxyInfo Client_signal_unreturned_error_info = { "unreturned_error", (GCallback) &Client_signal_unreturned_error_callback, (GCallback) &Client_signal_unreturned_error_callback }; static void Client_signal_error_callback(GConfClient* self, GError* p0,void* data) { using namespace Gnome::Conf; typedef sigc::slot< void,const Glib::Error& > SlotType; // Do not try to call a signal on a disassociated wrapper. if(Glib::ObjectBase::_get_current_wrapper((GObject*) self)) { #ifdef GLIBMM_EXCEPTIONS_ENABLED try { #endif //GLIBMM_EXCEPTIONS_ENABLED if(sigc::slot_base *const slot = Glib::SignalProxyNormal::data_to_slot(data)) (*static_cast(slot))(Glib::Error(p0, true) ); #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } static const Glib::SignalProxyInfo Client_signal_error_info = { "error", (GCallback) &Client_signal_error_callback, (GCallback) &Client_signal_error_callback }; } // anonymous namespace // static GType Glib::Value::value_type() { return gconf_client_error_handling_mode_get_type(); } // static GType Glib::Value::value_type() { return gconf_client_preload_type_get_type(); } Gnome::Conf::Error::Error(Gnome::Conf::Error::Code error_code, const Glib::ustring& error_message) : Glib::Error (GCONF_ERROR, error_code, error_message) {} Gnome::Conf::Error::Error(GError* gobject) : Glib::Error (gobject) {} Gnome::Conf::Error::Code Gnome::Conf::Error::code() const { return static_cast(Glib::Error::code()); } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Gnome::Conf::Error::throw_func(GError* gobject) { throw Gnome::Conf::Error(gobject); } #else //When not using exceptions, we just pass the Exception object around without throwing it: std::auto_ptr Gnome::Conf::Error::throw_func(GError* gobject) { return std::auto_ptr(new Gnome::Conf::Error(gobject)); } #endif //GLIBMM_EXCEPTIONS_ENABLED // static GType Glib::Value::value_type() { return gconf_error_get_type(); } namespace Glib { Glib::RefPtr wrap(GConfClient* object, bool take_copy) { return Glib::RefPtr( dynamic_cast (Glib::wrap_auto ((GObject*)(object), take_copy)) ); //We use dynamic_cast<> in case of multiple inheritance. } } /* namespace Glib */ namespace Gnome { namespace Conf { /* The *_Class implementation: */ const Glib::Class& Client_Class::init() { if(!gtype_) // create the GType if necessary { // Glib::Class has to know the class init function to clone custom types. class_init_func_ = &Client_Class::class_init_function; // This is actually just optimized away, apparently with no harm. // Make sure that the parent type has been created. //CppClassParent::CppObjectType::get_type(); // Create the wrapper type, with the same class/instance size as the base type. register_derived_type(gconf_client_get_type()); // Add derived versions of interfaces, if the C type implements any interfaces: } return *this; } void Client_Class::class_init_function(void* g_class, void* class_data) { BaseClassType *const klass = static_cast(g_class); CppClassParent::class_init_function(klass, class_data); #ifdef GLIBMM_VFUNCS_ENABLED #endif //GLIBMM_VFUNCS_ENABLED #ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED klass->value_changed = &value_changed_callback; klass->unreturned_error = &unreturned_error_callback; klass->error = &error_callback; #endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED } #ifdef GLIBMM_VFUNCS_ENABLED #endif //GLIBMM_VFUNCS_ENABLED #ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED void Client_Class::value_changed_callback(GConfClient* self, const gchar* p0, GConfValue* p1) { Glib::ObjectBase *const obj_base = static_cast( Glib::ObjectBase::_get_current_wrapper((GObject*)self)); // Non-gtkmmproc-generated custom classes implicitly call the default // Glib::ObjectBase constructor, which sets is_derived_. But gtkmmproc- // generated classes can use this optimisation, which avoids the unnecessary // parameter conversions if there is no possibility of the virtual function // being overridden: if(obj_base && obj_base->is_derived_()) { CppObjectType *const obj = dynamic_cast(obj_base); if(obj) // This can be NULL during destruction. { #ifdef GLIBMM_EXCEPTIONS_ENABLED try // Trap C++ exceptions which would normally be lost because this is a C callback. { #endif //GLIBMM_EXCEPTIONS_ENABLED // Call the virtual member method, which derived classes might override. obj->on_value_changed(Glib::convert_const_gchar_ptr_to_ustring(p0) , Value(p1, true) ); return; #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(self)) // Get the parent class of the object class (The original underlying C class). ); // Call the original underlying C function: if(base && base->value_changed) (*base->value_changed)(self, p0, p1); } void Client_Class::unreturned_error_callback(GConfClient* self, GError* p0) { Glib::ObjectBase *const obj_base = static_cast( Glib::ObjectBase::_get_current_wrapper((GObject*)self)); // Non-gtkmmproc-generated custom classes implicitly call the default // Glib::ObjectBase constructor, which sets is_derived_. But gtkmmproc- // generated classes can use this optimisation, which avoids the unnecessary // parameter conversions if there is no possibility of the virtual function // being overridden: if(obj_base && obj_base->is_derived_()) { CppObjectType *const obj = dynamic_cast(obj_base); if(obj) // This can be NULL during destruction. { #ifdef GLIBMM_EXCEPTIONS_ENABLED try // Trap C++ exceptions which would normally be lost because this is a C callback. { #endif //GLIBMM_EXCEPTIONS_ENABLED // Call the virtual member method, which derived classes might override. obj->on_unreturned_error(Glib::Error(p0, true) ); return; #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(self)) // Get the parent class of the object class (The original underlying C class). ); // Call the original underlying C function: if(base && base->unreturned_error) (*base->unreturned_error)(self, p0); } void Client_Class::error_callback(GConfClient* self, GError* p0) { Glib::ObjectBase *const obj_base = static_cast( Glib::ObjectBase::_get_current_wrapper((GObject*)self)); // Non-gtkmmproc-generated custom classes implicitly call the default // Glib::ObjectBase constructor, which sets is_derived_. But gtkmmproc- // generated classes can use this optimisation, which avoids the unnecessary // parameter conversions if there is no possibility of the virtual function // being overridden: if(obj_base && obj_base->is_derived_()) { CppObjectType *const obj = dynamic_cast(obj_base); if(obj) // This can be NULL during destruction. { #ifdef GLIBMM_EXCEPTIONS_ENABLED try // Trap C++ exceptions which would normally be lost because this is a C callback. { #endif //GLIBMM_EXCEPTIONS_ENABLED // Call the virtual member method, which derived classes might override. obj->on_error(Glib::Error(p0, true) ); return; #ifdef GLIBMM_EXCEPTIONS_ENABLED } catch(...) { Glib::exception_handlers_invoke(); } #endif //GLIBMM_EXCEPTIONS_ENABLED } } BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(self)) // Get the parent class of the object class (The original underlying C class). ); // Call the original underlying C function: if(base && base->error) (*base->error)(self, p0); } #endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED Glib::ObjectBase* Client_Class::wrap_new(GObject* object) { return new Client((GConfClient*)object); } /* The implementation: */ GConfClient* Client::gobj_copy() { reference(); return gobj(); } Client::Client(const Glib::ConstructParams& construct_params) : Glib::Object(construct_params) {} Client::Client(GConfClient* castitem) : Glib::Object((GObject*)(castitem)) {} Client::~Client() {} Client::CppClassType Client::client_class_; // initialize static member GType Client::get_type() { return client_class_.init().get_type(); } GType Client::get_base_type() { return gconf_client_get_type(); } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::add_dir(const Glib::ustring& dir, ClientPreloadType preload) #else void Client::add_dir(const Glib::ustring& dir, ClientPreloadType preload, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_add_dir(gobj(), dir.c_str(), ((GConfClientPreloadType)(preload)), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::remove_dir(const Glib::ustring& dir) #else void Client::remove_dir(const Glib::ustring& dir, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_remove_dir(gobj(), dir.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::notify_remove(guint cnxn) #else void Client::notify_remove(guint cnxn, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_notify_remove(gobj(), cnxn); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } void Client::set_error_handling(ClientErrorHandlingMode mode) { gconf_client_set_error_handling(gobj(), ((GConfClientErrorHandlingMode)(mode))); } void Client::clear_cache() { gconf_client_clear_cache(gobj()); } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::preload(const Glib::ustring& dirname, ClientPreloadType type) #else void Client::preload(const Glib::ustring& dirname, ClientPreloadType type, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_preload(gobj(), dirname.c_str(), ((GConfClientPreloadType)(type)), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED Value Client::get(const Glib::ustring& key) const #else Value Client::get(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Value retvalue = Value(gconf_client_get(const_cast(gobj()), key.c_str(), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Value Client::get_without_default(const Glib::ustring& key) const #else Value Client::get_without_default(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Value retvalue = Value(gconf_client_get_without_default(const_cast(gobj()), key.c_str(), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Value Client::get_default_from_schema(const Glib::ustring& key) const #else Value Client::get_default_from_schema(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Value retvalue = Value(gconf_client_get_default_from_schema(const_cast(gobj()), key.c_str(), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Entry Client::get_entry(const Glib::ustring& key, const char* locale, bool use_schema_default) const #else Entry Client::get_entry(const Glib::ustring& key, const char* locale, bool use_schema_default, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Entry retvalue = Entry(gconf_client_get_entry(const_cast(gobj()), key.c_str(), locale, static_cast(use_schema_default), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::unset(const Glib::ustring& key) #else void Client::unset(const Glib::ustring& key, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_unset(gobj(), key.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED Glib::SListHandle Client::all_entries(const Glib::ustring& dir) const #else Glib::SListHandle Client::all_entries(const Glib::ustring& dir, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Glib::SListHandle retvalue = Glib::SListHandle(gconf_client_all_entries(const_cast(gobj()), dir.c_str(), &(gerror)), Glib::OWNERSHIP_SHALLOW); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Glib::SListHandle Client::all_dirs(const Glib::ustring& dir) const #else Glib::SListHandle Client::all_dirs(const Glib::ustring& dir, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Glib::SListHandle retvalue = Glib::SListHandle(gconf_client_all_dirs(const_cast(gobj()), dir.c_str(), &(gerror)), Glib::OWNERSHIP_DEEP); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::suggest_sync() #else void Client::suggest_sync(std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_suggest_sync(gobj(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED bool Client::dir_exists(const Glib::ustring& p1) const #else bool Client::dir_exists(const Glib::ustring& p1, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; bool retvalue = gconf_client_dir_exists(const_cast(gobj()), p1.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED bool Client::key_is_writable(const Glib::ustring& p1) const #else bool Client::key_is_writable(const Glib::ustring& p1, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; bool retvalue = gconf_client_key_is_writable(const_cast(gobj()), p1.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED double Client::get_float(const Glib::ustring& key) const #else double Client::get_float(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; double retvalue = gconf_client_get_float(const_cast(gobj()), key.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED gint Client::get_int(const Glib::ustring& key) const #else gint Client::get_int(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gint retvalue = gconf_client_get_int(const_cast(gobj()), key.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED bool Client::get_bool(const Glib::ustring& key) const #else bool Client::get_bool(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; bool retvalue = gconf_client_get_bool(const_cast(gobj()), key.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Glib::ustring Client::get_string(const Glib::ustring& key) const #else Glib::ustring Client::get_string(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Glib::ustring retvalue = Glib::convert_return_gchar_ptr_to_ustring(gconf_client_get_string(const_cast(gobj()), key.c_str(), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED Schema Client::get_schema(const Glib::ustring& key) const #else Schema Client::get_schema(const Glib::ustring& key, std::auto_ptr& error) const #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; Schema retvalue = Schema(gconf_client_get_schema(const_cast(gobj()), key.c_str(), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, int what) #else void Client::set(const Glib::ustring& key, int what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set_int(gobj(), key.c_str(), what, &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, bool what) #else void Client::set(const Glib::ustring& key, bool what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set_bool(gobj(), key.c_str(), static_cast(what), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, double what) #else void Client::set(const Glib::ustring& key, double what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set_float(gobj(), key.c_str(), what, &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, const Glib::ustring& what) #else void Client::set(const Glib::ustring& key, const Glib::ustring& what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set_string(gobj(), key.c_str(), what.c_str(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, const Schema& what) #else void Client::set(const Glib::ustring& key, const Schema& what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set_schema(gobj(), key.c_str(), (what).gobj(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::set(const Glib::ustring& key, const Value& what) #else void Client::set(const Glib::ustring& key, const Value& what, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_set(gobj(), key.c_str(), (what).gobj(), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED ChangeSet Client::change_set_from_current(const Glib::SArray& set) #else ChangeSet Client::change_set_from_current(const Glib::SArray& set, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; ChangeSet retvalue = ChangeSet(gconf_client_change_set_from_currentv(gobj(), const_cast((set).data()), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } #ifdef GLIBMM_EXCEPTIONS_ENABLED void Client::change_set_commit(ChangeSet& set, bool remove_commited) #else void Client::change_set_commit(ChangeSet& set, bool remove_commited, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; gconf_client_commit_change_set(gobj(), (set).gobj(), static_cast(remove_commited), &(gerror)); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED } #ifdef GLIBMM_EXCEPTIONS_ENABLED ChangeSet Client::change_set_reverse(const ChangeSet& set) #else ChangeSet Client::change_set_reverse(const ChangeSet& set, std::auto_ptr& error) #endif //GLIBMM_EXCEPTIONS_ENABLED { GError* gerror = 0; ChangeSet retvalue = ChangeSet(gconf_client_reverse_change_set(gobj(), const_cast((set).gobj()), &(gerror))); #ifdef GLIBMM_EXCEPTIONS_ENABLED if(gerror) ::Glib::Error::throw_exception(gerror); #else if(gerror) error = ::Glib::Error::throw_exception(gerror); #endif //GLIBMM_EXCEPTIONS_ENABLED return retvalue; } void Client::value_changed(const Glib::ustring& key, const Value& value) { gconf_client_value_changed(gobj(), key.c_str(), const_cast(value.gobj())); } void Client::unreturned_error(const Glib::Error& error) { gconf_client_unreturned_error(gobj(), const_cast(error.gobj())); } void Client::error(const Glib::Error& error) { gconf_client_error(gobj(), const_cast(error.gobj())); } Glib::SignalProxy2< void,const Glib::ustring&,const Value& > Client::signal_value_changed() { return Glib::SignalProxy2< void,const Glib::ustring&,const Value& >(this, &Client_signal_value_changed_info); } Glib::SignalProxy1< void,const Glib::Error& > Client::signal_unreturned_error() { return Glib::SignalProxy1< void,const Glib::Error& >(this, &Client_signal_unreturned_error_info); } Glib::SignalProxy1< void,const Glib::Error& > Client::signal_error() { return Glib::SignalProxy1< void,const Glib::Error& >(this, &Client_signal_error_info); } #ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED void Gnome::Conf::Client::on_value_changed(const Glib::ustring& key, const Value& value) { BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(gobject_)) // Get the parent class of the object class (The original underlying C class). ); if(base && base->value_changed) (*base->value_changed)(gobj(),key.c_str(),const_cast(value.gobj())); } void Gnome::Conf::Client::on_unreturned_error(const Glib::Error& error) { BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(gobject_)) // Get the parent class of the object class (The original underlying C class). ); if(base && base->unreturned_error) (*base->unreturned_error)(gobj(),const_cast(error.gobj())); } void Gnome::Conf::Client::on_error(const Glib::Error& error) { BaseClassType *const base = static_cast( g_type_class_peek_parent(G_OBJECT_GET_CLASS(gobject_)) // Get the parent class of the object class (The original underlying C class). ); if(base && base->error) (*base->error)(gobj(),const_cast(error.gobj())); } #endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED #ifdef GLIBMM_VFUNCS_ENABLED #endif //GLIBMM_VFUNCS_ENABLED } // namespace Conf } // namespace Gnome