// -*- c++ -*- // Generated by gtkmmproc -- DO NOT MODIFY! #ifndef _GIOMM_ASYNCRESULT_H #define _GIOMM_ASYNCRESULT_H #include // -*- Mode: C++; indent-tabs-mode: nil; c-basic-offset: 2 -*- /* Copyright (C) 2007 The giomm 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 #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GAsyncResultIface GAsyncResultIface; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GAsyncResult GAsyncResult; typedef struct _GAsyncResultClass GAsyncResultClass; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ namespace Gio { class AsyncResult_Class; } // namespace Gio namespace Gio { class AsyncResult; /** A function that will be called when an asynchronous operation within GIO has been completed. * @param result The asynchronous function's results. * * For instance, * @code * void on_async_ready(Glib::RefPtr& result); * @endcode * * @newin2p16 */ typedef sigc::slot& > SlotAsyncReady; /** Provides a base class for implementing asynchronous function results. * Asynchronous operations are broken up into two separate operations which are chained together by a SlotAsyncReady. * To begin an asynchronous operation, provide a SlotAsyncReady to the asynchronous function. This callback will be triggered * when the operation has completed, and will be passed an AsyncResult instance filled with the details of the operation's success or * failure, the object the asynchronous function was started for and any error codes returned. The asynchronous callback function is then * expected to call the corresponding "_finish()" function with the object the function was called for, and the AsyncResult instance. * * The purpose of the "_finish()" function is to take the generic result of type AsyncResult and return the specific result that the operation * in question yields (e.g. a FileEnumerator for an "enumerate children" operation). If the result or error status of the operation is not needed, * there is no need to call the "_finish()" function and GIO will take care of cleaning up the result and error information after the * SlotAsyncReady returns. You may also store the AsyncResult and call "_finish()" later. * * Example of a typical asynchronous operation flow: * @code * void _theoretical_frobnitz_async(const Glib::RefPtr& t, * const SlotAsyncReady& slot); * * gboolean _theoretical_frobnitz_finish(const Glib::RefPtr& t, * const Glib::RefPtr& result); * * static void * on_frobnitz_result(Glib::RefPtr& result) * { * * Glib::RefPtr source_object = result->get_source_object(); * bool success = _theoretical_frobnitz_finish(source_object, res); * * if (success) * std::cout << "Hurray" << std::endl; * else * std::cout << "Uh oh!" << std::endl; * * ... * } * * int main (int argc, void *argv[]) * { * ... * * _theoretical_frobnitz_async (theoretical_data, * sigc::ptr_fun(&on_frobnitz_result) ); * * ... * } * @endcode * * The async function could also take an optional Glib::Cancellable object, allowing the calling function to cancel the asynchronous operation. * * The callback for an asynchronous operation is called only once, and is always called, even in the case of a cancelled operation. * On cancellation the result is a ERROR_CANCELLED error. * * Some ascynchronous operations are implemented using synchronous calls. These are run in a separate GThread, but otherwise they are sent * to the Main Event Loop and processed in an idle function. So, if you truly need asynchronous operations, make sure to initialize GThread. * * @newin2p16 */ class AsyncResult : public Glib::Interface { #ifndef DOXYGEN_SHOULD_SKIP_THIS public: typedef AsyncResult CppObjectType; typedef AsyncResult_Class CppClassType; typedef GAsyncResult BaseObjectType; typedef GAsyncResultIface BaseClassType; private: friend class AsyncResult_Class; static CppClassType asyncresult_class_; // noncopyable AsyncResult(const AsyncResult&); AsyncResult& operator=(const AsyncResult&); protected: AsyncResult(); // you must derive from this class /** Called by constructors of derived classes. Provide the result of * the Class init() function to ensure that it is properly * initialized. * * @param interface_class The Class object for the derived type. */ explicit AsyncResult(const Glib::Interface_Class& interface_class); public: // This is public so that C++ wrapper instances can be // created for C instances of unwrapped types. // For instance, if an unexpected C type implements the C interface. explicit AsyncResult(GAsyncResult* castitem); protected: #endif /* DOXYGEN_SHOULD_SKIP_THIS */ public: virtual ~AsyncResult(); static void add_interface(GType gtype_implementer); #ifndef DOXYGEN_SHOULD_SKIP_THIS static GType get_type() G_GNUC_CONST; static GType get_base_type() G_GNUC_CONST; #endif ///Provides access to the underlying C GObject. GAsyncResult* gobj() { return reinterpret_cast(gobject_); } ///Provides access to the underlying C GObject. const GAsyncResult* gobj() const { return reinterpret_cast(gobject_); } private: public: //Note that this returns a reference, unlike most GTK+ get_*() functions, //so we don't need to use refreturn. /** Gets the source object from a AsyncResult. * @return The source object for the @a res. */ Glib::RefPtr get_source_object(); /** Gets the source object from a AsyncResult. * @return The source object for the @a res. */ Glib::RefPtr get_source_object() const; #ifdef GLIBMM_VFUNCS_ENABLED virtual Glib::RefPtr get_source_object_vfunc(); #endif //GLIBMM_VFUNCS_ENABLED public: public: //C++ methods used to invoke GTK+ virtual functions: #ifdef GLIBMM_VFUNCS_ENABLED #endif //GLIBMM_VFUNCS_ENABLED protected: //GTK+ Virtual Functions (override these to change behaviour): #ifdef GLIBMM_VFUNCS_ENABLED #endif //GLIBMM_VFUNCS_ENABLED //Default Signal Handlers:: #ifdef GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED #endif //GLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED }; } // namespace Gio namespace Glib { /** A Glib::wrap() method for this object. * * @param object The C instance. * @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref. * @result A C++ instance that wraps this C instance. * * @relates Gio::AsyncResult */ Glib::RefPtr wrap(GAsyncResult* object, bool take_copy = false); } // namespace Glib #endif /* _GIOMM_ASYNCRESULT_H */