summaryrefslogtreecommitdiff
path: root/mate-about
diff options
context:
space:
mode:
authorPerberos <[email protected]>2013-05-08 07:51:17 -0300
committerPerberos <[email protected]>2013-05-08 07:51:17 -0300
commit5f48e596944cd7c12aeb4074758dde4451ddccea (patch)
treeaf6e4f10a09c2474784c9d46931288a4cd9eda55 /mate-about
parentb6c58586657b3d11f7ade8f01d0dcb500732164b (diff)
downloadmate-desktop-5f48e596944cd7c12aeb4074758dde4451ddccea.tar.bz2
mate-desktop-5f48e596944cd7c12aeb4074758dde4451ddccea.tar.xz
fixed g_type_init() deprecation
added Not without my gnu
Diffstat (limited to 'mate-about')
-rw-r--r--mate-about/Makefile.am6
-rw-r--r--mate-about/mate-about.c163
-rw-r--r--mate-about/mate-about.h8
3 files changed, 144 insertions, 33 deletions
diff --git a/mate-about/Makefile.am b/mate-about/Makefile.am
index 51cbdb4..0d82bd8 100644
--- a/mate-about/Makefile.am
+++ b/mate-about/Makefile.am
@@ -1,4 +1,5 @@
bin_PROGRAMS = mate-about
+
mate_about_SOURCES = mate-about.c mate-about.h
mate_about_CFLAGS = $(MATE_ABOUT_CFLAGS) $(UNIQUE_CFLAGS)
mate_about_LDADD = $(MATE_ABOUT_LIBS) $(UNIQUE_LIBS)
@@ -15,6 +16,11 @@ desktopdir = $(datadir)/applications
desktop_in_files = mate-about.desktop.in
desktop_DATA = $(desktop_in_files:.desktop.in=.desktop)
+if GNUCAT_ENABLED
+pixmapdir = $(datadir)/pixmaps
+pixmap_DATA = gnu-cat_navideno_v3.png gnu-cat.gif
+endif
+
CLEANFILES = mate-about.desktop mate-about
#-include $(top_srcdir)/git.mk
diff --git a/mate-about/mate-about.c b/mate-about/mate-about.c
index f5f8496..fad8b31 100644
--- a/mate-about/mate-about.c
+++ b/mate-about/mate-about.c
@@ -1,4 +1,4 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+/* -*- Mode: C; tab-width: 4; indent-tabs-mode: yes; c-basic-offset: 4 -*-
*
* Copyright (C) 2011 Perberos <[email protected]>
*
@@ -32,49 +32,141 @@
textdomain(package);
#endif
- #if GTK_CHECK_VERSION(3, 0, 0) && !defined(UNIQUE)
+//class mate-about <- pseudo-class!
+//{
+ //translate me:
+ // El codigo escrito aqui muestra un poco el desorden de lo que genera las
+ // deprecations de las librerias, segun van evolucionando en sus diferentes
+ // versiones.
+
+ #ifdef GNUCAT_ENABLED
+ // this function allow to display an animated image
+ // Thanks! http://www.gtkforums.com/viewtopic.php?t=1639
+ typedef struct iter_arg_s {
+ GtkWidget* widget;
+ GdkPixbufAnimation* animation;
+ GdkPixbufAnimationIter* iter;
+ } iter_arg_t;
+
+ gboolean
+ on_animation_frame(iter_arg_t* object)
+ {
+ if (object->widget == NULL)
+ {
+ return FALSE;
+ }
- static void mate_about_on_activate(GtkApplication* app)
- {
- GList* list;
- GtkWidget* window;
+ static gint frame = 1;
- list = gtk_application_get_windows(app);
+ if (gdk_pixbuf_animation_iter_advance(object->iter, NULL))
+ {
+ frame++;
- if (list)
- {
- gtk_window_present(GTK_WINDOW(list->data));
- }
- else
- {
- mate_about_run();
+ gtk_about_dialog_set_logo((GtkAboutDialog*) object->widget, gdk_pixbuf_animation_iter_get_pixbuf(object->iter));
+ }
+
+ return TRUE;
}
- }
- #elif GLIB_CHECK_VERSION(2, 26, 0) && !defined(UNIQUE)
+ #endif
- // callback
- static void mate_about_on_activate(GApplication* app)
+ static void
+ mate_about_on_activate(
+ #if GTK_CHECK_VERSION(3, 0, 0) && !defined(UNIQUE)
+ GtkApplication* app
+ #elif GLIB_CHECK_VERSION(2, 26, 0) && !defined(UNIQUE)
+ GApplication* app
+ #endif
+ )
{
- if (!mate_about_dialog)
- {
- mate_about_run();
- }
- else
- {
- gtk_window_present(GTK_WINDOW(mate_about_dialog));
- }
- }
+ #if GTK_CHECK_VERSION(3, 0, 0) && !defined(UNIQUE)
- #endif
+ GList* list;
+ GtkWidget* window;
+
+ list = gtk_application_get_windows(app);
+
+ if (list)
+ {
+ gtk_window_present(GTK_WINDOW(list->data));
+ }
+ else
+ {
+ mate_about_run();
+ }
+
+ #elif GLIB_CHECK_VERSION(2, 26, 0) && !defined(UNIQUE)
+
+ if (!mate_about_dialog)
+ {
+ mate_about_run();
+ }
+ else
+ {
+ gtk_window_present(GTK_WINDOW(mate_about_dialog));
+ }
+
+ #endif
+ }
- void mate_about_run(void)
+ void
+ mate_about_run(void)
{
mate_about_dialog = (GtkAboutDialog*) gtk_about_dialog_new();
gtk_window_set_default_icon_name(icon);
- #if GTK_CHECK_VERSION(3, 0, 0) || GTK_CHECK_VERSION(2, 6, 0)
+
+ #ifdef GNUCAT_ENABLED
+
+ /* check if it's christmas, to show a different image */
+ gboolean is_christmas = FALSE;
+
+ GDate* d = g_date_new();
+ g_date_set_time_t(d, (time_t) time(NULL));
+
+ if (g_date_get_month(d) == G_DATE_DECEMBER)
+ {
+ GDateDay day = g_date_get_day(d);
+
+ if (day >= 24 && day <=25)
+ {
+ is_christmas = TRUE;
+ }
+ }
+
+ g_date_free(d);
+
+ if (is_christmas == TRUE)
+ {
+ GdkPixbuf* pixbuf = gdk_pixbuf_new_from_file(PIXMAPS_DIR "gnu-cat_navideno_v3.png", NULL);
+ gtk_about_dialog_set_logo(mate_about_dialog, pixbuf);
+ g_object_unref(pixbuf);
+ }
+ else
+ {
+ iter_arg_t animation_object;
+ GdkPixbufAnimation* animation;
+ GdkPixbufAnimationIter *iter;
+ GtkWidget* image;
+
+ animation = gdk_pixbuf_animation_new_from_file(PIXMAPS_DIR "gnu-cat.gif", NULL);
+
+ if (animation != NULL)
+ {
+ iter = gdk_pixbuf_animation_get_iter(animation, NULL);
+
+ animation_object.animation = animation;
+ animation_object.iter = iter;
+ animation_object.widget = (GtkWidget*) mate_about_dialog;
+
+ gtk_about_dialog_set_logo(mate_about_dialog, gdk_pixbuf_animation_iter_get_pixbuf(iter));
+
+ g_timeout_add(gdk_pixbuf_animation_iter_get_delay_time(iter), (GSourceFunc) on_animation_frame, (gpointer) &animation_object);
+ }
+ }
+
+ #elif GTK_CHECK_VERSION(3, 0, 0) || GTK_CHECK_VERSION(2, 6, 0)
gtk_about_dialog_set_logo_icon_name(mate_about_dialog, icon);
@@ -134,13 +226,19 @@
gtk_widget_destroy((GtkWidget*) mate_about_dialog);
}
- int main(int argc, char** argv)
+ int
+ main(int argc, char** argv)
{
int status = 0;
mate_gettext(GETTEXT_PACKAGE, LOCALE_DIR, "UTF-8");
- g_type_init();
+ #if !GLIB_CHECK_VERSION(2, 36, 0)
+ // g_type_init has been deprecated since version 2.36 and should not
+ // be used in newly-written code. the type system is now initialised
+ // automatically
+ g_type_init();
+ #endif
/* http://www.gtk.org/api/2.6/glib/glib-Commandline-option-parser.html */
GOptionContext* context = g_option_context_new(NULL);
@@ -209,5 +307,6 @@
return status;
}
+//}
#endif
diff --git a/mate-about/mate-about.h b/mate-about/mate-about.h
index fd74b1c..131ddc4 100644
--- a/mate-about/mate-about.h
+++ b/mate-about/mate-about.h
@@ -30,10 +30,12 @@
#include <unique/unique.h>
#endif
+//class mate-about
+//{
const char* program_name = "MATE Desktop Environment";
const char* version = PACKAGE_VERSION;
const char* icon = "desktop";
- const char* website = "http://www.mate-desktop.org/";
+ const char* website = "http://mate-desktop.org/";
const char* copyright = ""
"Copyright © 1997-2011 GNOME developers\n"
@@ -628,6 +630,9 @@
const char* artists[] = {
"Marcel Dijkstra <[email protected]>",
"Rowen Stipe <[email protected]>",
+ #ifdef GNUCAT_ENABLED
+ "/g/entoomen (https://boards.4chan.org/g/)",
+ #endif
"Wolfgang Ulbrich <[email protected]>",
NULL
};
@@ -665,5 +670,6 @@
{"version", 'v', 0, G_OPTION_ARG_NONE, &mate_about_nogui, "Show MATE version", NULL},
{NULL}
};
+//}
#endif /* __MATE_ABOUT_H__ */