summaryrefslogtreecommitdiff
path: root/font-viewer
diff options
context:
space:
mode:
Diffstat (limited to 'font-viewer')
-rw-r--r--font-viewer/Makefile.am4
-rw-r--r--font-viewer/font-thumbnailer.c259
-rw-r--r--font-viewer/font-view.c604
-rw-r--r--font-viewer/ftstream-vfs.c98
-rw-r--r--font-viewer/ftstream-vfs.h35
-rw-r--r--font-viewer/totem-resources.c4
6 files changed, 584 insertions, 420 deletions
diff --git a/font-viewer/Makefile.am b/font-viewer/Makefile.am
index 130a9016..5dbf458c 100644
--- a/font-viewer/Makefile.am
+++ b/font-viewer/Makefile.am
@@ -5,10 +5,10 @@ AM_CPPFLAGS = $(FONT_VIEWER_CFLAGS) $(MATECC_CAPPLETS_CFLAGS) -DDIRECTORY_DIR=\"
bin_PROGRAMS = mate-thumbnail-font mate-font-viewer
mate_thumbnail_font_LDADD = $(MATECC_CAPPLETS_LIBS) $(FONT_VIEWER_LIBS)
-mate_thumbnail_font_SOURCES = ftstream-vfs.c font-thumbnailer.c totem-resources.c totem-resources.h
+mate_thumbnail_font_SOURCES = ftstream-vfs.c ftstream-vfs.h font-thumbnailer.c totem-resources.c totem-resources.h
mate_font_viewer_LDADD = $(MATECC_CAPPLETS_LIBS) $(FONT_VIEWER_LIBS)
-mate_font_viewer_SOURCES = ftstream-vfs.c font-view.c
+mate_font_viewer_SOURCES = ftstream-vfs.c ftstream-vfs.h font-view.c
thumbnailerdir = $(datadir)/thumbnailers
thumbnailer_DATA = mate-font-viewer.thumbnailer
diff --git a/font-viewer/font-thumbnailer.c b/font-viewer/font-thumbnailer.c
index 921d2679..5992b3a7 100644
--- a/font-viewer/font-thumbnailer.c
+++ b/font-viewer/font-thumbnailer.c
@@ -1,5 +1,8 @@
-/* -*- mode: C; c-basic-offset: 4 -*-
- * fontilus - a collection of font utilities for MATE
+/* -*- mode: C; c-basic-offset: 4 -*- */
+
+/*
+ * font-thumbnailer: a thumbnailer for font files, using FreeType
+ *
* Copyright (C) 2002-2003 James Henstridge <[email protected]>
*
* This program is free software; you can redistribute it and/or modify
@@ -23,19 +26,18 @@
#include <stdio.h>
#include <locale.h>
-
#include <ft2build.h>
#include FT_FREETYPE_H
#include <gdk-pixbuf/gdk-pixbuf.h>
-
#include <gio/gio.h>
#include <glib/gi18n.h>
+#include "ftstream-vfs.h"
#include "totem-resources.h"
static const gchar *
-get_ft_error(FT_Error error)
+get_ft_error (FT_Error error)
{
#undef __FTERRORS_H__
#define FT_ERRORDEF(e,v,s) case e: return s;
@@ -51,83 +53,87 @@ get_ft_error(FT_Error error)
#define FONT_SIZE 64
#define PAD_PIXELS 4
-FT_Error FT_New_Face_From_URI(FT_Library library,
- const gchar *uri,
- FT_Long face_index,
- FT_Face *aface);
-
static void
-draw_bitmap(GdkPixbuf *pixbuf, FT_Bitmap *bitmap, gint off_x, gint off_y)
+draw_bitmap (GdkPixbuf *pixbuf,
+ FT_Bitmap *bitmap,
+ gint off_x,
+ gint off_y)
{
guchar *buffer;
gint p_width, p_height, p_rowstride;
gint i, j;
- buffer = gdk_pixbuf_get_pixels(pixbuf);
- p_width = gdk_pixbuf_get_width(pixbuf);
- p_height = gdk_pixbuf_get_height(pixbuf);
- p_rowstride = gdk_pixbuf_get_rowstride(pixbuf);
+ buffer = gdk_pixbuf_get_pixels (pixbuf);
+ p_width = gdk_pixbuf_get_width (pixbuf);
+ p_height = gdk_pixbuf_get_height (pixbuf);
+ p_rowstride = gdk_pixbuf_get_rowstride (pixbuf);
for (j = 0; j < bitmap->rows; j++) {
if (j + off_y < 0 || j + off_y >= p_height)
continue;
+
for (i = 0; i < bitmap->width; i++) {
guchar pixel;
gint pos;
if (i + off_x < 0 || i + off_x >= p_width)
continue;
+
switch (bitmap->pixel_mode) {
case ft_pixel_mode_mono:
- pixel = bitmap->buffer[j * bitmap->pitch + i/8];
+ pixel = bitmap->buffer[j * bitmap->pitch + i / 8];
pixel = 255 - ((pixel >> (7 - i % 8)) & 0x1) * 255;
break;
case ft_pixel_mode_grays:
- pixel = 255 - bitmap->buffer[j*bitmap->pitch + i];
+ pixel = 255 - bitmap->buffer[j * bitmap->pitch + i];
break;
default:
pixel = 255;
}
pos = (j + off_y) * p_rowstride + 3 * (i + off_x);
- buffer[pos] = pixel;
- buffer[pos+1] = pixel;
- buffer[pos+2] = pixel;
+ buffer[pos] = pixel;
+ buffer[pos + 1] = pixel;
+ buffer[pos + 2] = pixel;
}
}
}
static void
-draw_char(GdkPixbuf *pixbuf, FT_Face face, FT_UInt glyph_index,
- gint *pen_x, gint *pen_y)
+draw_char (GdkPixbuf *pixbuf,
+ FT_Face face,
+ FT_UInt glyph_index,
+ gint *pen_x,
+ gint *pen_y)
{
FT_Error error;
FT_GlyphSlot slot;
slot = face->glyph;
- error = FT_Load_Glyph(face, glyph_index, FT_LOAD_DEFAULT);
+ error = FT_Load_Glyph (face, glyph_index, FT_LOAD_DEFAULT);
if (error) {
- g_printerr("could not load glyph index '%ud': %s\n", glyph_index,
- get_ft_error(error));
+ g_printerr ("Could not load glyph index '%ud': %s\n", glyph_index,
+ get_ft_error (error));
return;
}
- error = FT_Render_Glyph(slot, ft_render_mode_normal);
+ error = FT_Render_Glyph (slot, ft_render_mode_normal);
if (error) {
- g_printerr("could not render glyph index '%ud': %s\n", glyph_index,
- get_ft_error(error));
+ g_printerr("Could not render glyph index '%ud': %s\n", glyph_index,
+ get_ft_error (error));
return;
}
- draw_bitmap(pixbuf, &slot->bitmap,
- *pen_x + slot->bitmap_left,
- *pen_y - slot->bitmap_top);
+ draw_bitmap (pixbuf, &slot->bitmap,
+ *pen_x + slot->bitmap_left,
+ *pen_y - slot->bitmap_top);
*pen_x += slot->advance.x >> 6;
}
static void
-save_pixbuf(GdkPixbuf *pixbuf, gchar *filename)
+save_pixbuf (GdkPixbuf *pixbuf,
+ const gchar *filename)
{
guchar *buffer;
gint p_width, p_height, p_rowstride;
@@ -135,111 +141,127 @@ save_pixbuf(GdkPixbuf *pixbuf, gchar *filename)
gint trim_left, trim_right, trim_top, trim_bottom;
GdkPixbuf *subpixbuf;
- buffer = gdk_pixbuf_get_pixels(pixbuf);
- p_width = gdk_pixbuf_get_width(pixbuf);
- p_height = gdk_pixbuf_get_height(pixbuf);
- p_rowstride = gdk_pixbuf_get_rowstride(pixbuf);
+ buffer = gdk_pixbuf_get_pixels (pixbuf);
+ p_width = gdk_pixbuf_get_width (pixbuf);
+ p_height = gdk_pixbuf_get_height (pixbuf);
+ p_rowstride = gdk_pixbuf_get_rowstride (pixbuf);
for (i = 0; i < p_width; i++) {
gboolean seen_pixel = FALSE;
for (j = 0; j < p_height; j++) {
- gint offset = j * p_rowstride + 3*i;
+ gint offset = j * p_rowstride + 3 * i;
+
+ seen_pixel = (buffer[offset] != 0xff ||
+ buffer[offset + 1] != 0xff ||
+ buffer[offset + 2] != 0xff);
- seen_pixel = (buffer[offset] != 0xff ||
- buffer[offset+1] != 0xff ||
- buffer[offset+2] != 0xff);
if (seen_pixel)
break;
}
+
if (seen_pixel)
break;
}
- trim_left = MIN(p_width, i);
- trim_left = MAX(trim_left - PAD_PIXELS, 0);
- for (i = p_width-1; i >= trim_left; i--) {
+ trim_left = MIN (p_width, i);
+ trim_left = MAX (trim_left - PAD_PIXELS, 0);
+
+ for (i = p_width - 1; i >= trim_left; i--) {
gboolean seen_pixel = FALSE;
for (j = 0; j < p_height; j++) {
- gint offset = j * p_rowstride + 3*i;
+ gint offset = j * p_rowstride + 3 * i;
+
+ seen_pixel = (buffer[offset] != 0xff ||
+ buffer[offset + 1] != 0xff ||
+ buffer[offset + 2] != 0xff);
- seen_pixel = (buffer[offset] != 0xff ||
- buffer[offset+1] != 0xff ||
- buffer[offset+2] != 0xff);
if (seen_pixel)
break;
}
+
if (seen_pixel)
break;
}
- trim_right = MAX(trim_left, i);
- trim_right = MIN(trim_right + PAD_PIXELS, p_width-1);
+
+ trim_right = MAX (trim_left, i);
+ trim_right = MIN (trim_right + PAD_PIXELS, p_width - 1);
for (j = 0; j < p_height; j++) {
gboolean seen_pixel = FALSE;
for (i = 0; i < p_width; i++) {
- gint offset = j * p_rowstride + 3*i;
+ gint offset = j * p_rowstride + 3 * i;
+
+ seen_pixel = (buffer[offset] != 0xff ||
+ buffer[offset + 1] != 0xff ||
+ buffer[offset + 2] != 0xff);
- seen_pixel = (buffer[offset] != 0xff ||
- buffer[offset+1] != 0xff ||
- buffer[offset+2] != 0xff);
if (seen_pixel)
break;
}
+
if (seen_pixel)
break;
}
- trim_top = MIN(p_height, j);
- trim_top = MAX(trim_top - PAD_PIXELS, 0);
- for (j = p_height-1; j >= trim_top; j--) {
+ trim_top = MIN (p_height, j);
+ trim_top = MAX (trim_top - PAD_PIXELS, 0);
+
+ for (j = p_height - 1; j >= trim_top; j--) {
gboolean seen_pixel = FALSE;
for (i = 0; i < p_width; i++) {
- gint offset = j * p_rowstride + 3*i;
+ gint offset = j * p_rowstride + 3 * i;
+
+ seen_pixel = (buffer[offset] != 0xff ||
+ buffer[offset + 1] != 0xff ||
+ buffer[offset + 2] != 0xff);
- seen_pixel = (buffer[offset] != 0xff ||
- buffer[offset+1] != 0xff ||
- buffer[offset+2] != 0xff);
if (seen_pixel)
break;
}
+
if (seen_pixel)
break;
}
- trim_bottom = MAX(trim_top, j);
- trim_bottom = MIN(trim_bottom + PAD_PIXELS, p_height-1);
-
- subpixbuf = gdk_pixbuf_new_subpixbuf(pixbuf, trim_left, trim_top,
- trim_right - trim_left,
- trim_bottom - trim_top);
- gdk_pixbuf_save(subpixbuf, filename, "png", NULL, NULL);
- g_object_unref(subpixbuf);
+
+ trim_bottom = MAX (trim_top, j);
+ trim_bottom = MIN (trim_bottom + PAD_PIXELS, p_height - 1);
+
+ subpixbuf = gdk_pixbuf_new_subpixbuf (pixbuf,
+ trim_left, trim_top,
+ trim_right - trim_left,
+ trim_bottom - trim_top);
+
+ gdk_pixbuf_save (subpixbuf, filename,
+ "png", NULL, NULL);
+ g_object_unref (subpixbuf);
}
int
-main(int argc, char **argv)
+main (int argc,
+ char **argv)
{
FT_Error error;
FT_Library library;
FT_Face face;
FT_UInt glyph_index1, glyph_index2;
GFile *file;
- gchar *uri;
GdkPixbuf *pixbuf;
guchar *buffer;
gint i, len, pen_x, pen_y;
gunichar *thumbstr = NULL;
glong thumbstr_len = 2;
gint font_size = FONT_SIZE;
- gchar *thumbstr_utf8 = NULL;
+ gchar *thumbstr_utf8 = NULL, *help, *uri;
gchar **arguments = NULL;
GOptionContext *context;
GError *gerror = NULL;
gboolean retval, default_thumbstr = TRUE;
gint rv = 1;
+
const GOptionEntry options[] = {
{ "text", 't', 0, G_OPTION_ARG_STRING, &thumbstr_utf8,
N_("Text to thumbnail (default: Aa)"), N_("TEXT") },
@@ -260,19 +282,24 @@ main(int argc, char **argv)
g_option_context_add_main_entries (context, options, GETTEXT_PACKAGE);
retval = g_option_context_parse (context, &argc, &argv, &gerror);
- g_option_context_free (context);
if (!retval) {
- g_printerr (_("Error parsing arguments: %s\n"), gerror->message);
+ g_printerr ("Error parsing arguments: %s\n", gerror->message);
+
+ g_option_context_free (context);
g_error_free (gerror);
return 1;
}
if (!arguments || g_strv_length (arguments) != 2) {
- /* FIXME: once glib bug 336089 is fixed, use print_help here instead! */
- g_printerr("usage: %s [--text TEXT] [--size SIZE] FONT-FILE OUTPUT-FILE\n", argv[0]);
+ help = g_option_context_get_help (context, TRUE, NULL);
+ g_printerr ("%s", help);
+
+ g_option_context_free (context);
goto out;
}
+ g_option_context_free (context);
+
if (thumbstr_utf8 != NULL) {
/* build ucs4 version of string to thumbnail */
gerror = NULL;
@@ -280,17 +307,16 @@ main(int argc, char **argv)
NULL, &thumbstr_len, &gerror);
default_thumbstr = FALSE;
- /* Not sure this can really happen... */
if (gerror != NULL) {
- g_printerr("Failed to convert: %s\n", gerror->message);
- g_error_free (gerror);
- goto out;
+ g_printerr ("Failed to convert: %s\n", gerror->message);
+ g_error_free (gerror);
+ goto out;
}
}
- error = FT_Init_FreeType(&library);
+ error = FT_Init_FreeType (&library);
if (error) {
- g_printerr("could not initialise freetype: %s\n", get_ft_error(error));
+ g_printerr("Could not initialise freetype: %s\n", get_ft_error (error));
goto out;
}
@@ -300,47 +326,53 @@ main(int argc, char **argv)
uri = g_file_get_uri (file);
g_object_unref (file);
- error = FT_New_Face_From_URI(library, uri, 0, &face);
+ error = FT_New_Face_From_URI (library, uri, 0, &face);
if (error) {
- g_printerr("could not load face '%s': %s\n", uri,
- get_ft_error(error));
+ g_printerr ("Could not load face '%s': %s\n", uri,
+ get_ft_error (error));
g_free (uri);
goto out;
}
g_free (uri);
- error = FT_Set_Pixel_Sizes(face, 0, font_size);
+ error = FT_Set_Pixel_Sizes (face, 0, font_size);
if (error) {
- g_printerr("could not set pixel size: %s\n", get_ft_error(error));
- /* goto out; */
+ g_printerr ("Could not set pixel size: %s\n", get_ft_error (error));
+ goto out;
}
for (i = 0; i < face->num_charmaps; i++) {
if (face->charmaps[i]->encoding == ft_encoding_latin_1 ||
face->charmaps[i]->encoding == ft_encoding_unicode ||
face->charmaps[i]->encoding == ft_encoding_apple_roman) {
- error = FT_Set_Charmap(face, face->charmaps[i]);
+ error = FT_Set_Charmap (face, face->charmaps[i]);
if (error) {
- g_printerr("could not set charmap: %s\n", get_ft_error(error));
- /* goto out; */
+ g_printerr("Could not set charmap: %s\n", get_ft_error(error));
+ goto out;
}
break;
}
}
- pixbuf = gdk_pixbuf_new(GDK_COLORSPACE_RGB, FALSE, 8,
- font_size*3*thumbstr_len/2, font_size*1.5);
+ pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB,
+ FALSE, /* has-alpha */
+ 8, /* bits-per-sample */
+ font_size * 3 * thumbstr_len / 2, /* width */
+ font_size * 1.5); /* height */
if (!pixbuf) {
- g_printerr("could not create pixbuf\n");
+ g_printerr ("Could not create pixbuf\n");
goto out;
}
- buffer = gdk_pixbuf_get_pixels(pixbuf);
- len = gdk_pixbuf_get_rowstride(pixbuf) * gdk_pixbuf_get_height(pixbuf);
+
+ buffer = gdk_pixbuf_get_pixels (pixbuf);
+ len = gdk_pixbuf_get_rowstride (pixbuf) * gdk_pixbuf_get_height (pixbuf);
+
+ /* fill the pixbuf buffer to make it white */
for (i = 0; i < len; i++)
buffer[i] = 255;
- pen_x = font_size/2;
+ pen_x = font_size / 2;
pen_y = font_size;
if (default_thumbstr) {
@@ -349,38 +381,43 @@ main(int argc, char **argv)
/* if the glyphs for those letters don't exist, pick some other
* glyphs. */
- if (glyph_index1 == 0) glyph_index1 = MIN (65, face->num_glyphs-1);
- if (glyph_index2 == 0) glyph_index2 = MIN (97, face->num_glyphs-1);
+ if (glyph_index1 == 0)
+ glyph_index1 = MIN (65, face->num_glyphs - 1);
- draw_char(pixbuf, face, glyph_index1, &pen_x, &pen_y);
- draw_char(pixbuf, face, glyph_index2, &pen_x, &pen_y);
- }
- else {
- gunichar *p = thumbstr;
+ if (glyph_index2 == 0)
+ glyph_index2 = MIN (97, face->num_glyphs - 1);
+
+ draw_char (pixbuf, face, glyph_index1, &pen_x, &pen_y);
+ draw_char (pixbuf, face, glyph_index2, &pen_x, &pen_y);
+ } else {
+ const gunichar *p = thumbstr;
FT_Select_Charmap (face, FT_ENCODING_UNICODE);
i = 0;
+
while (i < thumbstr_len) {
glyph_index1 = FT_Get_Char_Index (face, *p);
- draw_char(pixbuf, face, glyph_index1, &pen_x, &pen_y);
+ draw_char (pixbuf, face, glyph_index1, &pen_x, &pen_y);
i++;
p++;
}
}
- save_pixbuf(pixbuf, arguments[1]);
- g_object_unref(pixbuf);
+
+ save_pixbuf (pixbuf, arguments[1]);
+ g_object_unref (pixbuf);
totem_resources_monitor_stop ();
/* freeing the face causes a crash I haven't tracked down yet */
- error = FT_Done_Face(face);
+ error = FT_Done_Face (face);
if (error) {
- g_printerr("could not unload face: %s\n", get_ft_error(error));
+ g_printerr("Could not unload face: %s\n", get_ft_error (error));
goto out;
}
- error = FT_Done_FreeType(library);
+
+ error = FT_Done_FreeType (library);
if (error) {
- g_printerr("could not finalise freetype library: %s\n",
- get_ft_error(error));
+ g_printerr ("Could not finalize freetype library: %s\n",
+ get_ft_error (error));
goto out;
}
diff --git a/font-viewer/font-view.c b/font-viewer/font-view.c
index 3c150441..bf4138fb 100644
--- a/font-viewer/font-view.c
+++ b/font-viewer/font-view.c
@@ -1,6 +1,10 @@
-/* -*- mode: C; c-basic-offset: 4 -*-
- * fontilus - a collection of font utilities for MATE
+/* -*- mode: C; c-basic-offset: 4 -*- */
+
+/*
+ * font-view: a font viewer for MATE
+ *
* Copyright (C) 2002-2003 James Henstridge <[email protected]>
+ * Copyright (C) 2010 Cosimo Cecchi <[email protected]>
*
* 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
@@ -26,121 +30,75 @@
#include FT_TYPE1_TABLES_H
#include FT_SFNT_NAMES_H
#include FT_TRUETYPE_IDS_H
-#include <X11/Xlib.h>
-#include <X11/Xft/Xft.h>
-
+#include <cairo/cairo-ft.h>
#include <gio/gio.h>
#include <gtk/gtk.h>
-#include <gdk/gdkx.h>
#include <glib/gi18n.h>
-FT_Error FT_New_Face_From_URI(FT_Library library,
- const gchar *uri,
- FT_Long face_index,
- FT_Face *aface);
+#include "ftstream-vfs.h"
static const gchar lowercase_text[] = "abcdefghijklmnopqrstuvwxyz";
static const gchar uppercase_text[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
static const gchar punctuation_text[] = "0123456789.:,;(*!?')";
-static inline XftFont *
-get_font(Display *xdisplay, FT_Face face, gint size, FcCharSet *charset)
+static void
+draw_string (cairo_t *cr,
+ const gchar *text,
+ gint *pos_y)
{
- FcPattern *pattern;
- XftFont *font;
- int screen = DefaultScreen (xdisplay);
+ GdkColor black = { 0, 0, 0, 0 };
+ cairo_text_extents_t extents;
- pattern = FcPatternBuild(NULL,
- FC_FT_FACE, FcTypeFTFace, face,
- FC_PIXEL_SIZE, FcTypeDouble, (double)size,
- NULL);
+ gdk_cairo_set_source_color (cr, &black);
- if (charset)
- FcPatternAddCharSet (pattern, "charset", charset);
+ cairo_text_extents (cr, text, &extents);
+ cairo_move_to (cr, 4, *pos_y);
+ cairo_show_text (cr, text);
- FcConfigSubstitute (NULL, pattern, FcMatchPattern);
- XftDefaultSubstitute (xdisplay, screen, pattern);
-
- font = XftFontOpenPattern(xdisplay, pattern);
-
- return font;
-}
-
-static inline void
-draw_string(Display *xdisplay, XftDraw *draw, XftFont *font, XftColor *colour,
- const gchar *text, gint *pos_y)
-{
- XGlyphInfo extents;
- gint len = strlen(text);
-
- XftTextExtentsUtf8(xdisplay, font, (guchar *)text, len, &extents);
- XftDrawStringUtf8(draw, colour, font, 4, *pos_y + extents.y, (guchar *)text, len);
- *pos_y += extents.height + 4;
+ *pos_y += extents.height + extents.y_advance + 4;
}
static gboolean
check_font_contain_text (FT_Face face, const gchar *text)
{
- while (text && *text)
- {
+ while (text && *text) {
gunichar wc = g_utf8_get_char (text);
+
if (!FT_Get_Char_Index (face, wc))
return FALSE;
text = g_utf8_next_char (text);
- }
+ }
return TRUE;
}
-#if GTK_CHECK_VERSION (3, 0, 0)
- /* FIXME */
- /* https://git.gnome.org/browse/gnome-control-center/commit/font-viewer?h=gnome-3-0&id=7ea3249a4a0fa9a176a120257355a4ca75593386 */
-#else
-static gboolean expose_event(GtkWidget *widget, GdkEventExpose *event, GdkPixmap *pixmap);
-
-static GdkPixmap *
-create_text_pixmap(GtkWidget *drawing_area, FT_Face face)
+static const gchar *
+get_sample_string (FT_Face face)
{
- gint i, pixmap_width, pixmap_height, pos_y, textlen;
- GdkPixmap *pixmap = NULL;
const gchar *text;
- Display *xdisplay;
- Drawable xdrawable;
- Visual *xvisual;
- Colormap xcolormap;
- XftDraw *draw;
- XftColor colour;
- XGlyphInfo extents;
- XftFont *font;
- gint *sizes = NULL, n_sizes, alpha_size;
- FcCharSet *charset = NULL;
- GdkWindow *window = gtk_widget_get_window (drawing_area);
-
- text = pango_language_get_sample_string(NULL);
- if (! check_font_contain_text (face, text))
- {
- pango_language_get_sample_string (pango_language_from_string ("en_US"));
- }
- textlen = strlen(text);
+ text = pango_language_get_sample_string (NULL);
- /* create the XftDraw */
- xdisplay = GDK_PIXMAP_XDISPLAY(window);
+ if (!check_font_contain_text (face, text)) {
+ text = pango_language_get_sample_string (pango_language_from_string ("en_US"));
+ }
- #if GTK_CHECK_VERSION(3, 0, 0)
- xvisual = GDK_VISUAL_XVISUAL(gdk_window_get_visual(window));
- #else
- xvisual = GDK_VISUAL_XVISUAL(gdk_drawable_get_visual(window));
- #endif
+ return text;
+}
- xcolormap = GDK_COLORMAP_XCOLORMAP(gdk_drawable_get_colormap(window));
- XftColorAllocName(xdisplay, xvisual, xcolormap, "black", &colour);
+static gint *
+build_sizes_table (FT_Face face,
+ gint *n_sizes,
+ gint *alpha_size)
+{
+ gint *sizes = NULL;
+ gint i;
/* work out what sizes to render */
- if (FT_IS_SCALABLE(face)) {
- n_sizes = 8;
- sizes = g_new(gint, n_sizes);
+ if (FT_IS_SCALABLE (face)) {
+ *n_sizes = 8;
+ sizes = g_new (gint, *n_sizes);
sizes[0] = 8;
sizes[1] = 10;
sizes[2] = 12;
@@ -149,106 +107,158 @@ create_text_pixmap(GtkWidget *drawing_area, FT_Face face)
sizes[5] = 36;
sizes[6] = 48;
sizes[7] = 72;
- alpha_size = 24;
+ *alpha_size = 24;
} else {
/* use fixed sizes */
- n_sizes = face->num_fixed_sizes;
- sizes = g_new(gint, n_sizes);
- alpha_size = 0;
+ *n_sizes = face->num_fixed_sizes;
+ sizes = g_new (gint, *n_sizes);
+ *alpha_size = 0;
+
for (i = 0; i < face->num_fixed_sizes; i++) {
sizes[i] = face->available_sizes[i].height;
/* work out which font size to render */
if (face->available_sizes[i].height <= 24)
- alpha_size = face->available_sizes[i].height;
+ *alpha_size = face->available_sizes[i].height;
}
}
+ return sizes;
+}
+
+static void
+realize_callback (GtkWidget *drawing_area,
+ FT_Face face)
+{
+ gint i, pixmap_width, pixmap_height;
+ const gchar *text;
+ cairo_text_extents_t extents;
+ cairo_font_face_t *font;
+ gint *sizes = NULL, n_sizes, alpha_size;
+ cairo_t *cr;
+
+ cr = gdk_cairo_create (gtk_widget_get_window (drawing_area));
+
+ text = get_sample_string (face);
+ sizes = build_sizes_table (face, &n_sizes, &alpha_size);
+
/* calculate size of pixmap to use (with 4 pixels padding) ... */
pixmap_width = 8;
pixmap_height = 8;
- font = get_font(xdisplay, face, alpha_size, charset);
- charset = FcCharSetCopy (font->charset);
- XftTextExtentsUtf8(xdisplay, font,
- (guchar *)lowercase_text, strlen(lowercase_text), &extents);
+ font = cairo_ft_font_face_create_for_ft_face (face, 0);
+ cairo_set_font_face (cr, font);
+ cairo_set_font_size (cr, alpha_size);
+ cairo_font_face_destroy (font);
+
+ cairo_text_extents (cr, lowercase_text, &extents);
pixmap_height += extents.height + 4;
- pixmap_width = MAX(pixmap_width, 8 + extents.width);
- XftTextExtentsUtf8(xdisplay, font,
- (guchar *)uppercase_text, strlen(uppercase_text), &extents);
+ pixmap_width = MAX (pixmap_width, 8 + extents.width);
+
+ cairo_text_extents (cr, uppercase_text, &extents);
pixmap_height += extents.height + 4;
- pixmap_width = MAX(pixmap_width, 8 + extents.width);
- XftTextExtentsUtf8(xdisplay, font,
- (guchar *)punctuation_text, strlen(punctuation_text), &extents);
+ pixmap_width = MAX (pixmap_width, 8 + extents.width);
+
+ cairo_text_extents (cr, punctuation_text, &extents);
pixmap_height += extents.height + 4;
- pixmap_width = MAX(pixmap_width, 8 + extents.width);
- XftFontClose(xdisplay, font);
+ pixmap_width = MAX (pixmap_width, 8 + extents.width);
pixmap_height += 8;
for (i = 0; i < n_sizes; i++) {
- font = get_font(xdisplay, face, sizes[i], charset);
- if (!font) continue;
- XftTextExtentsUtf8(xdisplay, font, (guchar *)text, textlen, &extents);
+ cairo_set_font_size (cr, sizes[i]);
+ cairo_text_extents (cr, text, &extents);
pixmap_height += extents.height + 4;
- pixmap_width = MAX(pixmap_width, 8 + extents.width);
- XftFontClose(xdisplay, font);
+ pixmap_width = MAX (pixmap_width, 8 + extents.width);
}
- /* create pixmap */
- gtk_widget_set_size_request(drawing_area, pixmap_width, pixmap_height);
- pixmap = gdk_pixmap_new(window,
- pixmap_width, pixmap_height, -1);
- if (!pixmap)
- goto end;
- gdk_draw_rectangle(pixmap, gtk_widget_get_style(drawing_area)->white_gc,
- TRUE, 0, 0, pixmap_width, pixmap_height);
+ gtk_widget_set_size_request (drawing_area, pixmap_width, pixmap_height);
+
+ cairo_destroy (cr);
+ g_free (sizes);
+}
- xdrawable = GDK_DRAWABLE_XID(pixmap);
- draw = XftDrawCreate(xdisplay, xdrawable, xvisual, xcolormap);
+static void
+draw (GtkWidget *drawing_area,
+ cairo_t *cr,
+ FT_Face face)
+{
+ cairo_font_extents_t font_extents;
+ gint *sizes = NULL, n_sizes, alpha_size, pos_y, i;
+ const gchar *text;
+ cairo_font_face_t *font;
+
+ text = get_sample_string (face);
+ sizes = build_sizes_table (face, &n_sizes, &alpha_size);
+
+ font = cairo_ft_font_face_create_for_ft_face (face, 0);
+ cairo_set_font_face (cr, font);
+ cairo_font_extents (cr, &font_extents);
+ cairo_font_face_destroy (font);
/* draw text */
- pos_y = 4;
- font = get_font(xdisplay, face, alpha_size, charset);
- draw_string(xdisplay, draw, font, &colour, lowercase_text, &pos_y);
- draw_string(xdisplay, draw, font, &colour, uppercase_text, &pos_y);
- draw_string(xdisplay, draw, font, &colour, punctuation_text, &pos_y);
- XftFontClose(xdisplay, font);
+ pos_y = MAX (font_extents.height, 32) + 4;
+ cairo_set_font_size (cr, alpha_size);
+ draw_string (cr, lowercase_text, &pos_y);
+ draw_string (cr, uppercase_text, &pos_y);
+ draw_string (cr, punctuation_text, &pos_y);
pos_y += 8;
for (i = 0; i < n_sizes; i++) {
- font = get_font(xdisplay, face, sizes[i], charset);
- if (!font) continue;
- draw_string(xdisplay, draw, font, &colour, text, &pos_y);
- XftFontClose(xdisplay, font);
+ cairo_set_font_size (cr, sizes[i]);
+ draw_string (cr, text, &pos_y);
}
- g_signal_connect(drawing_area, "expose-event", G_CALLBACK(expose_event),
- pixmap);
+ g_free (sizes);
+}
- end:
- g_free(sizes);
- FcCharSetDestroy (charset);
- return pixmap;
+#if GTK_CHECK_VERSION (3, 0, 0)
+static void
+draw_callback (GtkWidget *drawing_area,
+ cairo_t *cr,
+ FT_Face face)
+{
+ draw (drawing_area, cr, face);
+}
+#else
+static void
+expose_callback (GtkWidget *drawing_area,
+ GdkEventExpose *event,
+ FT_Face face)
+{
+ cairo_t *cr = gdk_cairo_create (event->window);
+ draw (drawing_area, cr, face);
+ cairo_destroy (cr);
}
#endif
static void
-add_row(GtkWidget *table, gint *row_p,
- const gchar *name, const gchar *value, gboolean multiline,
- gboolean expand)
+#if GTK_CHECK_VERSION (3, 4, 0)
+add_row (GtkWidget *grid,
+#else
+add_row (GtkWidget *table,
+ gint *row_p,
+#endif
+ const gchar *name,
+ const gchar *value,
+ gboolean multiline,
+ gboolean expand)
{
gchar *bold_name;
GtkWidget *name_w;
- bold_name = g_strconcat("<b>", name, "</b>", NULL);
- name_w = gtk_label_new(bold_name);
- g_free(bold_name);
- gtk_misc_set_alignment(GTK_MISC(name_w), 0.0, 0.0);
- gtk_label_set_use_markup(GTK_LABEL(name_w), TRUE);
+ bold_name = g_strconcat ("<b>", name, "</b>", NULL);
+ name_w = gtk_label_new (bold_name);
+ g_free (bold_name);
+ gtk_misc_set_alignment (GTK_MISC (name_w), 0.0, 0.0);
+ gtk_label_set_use_markup (GTK_LABEL (name_w), TRUE);
- gtk_table_attach(GTK_TABLE(table), name_w, 0, 1, *row_p, *row_p + 1,
- GTK_FILL, GTK_FILL, 0, 0);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ gtk_container_add (GTK_CONTAINER (grid), name_w);
+#else
+ gtk_table_attach (GTK_TABLE(table), name_w, 0, 1, *row_p, *row_p + 1,
+ GTK_FILL, GTK_FILL, 0, 0);
+#endif
if (multiline) {
GtkWidget *label, *viewport;
@@ -261,52 +271,86 @@ add_row(GtkWidget *table, gint *row_p,
gtk_widget_set_size_request (label, 200, -1);
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.0);
-
- swin = GTK_SCROLLED_WINDOW(gtk_scrolled_window_new(NULL, NULL));
- gtk_scrolled_window_set_policy(swin,
- GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
+ swin = GTK_SCROLLED_WINDOW (gtk_scrolled_window_new (NULL, NULL));
+ gtk_scrolled_window_set_policy (swin,
+ GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
viewport = gtk_viewport_new (gtk_scrolled_window_get_hadjustment (swin),
gtk_scrolled_window_get_vadjustment (swin));
gtk_viewport_set_shadow_type (GTK_VIEWPORT (viewport), GTK_SHADOW_NONE);
- gtk_container_add (GTK_CONTAINER(swin), viewport);
+ gtk_container_add (GTK_CONTAINER (swin), viewport);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ if (expand) {
+ gtk_widget_set_hexpand (GTK_WIDGET (swin), TRUE);
+ gtk_widget_set_vexpand (GTK_WIDGET (swin), TRUE);
+ }
+
+ gtk_container_add_with_properties (GTK_CONTAINER (grid), GTK_WIDGET (swin),
+ "width", 2,
+ NULL);
+#else
(*row_p)++;
+
if (expand)
- flags = GTK_FILL|GTK_EXPAND;
+ flags = GTK_FILL | GTK_EXPAND;
else
flags = GTK_FILL;
- gtk_table_attach(GTK_TABLE(table), GTK_WIDGET(swin), 0, 2, *row_p, *row_p + 1,
- GTK_FILL|GTK_EXPAND, flags, 0, 0);
+
+ gtk_table_attach (GTK_TABLE (table), GTK_WIDGET (swin),
+ 0, 2, *row_p, *row_p + 1,
+ GTK_FILL | GTK_EXPAND, flags, 0, 0);
+#endif
gtk_container_add (GTK_CONTAINER (viewport), label);
} else {
- GtkWidget *label = gtk_label_new(value);
- gtk_misc_set_alignment(GTK_MISC(label), 0.0, 0.5);
- gtk_label_set_selectable(GTK_LABEL(label), TRUE);
- gtk_table_attach(GTK_TABLE(table), label, 1, 2, *row_p, *row_p + 1,
- GTK_FILL|GTK_EXPAND, GTK_FILL, 0, 0);
+ GtkWidget *label = gtk_label_new (value);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_selectable (GTK_LABEL(label), TRUE);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ gtk_grid_attach_next_to (GTK_GRID (grid), label,
+ name_w, GTK_POS_RIGHT,
+ 1, 1);
+ }
+#else
+ gtk_table_attach (GTK_TABLE (table), label,
+ 1, 2, *row_p, *row_p + 1,
+ GTK_FILL | GTK_EXPAND, GTK_FILL, 0, 0);
}
-
(*row_p)++;
+#endif
}
static void
-add_face_info(GtkWidget *table, gint *row_p, const gchar *uri, FT_Face face)
+#if GTK_CHECK_VERSION (3, 4, 0)
+add_face_info (GtkWidget *grid,
+#else
+add_face_info (GtkWidget *table,
+ gint *row_p,
+#endif
+ const gchar *uri,
+ FT_Face face)
{
gchar *s;
GFile *file;
GFileInfo *info;
PS_FontInfoRec ps_info;
- add_row(table, row_p, _("Name:"), face->family_name, FALSE, FALSE);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Name:"), face->family_name, FALSE, FALSE);
+#else
+ add_row (table, row_p, _("Name:"), face->family_name, FALSE, FALSE);
+#endif
if (face->style_name)
- add_row(table, row_p, _("Style:"), face->style_name, FALSE, FALSE);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Style:"), face->style_name, FALSE, FALSE);
+#else
+ add_row (table, row_p, _("Style:"), face->style_name, FALSE, FALSE);
+#endif
file = g_file_new_for_uri (uri);
-
info = g_file_query_info (file,
G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE ","
G_FILE_ATTRIBUTE_STANDARD_SIZE,
@@ -314,27 +358,35 @@ add_face_info(GtkWidget *table, gint *row_p, const gchar *uri, FT_Face face)
NULL, NULL);
g_object_unref (file);
- if (info) {
+ if (info != NULL) {
s = g_content_type_get_description (g_file_info_get_content_type (info));
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Type:"), s, FALSE, FALSE);
+#else
add_row (table, row_p, _("Type:"), s, FALSE, FALSE);
+#endif
g_free (s);
s = g_format_size (g_file_info_get_size (info));
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Size:"), s, FALSE, FALSE);
+#else
add_row (table, row_p, _("Size:"), s, FALSE, FALSE);
+#endif
g_free (s);
g_object_unref (info);
}
- if (FT_IS_SFNT(face)) {
+ if (FT_IS_SFNT (face)) {
gint i, len;
gchar *version = NULL, *copyright = NULL, *description = NULL;
- len = FT_Get_Sfnt_Name_Count(face);
+ len = FT_Get_Sfnt_Name_Count (face);
for (i = 0; i < len; i++) {
FT_SfntName sname;
- if (FT_Get_Sfnt_Name(face, i, &sname) != 0)
+ if (FT_Get_Sfnt_Name (face, i, &sname) != 0)
continue;
/* only handle the unicode names for US langid */
@@ -345,60 +397,67 @@ add_face_info(GtkWidget *table, gint *row_p, const gchar *uri, FT_Face face)
switch (sname.name_id) {
case TT_NAME_ID_COPYRIGHT:
- g_free(copyright);
- copyright = g_convert((gchar *)sname.string, sname.string_len,
- "UTF-8", "UTF-16BE", NULL, NULL, NULL);
+ g_free (copyright);
+ copyright = g_convert ((gchar *)sname.string, sname.string_len,
+ "UTF-8", "UTF-16BE", NULL, NULL, NULL);
break;
case TT_NAME_ID_VERSION_STRING:
- g_free(version);
- version = g_convert((gchar *)sname.string, sname.string_len,
- "UTF-8", "UTF-16BE", NULL, NULL, NULL);
+ g_free (version);
+ version = g_convert ((gchar *)sname.string, sname.string_len,
+ "UTF-8", "UTF-16BE", NULL, NULL, NULL);
break;
case TT_NAME_ID_DESCRIPTION:
- g_free(description);
- description = g_convert((gchar *)sname.string, sname.string_len,
- "UTF-8", "UTF-16BE", NULL, NULL, NULL);
+ g_free (description);
+ description = g_convert ((gchar *)sname.string, sname.string_len,
+ "UTF-8", "UTF-16BE", NULL, NULL, NULL);
break;
default:
break;
}
}
if (version) {
- add_row(table, row_p, _("Version:"), version, FALSE, FALSE);
- g_free(version);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Version:"), version, FALSE, FALSE);
+#else
+ add_row (table, row_p, _("Version:"), version, FALSE, FALSE);
+#endif
+ g_free (version);
}
if (copyright) {
- add_row(table, row_p, _("Copyright:"), copyright, TRUE, TRUE);
- g_free(copyright);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Copyright:"), copyright, TRUE, TRUE);
+#else
+ add_row (table, row_p, _("Copyright:"), copyright, TRUE, TRUE);
+#endif
+ g_free (copyright);
}
if (description) {
- add_row(table, row_p, _("Description:"), description, TRUE, TRUE);
- g_free(description);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Description:"), description, TRUE, TRUE);
+#else
+ add_row (table, row_p, _("Description:"), description, TRUE, TRUE);
+#endif
+ g_free (description);
}
- } else if (FT_Get_PS_Font_Info(face, &ps_info) == 0) {
- if (ps_info.version && g_utf8_validate(ps_info.version, -1, NULL))
- add_row(table, row_p, _("Version:"), ps_info.version, FALSE, FALSE);
- if (ps_info.notice && g_utf8_validate(ps_info.notice, -1, NULL))
- add_row(table, row_p, _("Copyright:"), ps_info.notice, TRUE, FALSE);
+ } else if (FT_Get_PS_Font_Info (face, &ps_info) == 0) {
+ if (ps_info.version && g_utf8_validate (ps_info.version, -1, NULL))
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Version:"), ps_info.version, FALSE, FALSE);
+#else
+ add_row (table, row_p, _("Version:"), ps_info.version, FALSE, FALSE);
+#endif
+ if (ps_info.notice && g_utf8_validate (ps_info.notice, -1, NULL))
+#if GTK_CHECK_VERSION (3, 4, 0)
+ add_row (grid, _("Copyright:"), ps_info.notice, TRUE, FALSE);
+#else
+ add_row (table, row_p, _("Copyright:"), ps_info.notice, TRUE, FALSE);
+#endif
}
}
-#if !GTK_CHECK_VERSION (3, 0, 0)
-static gboolean
-expose_event(GtkWidget *widget, GdkEventExpose *event, GdkPixmap *pixmap)
-{
- gdk_draw_drawable(gtk_widget_get_window (widget),
- gtk_widget_get_style (widget)->fg_gc[gtk_widget_get_state (widget)],
- pixmap,
- event->area.x, event->area.y,
- event->area.x, event->area.y,
- event->area.width, event->area.height);
- return FALSE;
-}
-#endif
-
static void
-set_icon(GtkWindow *window, const gchar *uri)
+set_icon (GtkWindow *window,
+ const gchar *uri)
{
GFile *file;
GIcon *icon;
@@ -411,12 +470,11 @@ set_icon(GtkWindow *window, const gchar *uri)
icon_theme = gtk_icon_theme_get_for_screen (screen);
file = g_file_new_for_uri (uri);
-
info = g_file_query_info (file, G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE,
G_FILE_QUERY_INFO_NONE, NULL, NULL);
g_object_unref (file);
- if (! info)
+ if (info == NULL)
return;
content_type = g_file_info_get_content_type (info);
@@ -455,22 +513,21 @@ font_install_finished_cb (GObject *source_object,
if (!err) {
gtk_button_set_label (GTK_BUTTON (data), _("Installed"));
- }
- else {
+ } else {
gtk_button_set_label (GTK_BUTTON (data), _("Install Failed"));
g_debug ("Install failed: %s", err->message);
g_error_free (err);
}
+
gtk_widget_set_sensitive (GTK_WIDGET (data), FALSE);
}
static void
-install_button_clicked_cb (GtkButton *button,
+install_button_clicked_cb (GtkButton *button,
const gchar *font_file)
{
GFile *src, *dest;
gchar *dest_path, *dest_filename;
-
GError *err = NULL;
/* first check if ~/.fonts exists */
@@ -493,7 +550,8 @@ install_button_clicked_cb (GtkButton *button,
src = g_file_new_for_uri (font_file);
dest_filename = g_file_get_basename (src);
- dest_path = g_build_filename (g_get_home_dir (), ".fonts", dest_filename, NULL);
+ dest_path = g_build_filename (g_get_home_dir (), ".fonts", dest_filename,
+ NULL);
g_free (dest_filename);
dest = g_file_new_for_path (dest_path);
@@ -508,7 +566,8 @@ install_button_clicked_cb (GtkButton *button,
}
int
-main(int argc, char **argv)
+main (int argc,
+ char **argv)
{
FT_Error error;
FT_Library library;
@@ -516,32 +575,28 @@ main(int argc, char **argv)
GFile *file;
gchar *font_file, *title;
gint row;
+#if GTK_CHECK_VERSION (3, 4, 0)
+ GtkWidget *window, *hbox, *grid, *swin, *drawing_area;
+#else
GtkWidget *window, *hbox, *table, *swin, *drawing_area;
-#if !GTK_CHECK_VERSION (3, 0, 0)
- GdkPixmap *pixmap;
#endif
GdkColor white = { 0, 0xffff, 0xffff, 0xffff };
GtkWidget *button, *align;
- bindtextdomain(GETTEXT_PACKAGE, MATELOCALEDIR);
- bind_textdomain_codeset(GETTEXT_PACKAGE, "UTF-8");
- textdomain(GETTEXT_PACKAGE);
+ bindtextdomain (GETTEXT_PACKAGE, MATELOCALEDIR);
+ bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
+ textdomain (GETTEXT_PACKAGE);
- gtk_init(&argc, &argv);
+ gtk_init (&argc, &argv);
if (argc != 2) {
- g_printerr(_("usage: %s fontfile\n"), argv[0]);
- return 1;
- }
-
- if (!XftInitFtLibrary()) {
- g_printerr("could not initialise freetype library\n");
+ g_printerr (_("Usage: %s fontfile\n"), argv[0]);
return 1;
}
- error = FT_Init_FreeType(&library);
+ error = FT_Init_FreeType (&library);
if (error) {
- g_printerr("could not initialise freetype\n");
+ g_printerr("Could not initialise freetype\n");
return 1;
}
@@ -550,69 +605,106 @@ main(int argc, char **argv)
g_object_unref (file);
if (!font_file) {
- g_printerr("could not parse argument into a URI\n");
+ g_printerr("Could not parse argument into a URI\n");
return 1;
}
- error = FT_New_Face_From_URI(library, font_file, 0, &face);
+ error = FT_New_Face_From_URI (library, font_file, 0, &face);
if (error) {
- g_printerr("could not load face '%s'\n", font_file);
+ g_printerr("Could not load face '%s'\n", font_file);
return 1;
}
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- title = g_strconcat(face->family_name,
- face->style_name ? ", " : "",
- face->style_name, NULL);
- gtk_window_set_title(GTK_WINDOW(window), title);
- set_icon(GTK_WINDOW(window), font_file);
- g_free(title);
- gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
-
- hbox = gtk_hbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(window), hbox);
-
- swin = gtk_scrolled_window_new(NULL, NULL);
- gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(swin),
- GTK_POLICY_AUTOMATIC, GTK_POLICY_NEVER);
- gtk_box_pack_start(GTK_BOX(hbox), swin, TRUE, TRUE, 0);
-
- drawing_area = gtk_drawing_area_new();
- gtk_widget_modify_bg(drawing_area, GTK_STATE_NORMAL, &white);
- gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(swin),
- drawing_area);
-#if !GTK_CHECK_VERSION (3, 0, 0)
- g_signal_connect (drawing_area, "realize", G_CALLBACK(create_text_pixmap), face);
+ window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ title = g_strconcat (face->family_name,
+ face->style_name ? ", " : "",
+ face->style_name, NULL);
+ gtk_window_set_title (GTK_WINDOW (window), title);
+ set_icon (GTK_WINDOW (window), font_file);
+ g_free (title);
+ gtk_window_set_resizable (GTK_WINDOW (window), TRUE);
+
+#if GTK_CHECK_VERSION (3, 2, 0)
+ hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+#else
+ hbox = gtk_hbox_new (FALSE, 0);
+#endif
+ gtk_container_add (GTK_CONTAINER (window), hbox);
+
+ swin = gtk_scrolled_window_new (NULL, NULL);
+ gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (swin),
+ GTK_POLICY_AUTOMATIC, GTK_POLICY_NEVER);
+ gtk_box_pack_start (GTK_BOX (hbox), swin, TRUE, TRUE, 0);
+
+ drawing_area = gtk_drawing_area_new ();
+ gtk_widget_modify_bg (drawing_area, GTK_STATE_NORMAL, &white);
+ gtk_scrolled_window_add_with_viewport (GTK_SCROLLED_WINDOW (swin),
+ drawing_area);
+ g_signal_connect (drawing_area, "realize",
+ G_CALLBACK (realize_callback), face);
+#if GTK_CHECK_VERSION (3, 0, 0)
+ g_signal_connect (drawing_area, "draw",
+ G_CALLBACK (draw_callback), face);
+#else
+ g_signal_connect (drawing_area, "expose-event",
+ G_CALLBACK (expose_callback), face);
#endif
/* set the minimum size on the scrolled window to prevent
* unnecessary scrolling */
- gtk_widget_set_size_request(swin, 500, -1);
+ /* 800 is better for GtkGrid */
+#if GTK_CHECK_VERSION (3, 4, 0)
+ gtk_widget_set_size_request (swin, 800, -1);
+#else
+ gtk_widget_set_size_request (swin, 500, -1);
+#endif
- g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);
+ g_signal_connect (window, "destroy",
+ G_CALLBACK (gtk_main_quit), NULL);
- table = gtk_table_new(1, 2, FALSE);
- gtk_container_set_border_width(GTK_CONTAINER(table), 5);
- gtk_box_pack_start(GTK_BOX(hbox), table, FALSE, TRUE, 0);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ grid = gtk_grid_new ();
+ gtk_orientable_set_orientation (GTK_ORIENTABLE (grid), GTK_ORIENTATION_VERTICAL);
+ gtk_container_set_border_width (GTK_CONTAINER (grid), 5);
+ gtk_box_pack_start (GTK_BOX (hbox), grid, FALSE, TRUE, 0);
+
+ add_face_info (grid, font_file, face);
+#else
+ table = gtk_table_new (1, 2, FALSE);
+ gtk_container_set_border_width (GTK_CONTAINER (table), 5);
+ gtk_box_pack_start (GTK_BOX (hbox), table, FALSE, TRUE, 0);
row = 0;
- add_face_info(table, &row, font_file, face);
+ add_face_info (table, &row, font_file, face);
+#endif
/* add install button */
align = gtk_alignment_new (1.0, 0.5, 0.0, 0.0);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ gtk_widget_set_hexpand (align, TRUE);
+ gtk_container_add_with_properties (GTK_CONTAINER (grid), align,
+ "width", 2,
+ NULL);
+#else
gtk_table_attach (GTK_TABLE (table), align, 0, 2, row, row + 1,
- GTK_FILL|GTK_EXPAND, GTK_FILL, 0, 0);
+ GTK_FILL | GTK_EXPAND, GTK_FILL, 0, 0);
+#endif
button = gtk_button_new_with_mnemonic (_("I_nstall Font"));
g_signal_connect (button, "clicked",
G_CALLBACK (install_button_clicked_cb), font_file);
gtk_container_add (GTK_CONTAINER (align), button);
+#if GTK_CHECK_VERSION (3, 4, 0)
+ gtk_grid_set_column_spacing (GTK_GRID (grid), 8);
+ gtk_grid_set_row_spacing (GTK_GRID (grid), 2);
+#else
+ gtk_table_set_col_spacings (GTK_TABLE (table), 8);
+ gtk_table_set_row_spacings (GTK_TABLE (table), 2);
+#endif
+ gtk_widget_show_all (window);
- gtk_table_set_col_spacings(GTK_TABLE(table), 8);
- gtk_table_set_row_spacings(GTK_TABLE(table), 2);
- gtk_widget_show_all(window);
+ gtk_main ();
- gtk_main();
return 0;
}
diff --git a/font-viewer/ftstream-vfs.c b/font-viewer/ftstream-vfs.c
index 9ea7cac1..cf666f2e 100644
--- a/font-viewer/ftstream-vfs.c
+++ b/font-viewer/ftstream-vfs.c
@@ -1,5 +1,8 @@
-/* -*- mode: C; c-basic-offset: 4 -*-
- * fontilus - a collection of font utilities for MATE
+/* -*- mode: C; c-basic-offset: 4 -*- */
+
+/*
+ * ftstream-vfs: a FreeType/GIO stream bridge
+ *
* Copyright (C) 2002-2003 James Henstridge <[email protected]>
*
* This program is free software; you can redistribute it and/or modify
@@ -27,20 +30,23 @@
#include <gio/gio.h>
+#include "ftstream-vfs.h"
+
static unsigned long
-vfs_stream_read(FT_Stream stream,
- unsigned long offset,
- unsigned char *buffer,
- unsigned long count)
+vfs_stream_read (FT_Stream stream,
+ unsigned long offset,
+ unsigned char *buffer,
+ unsigned long count)
{
- GFileInputStream *handle = (GFileInputStream *)stream->descriptor.pointer;
+ GFileInputStream *handle = stream->descriptor.pointer;
gssize bytes_read = 0;
- if (! g_seekable_seek (G_SEEKABLE (handle), offset, G_SEEK_SET, NULL, NULL))
+ if (!g_seekable_seek (G_SEEKABLE (handle), offset, G_SEEK_SET, NULL, NULL))
return 0;
if (count > 0) {
- bytes_read = g_input_stream_read (G_INPUT_STREAM (handle), buffer, count, NULL, NULL);
+ bytes_read = g_input_stream_read (G_INPUT_STREAM (handle), buffer,
+ count, NULL, NULL);
if (bytes_read == -1)
return 0;
@@ -50,51 +56,44 @@ vfs_stream_read(FT_Stream stream,
}
static void
-vfs_stream_close(FT_Stream stream)
+vfs_stream_close (FT_Stream stream)
{
- GFileInputStream *handle = (GFileInputStream *)stream->descriptor.pointer;
+ GFileInputStream *handle = stream->descriptor.pointer;
- if (! handle)
+ if (handle == NULL)
return;
+ /* this also closes the stream */
g_object_unref (handle);
stream->descriptor.pointer = NULL;
- stream->size = 0;
- stream->base = NULL;
+ stream->size = 0;
+ stream->base = NULL;
}
static FT_Error
-vfs_stream_open(FT_Stream stream,
- const char *uri)
+vfs_stream_open (FT_Stream stream,
+ const char *uri)
{
GFile *file;
- GError *error = NULL;
GFileInfo *info;
GFileInputStream *handle;
- if (!stream)
- return FT_Err_Invalid_Stream_Handle;
-
file = g_file_new_for_uri (uri);
+ handle = g_file_read (file, NULL, NULL);
- handle = g_file_read (file, NULL, &error);
- if (! handle) {
- g_message ("%s", error->message);
+ if (handle == NULL) {
g_object_unref (file);
-
- g_error_free (error);
return FT_Err_Cannot_Open_Resource;
}
- info = g_file_query_info (file, G_FILE_ATTRIBUTE_STANDARD_SIZE,
- G_FILE_QUERY_INFO_NONE, NULL, &error);
+ info = g_file_query_info (file,
+ G_FILE_ATTRIBUTE_STANDARD_SIZE,
+ G_FILE_QUERY_INFO_NONE, NULL,
+ NULL);
g_object_unref (file);
- if (! info) {
- g_warning ("%s", error->message);
-
- g_error_free (error);
+ if (info == NULL) {
return FT_Err_Cannot_Open_Resource;
}
@@ -103,10 +102,10 @@ vfs_stream_open(FT_Stream stream,
g_object_unref (info);
stream->descriptor.pointer = handle;
- stream->pathname.pointer = NULL;
- stream->pos = 0;
+ stream->pathname.pointer = NULL;
+ stream->pos = 0;
- stream->read = vfs_stream_read;
+ stream->read = vfs_stream_read;
stream->close = vfs_stream_close;
return FT_Err_Ok;
@@ -114,36 +113,37 @@ vfs_stream_open(FT_Stream stream,
/* load a typeface from a URI */
FT_Error
-FT_New_Face_From_URI(FT_Library library,
- const gchar* uri,
- FT_Long face_index,
- FT_Face *aface)
+FT_New_Face_From_URI (FT_Library library,
+ const gchar* uri,
+ FT_Long face_index,
+ FT_Face *aface)
{
FT_Open_Args args;
FT_Stream stream;
FT_Error error;
- if ((stream = calloc(1, sizeof(*stream))) == NULL)
+ stream = calloc (1, sizeof (*stream));
+
+ if (stream == NULL)
return FT_Err_Out_Of_Memory;
- error = vfs_stream_open(stream, uri);
+ error = vfs_stream_open (stream, uri);
+
if (error != FT_Err_Ok) {
- free(stream);
+ free (stream);
return error;
}
- /* freetype-2.1.3 accidentally broke compatibility. */
-#if defined(FT_OPEN_STREAM) && !defined(ft_open_stream)
-# define ft_open_stream FT_OPEN_STREAM
-#endif
- args.flags = ft_open_stream;
+ args.flags = FT_OPEN_STREAM;
args.stream = stream;
- error = FT_Open_Face(library, &args, face_index, aface);
+ error = FT_Open_Face (library, &args, face_index, aface);
if (error != FT_Err_Ok) {
- if (stream->close) stream->close(stream);
- free(stream);
+ if (stream->close != NULL)
+ stream->close(stream);
+
+ free (stream);
return error;
}
diff --git a/font-viewer/ftstream-vfs.h b/font-viewer/ftstream-vfs.h
new file mode 100644
index 00000000..c550cafd
--- /dev/null
+++ b/font-viewer/ftstream-vfs.h
@@ -0,0 +1,35 @@
+/* -*- mode: C; c-basic-offset: 4 -*- */
+
+/*
+ * ftstream-vfs: a FreeType/GIO stream bridge
+ *
+ * Copyright (C) 2002-2003 James Henstridge <[email protected]>
+ *
+ * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#ifndef __FTSTREAM_VFS_H__
+#define __FTSTREAM_VFS_H__
+
+#include <ft2build.h>
+#include FT_FREETYPE_H
+#include <glib.h>
+
+FT_Error FT_New_Face_From_URI (FT_Library library,
+ const gchar* uri,
+ FT_Long face_index,
+ FT_Face *aface);
+
+#endif /* __FTSTREAM_VFS_H__ */
diff --git a/font-viewer/totem-resources.c b/font-viewer/totem-resources.c
index 3d107737..96e90524 100644
--- a/font-viewer/totem-resources.c
+++ b/font-viewer/totem-resources.c
@@ -25,7 +25,7 @@
*
*/
-#include "config.h"
+#include <config.h>
#include <glib.h>
#include <glib/gstdio.h>
@@ -112,7 +112,7 @@ totem_resources_monitor_start (const char *input, gint wall_clock_time)
sleep_time = wall_clock_time;
finished = FALSE;
- g_thread_create (time_monitor, (gpointer) input, FALSE, NULL);
+ g_thread_new ("time-monitor", time_monitor, (gpointer) input);
}
void