summaryrefslogtreecommitdiff
path: root/gui/simple-greeter/gdm-clock-widget.c
diff options
context:
space:
mode:
authorRay Strode <rstrode@redhat.com>2013-05-23 10:23:53 -0400
committerRay Strode <rstrode@redhat.com>2013-05-23 15:23:27 -0400
commit8dbec8431d558b9d33adc987de2f7a58815589d4 (patch)
treeaf9f086ce839d9f2381bec3bedbe3c58800d1aac /gui/simple-greeter/gdm-clock-widget.c
parent421365c4f3cb44e037f576efd55b36dfcc63c6f3 (diff)
downloadgdm-8dbec8431d558b9d33adc987de2f7a58815589d4.tar.gz
gui: drop fallback greeter
We don't use it anymore. https://bugzilla.gnome.org/show_bug.cgi?id=688665
Diffstat (limited to 'gui/simple-greeter/gdm-clock-widget.c')
-rw-r--r--gui/simple-greeter/gdm-clock-widget.c314
1 files changed, 0 insertions, 314 deletions
diff --git a/gui/simple-greeter/gdm-clock-widget.c b/gui/simple-greeter/gdm-clock-widget.c
deleted file mode 100644
index 0c6fbde7..00000000
--- a/gui/simple-greeter/gdm-clock-widget.c
+++ /dev/null
@@ -1,314 +0,0 @@
-/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
- *
- * Copyright (C) 2007 William Jon McCann <mccann@jhu.edu>
- * Copyright (C) 2008 Red Hat, Inc.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program 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 General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- *
- * Written by: William Jon McCann <mccann@jhu.edu>
- * Ray Strode <rstrode@redhat.com>
- */
-
-#include "config.h"
-
-#include <stdlib.h>
-#include <stdio.h>
-#include <unistd.h>
-#include <string.h>
-#include <errno.h>
-#include <dirent.h>
-#include <sys/stat.h>
-
-#include <glib.h>
-#include <glib/gi18n.h>
-#include <glib/gstdio.h>
-#include <gtk/gtk.h>
-
-#include "gdm-clock-widget.h"
-
-#define GDM_CLOCK_WIDGET_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GDM_TYPE_CLOCK_WIDGET, GdmClockWidgetPrivate))
-
-struct GdmClockWidgetPrivate
-{
- GtkWidget *label;
- char *time_format;
- char *tooltip_format;
- guint update_clock_id;
- guint should_show_seconds : 1;
- guint should_show_date : 1;
-};
-
-static void gdm_clock_widget_class_init (GdmClockWidgetClass *klass);
-static void gdm_clock_widget_init (GdmClockWidget *clock_widget);
-static void gdm_clock_widget_finalize (GObject *object);
-static gboolean update_timeout_cb (GdmClockWidget *clock);
-
-G_DEFINE_TYPE (GdmClockWidget, gdm_clock_widget, GTK_TYPE_ALIGNMENT)
-
-static void
-update_time_format (GdmClockWidget *clock)
-{
- char *clock_format;
- char *tooltip_format;
-
- if (clock->priv->should_show_date && clock->priv->should_show_seconds) {
- /* translators: This is the time format to use when both
- * the date and time with seconds are being shown together.
- */
- clock_format = _("%a %b %e, %l:%M:%S %p");
- tooltip_format = NULL;
- } else if (clock->priv->should_show_date && !clock->priv->should_show_seconds) {
- /* translators: This is the time format to use when both
- * the date and time without seconds are being shown together.
- */
- clock_format = _("%a %b %e, %l:%M %p");
-
- tooltip_format = NULL;
- } else if (!clock->priv->should_show_date && clock->priv->should_show_seconds) {
- /* translators: This is the time format to use when there is
- * no date, just weekday and time with seconds.
- */
- clock_format = _("%a %l:%M:%S %p");
-
- /* translators: This is the time format to use for the date
- */
- tooltip_format = "%x";
- } else {
- /* translators: This is the time format to use when there is
- * no date, just weekday and time without seconds.
- */
- clock_format = _("%a %l:%M %p");
-
- tooltip_format = "%x";
- }
-
- g_free (clock->priv->time_format);
- clock->priv->time_format = g_locale_from_utf8 (clock_format, -1, NULL, NULL, NULL);
-
- g_free (clock->priv->tooltip_format);
-
- if (tooltip_format != NULL) {
- clock->priv->tooltip_format = g_locale_from_utf8 (tooltip_format, -1, NULL, NULL, NULL);
- } else {
- clock->priv->tooltip_format = NULL;
- }
-}
-
-static void
-update_clock (GtkLabel *label,
- const char *clock_format,
- const char *tooltip_format)
-{
- time_t t;
- struct tm *tm;
- char buf[256];
- char *utf8;
- char *markup;
-
- time (&t);
- tm = localtime (&t);
- if (tm == NULL) {
- g_warning ("Unable to get broken down local time");
- return;
- }
- if (strftime (buf, sizeof (buf), clock_format, tm) == 0) {
- g_warning ("Couldn't format time: %s", clock_format);
- strcpy (buf, "???");
- }
- utf8 = g_locale_to_utf8 (buf, -1, NULL, NULL, NULL);
- markup = g_strdup_printf ("<b><span foreground=\"white\">%s</span></b>", utf8);
- gtk_label_set_markup (label, markup);
- g_free (markup);
- g_free (utf8);
-
- if (tooltip_format != NULL) {
- if (strftime (buf, sizeof (buf), tooltip_format, tm) == 0) {
- g_warning ("Couldn't format tooltip date: %s", tooltip_format);
- strcpy (buf, "???");
- }
- utf8 = g_locale_to_utf8 (buf, -1, NULL, NULL, NULL);
- gtk_widget_set_tooltip_text (GTK_WIDGET (label), utf8);
- g_free (utf8);
- } else {
- gtk_widget_set_has_tooltip (GTK_WIDGET (label), FALSE);
- }
-}
-
-static void
-set_clock_timeout (GdmClockWidget *clock,
- time_t now)
-{
- GTimeVal tv;
- int timeouttime;
-
- if (clock->priv->update_clock_id > 0) {
- g_source_remove (clock->priv->update_clock_id);
- clock->priv->update_clock_id = 0;
- }
-
- g_get_current_time (&tv);
- timeouttime = (G_USEC_PER_SEC - tv.tv_usec) / 1000 + 1;
-
- /* timeout of one minute if we don't care about the seconds */
- if (! clock->priv->should_show_seconds) {
- timeouttime += 1000 * (59 - now % 60);
- }
-
- clock->priv->update_clock_id = g_timeout_add (timeouttime,
- (GSourceFunc)update_timeout_cb,
- clock);
-}
-
-static gboolean
-update_timeout_cb (GdmClockWidget *clock)
-{
- time_t new_time;
-
- time (&new_time);
-
- if (clock->priv->label != NULL) {
- update_clock (GTK_LABEL (clock->priv->label),
- clock->priv->time_format,
- clock->priv->tooltip_format);
- }
-
- set_clock_timeout (clock, new_time);
-
- return FALSE;
-}
-
-static void
-remove_timeout (GdmClockWidget *clock)
-{
- if (clock->priv->update_clock_id > 0) {
- g_source_remove (clock->priv->update_clock_id);
- clock->priv->update_clock_id = 0;
- }
-}
-
-static void
-gdm_clock_widget_get_preferred_width (GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size)
-{
- if (GTK_WIDGET_CLASS (gdm_clock_widget_parent_class)->get_preferred_width) {
- GTK_WIDGET_CLASS (gdm_clock_widget_parent_class)->get_preferred_width (widget, minimum_size, natural_size);
- }
-
-}
-
-static void
-gdm_clock_widget_get_preferred_height (GtkWidget *widget,
- gint *minimum_size,
- gint *natural_size)
-{
- PangoFontMetrics *metrics;
- PangoContext *context;
- int ascent;
- int descent;
- int padding;
- int min_size;
- int nat_size;
-
- min_size = 0;
- nat_size = 0;
-
- if (GTK_WIDGET_CLASS (gdm_clock_widget_parent_class)->get_preferred_height) {
- GTK_WIDGET_CLASS (gdm_clock_widget_parent_class)->get_preferred_height (widget, &min_size, &nat_size);
- }
-
- gtk_widget_ensure_style (widget);
- context = gtk_widget_get_pango_context (widget);
- metrics = pango_context_get_metrics (context,
- gtk_widget_get_style (widget)->font_desc,
- pango_context_get_language (context));
-
- ascent = pango_font_metrics_get_ascent (metrics);
- descent = pango_font_metrics_get_descent (metrics);
- padding = PANGO_PIXELS (ascent + descent) / 2.0;
- min_size += padding;
- nat_size += padding;
-
- if (minimum_size)
- *minimum_size = min_size;
- if (natural_size)
- *natural_size = nat_size;
-
- pango_font_metrics_unref (metrics);
-}
-
-static void
-gdm_clock_widget_class_init (GdmClockWidgetClass *klass)
-{
- GObjectClass *object_class;
- GtkWidgetClass *widget_class;
-
- object_class = G_OBJECT_CLASS (klass);
- widget_class = GTK_WIDGET_CLASS (klass);
-
- object_class->finalize = gdm_clock_widget_finalize;
- widget_class->get_preferred_width = gdm_clock_widget_get_preferred_width;
- widget_class->get_preferred_height = gdm_clock_widget_get_preferred_height;
-
- g_type_class_add_private (klass, sizeof (GdmClockWidgetPrivate));
-}
-
-static void
-gdm_clock_widget_init (GdmClockWidget *widget)
-{
- GtkWidget *box;
-
- widget->priv = GDM_CLOCK_WIDGET_GET_PRIVATE (widget);
-
- box = gtk_hbox_new (FALSE, 6);
- gtk_widget_show (box);
- gtk_container_add (GTK_CONTAINER (widget), box);
-
- widget->priv->label = gtk_label_new ("");
-
- gtk_widget_show (widget->priv->label);
- gtk_box_pack_start (GTK_BOX (box), widget->priv->label, FALSE, FALSE, 0);
-
- update_time_format (widget);
- update_timeout_cb (widget);
-}
-
-static void
-gdm_clock_widget_finalize (GObject *object)
-{
- GdmClockWidget *clock_widget;
-
- g_return_if_fail (object != NULL);
- g_return_if_fail (GDM_IS_CLOCK_WIDGET (object));
-
- clock_widget = GDM_CLOCK_WIDGET (object);
-
- g_return_if_fail (clock_widget->priv != NULL);
-
- remove_timeout (clock_widget);
-
- G_OBJECT_CLASS (gdm_clock_widget_parent_class)->finalize (object);
-}
-
-GtkWidget *
-gdm_clock_widget_new (void)
-{
- GObject *object;
-
- object = g_object_new (GDM_TYPE_CLOCK_WIDGET,
- NULL);
-
- return GTK_WIDGET (object);
-}