X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmodest-runtime.h;h=6d5f8214439eb2b3cd3366585e601889a0d9d914;hb=39d728083bfd2a0e31ea7a69f0278c79a755f41e;hp=e4f91e84182f927623a9640a51a5cc94e05d876e;hpb=150b4cb3020b18a35b08703f5caa6386025805c7;p=modest diff --git a/src/modest-runtime.h b/src/modest-runtime.h index e4f91e8..6d5f821 100644 --- a/src/modest-runtime.h +++ b/src/modest-runtime.h @@ -39,6 +39,7 @@ #include #include #include +#include "widgets/modest-window-mgr.h" G_BEGIN_DECLS @@ -87,6 +88,7 @@ gboolean modest_runtime_init_ui (gint argc, gchar** argv); */ gboolean modest_runtime_uninit (void); + /** * modest_runtime_get_debug_flags @@ -194,6 +196,61 @@ ModestMailOperationQueue* modest_runtime_get_mail_operation_queue (void); ModestTnySendQueue* modest_runtime_get_send_queue (TnyTransportAccount *account); +/** + * modest_runtime_get_window_mgr: + * + * get the #ModestWindowMgr singleton instance + * + * Returns: the #ModestWindowMgr singleton. This should NOT be unref'd. + **/ +ModestWindowMgr* modest_runtime_get_window_mgr (void); + +/** + * modest_runtime_verify_object_last_ref + * @OBJ: some (GObject) ptr + * @NAME: name of @OBJ + * + * macro to check whether @obj holds only one more ref (ie. after the + * next unref it will die) + * + * not, a g_warning will be issued on stderr. NOTE: this is only active + * when MODEST_DEBUG contains "debug-objects". + * + ***/ +#define modest_runtime_verify_object_last_ref(OBJ,name) \ + do { \ + if (modest_runtime_get_debug_flags() & MODEST_RUNTIME_DEBUG_DEBUG_OBJECTS) \ + if (G_IS_OBJECT(OBJ) && G_OBJECT(OBJ)->ref_count != 1) \ + g_warning ("%s:%d: %s (" \ + #OBJ ") still holds a ref count of %d", \ + __FILE__,__LINE__,name, G_OBJECT(OBJ)->ref_count); \ + } while (0) + + + +/** + * modest_runtime_not_implemented + * @WIN: the parent GtkWindow, or NULL + * + * give a not-implemented-yet warning popup or g_warning + * + ***/ +#define modest_runtime_not_implemented(WIN) \ + do { \ + if (gtk_main_level() > 0) { \ + GtkWidget *popup; \ + popup = gtk_message_dialog_new (WIN,\ + GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT,\ + GTK_MESSAGE_WARNING, \ + GTK_BUTTONS_OK, \ + "Not yet implemented");\ + gtk_dialog_run (GTK_DIALOG(popup)); \ + gtk_widget_destroy (popup); \ + } else \ + g_warning ("%s:%d: Not yet implemented",__FILE__,__LINE__); \ + } while (0) \ + + G_END_DECLS #endif /*__MODEST_RUNTIME_H__*/