mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-11 21:20:09 +00:00
If possible, create only a single shm segment and use multiple parts of it
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com> * gdk/gdkrgb.c: If possible, create only a single shm segment and use multiple parts of it instead of creating a bunch of separate segments, since the maximum number of segments per system is not large. (This might be worth backporting to GTK+-1.2.x if we make a new release ) * gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo structure in preparation for per-colormap GdkRGB. * gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm to False when we get EINVAL from shmget so that the caller of gdk_image_new can retry with a smaller segment size.
This commit is contained in:
parent
d872631bae
commit
2bb4bcff5d
15
ChangeLog
15
ChangeLog
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
Mon Jun 26 18:53:31 2000 Owen Taylor <otaylor@redhat.com>
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: If possible, create only a single shm segment and
|
||||||
|
use multiple parts of it instead of creating a bunch of separate
|
||||||
|
segments, since the maximum number of segments per system is not
|
||||||
|
large. (This might be worth backporting to GTK+-1.2.x if we make a
|
||||||
|
new release )
|
||||||
|
|
||||||
|
* gdk/gdkrgb.c: Localize a bunch of variables into the GdkRgbInfo
|
||||||
|
structure in preparation for per-colormap GdkRGB.
|
||||||
|
|
||||||
|
* gdk/x11/gdkimage-x11.c (gdk_image_new): Don't set gdk_use_xshm
|
||||||
|
to False when we get EINVAL from shmget so that the caller of
|
||||||
|
gdk_image_new can retry with a smaller segment size.
|
||||||
|
|
||||||
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
Mon Jun 26 13:01:16 BST 2000 Tony Gale <gale@gtk.org>
|
||||||
|
|
||||||
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
* docs/faq/gtk-faq.sgml: Add Sections 4 & 5.
|
||||||
|
272
gdk/gdkrgb.c
272
gdk/gdkrgb.c
@ -83,6 +83,24 @@ static const gchar* visual_names[] =
|
|||||||
"direct color",
|
"direct color",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define REGION_WIDTH 256
|
||||||
|
#define STAGE_ROWSTRIDE (REGION_WIDTH * 3)
|
||||||
|
#define REGION_HEIGHT 64
|
||||||
|
|
||||||
|
/* We have N_REGION REGION_WIDTH x REGION_HEIGHT regions divided
|
||||||
|
* up between n_images different images. possible_n_images gives
|
||||||
|
* various divisors of N_REGIONS. The reason for allowing this
|
||||||
|
* flexibility is that we want to create as few images as possible,
|
||||||
|
* but we want to deal with the abberant systems that have a SHMMAX
|
||||||
|
* limit less than
|
||||||
|
*
|
||||||
|
* REGION_WIDTH * REGION_HEIGHT * N_REGIONS * 4 (384k)
|
||||||
|
*
|
||||||
|
* (Are there any such?)
|
||||||
|
*/
|
||||||
|
#define N_REGIONS 6
|
||||||
|
static const int possible_n_images[] = { 1, 2, 3, 6 };
|
||||||
|
|
||||||
/* Some of these fields should go, as they're not being used at all.
|
/* Some of these fields should go, as they're not being used at all.
|
||||||
Globals should generally migrate into here - it's very likely that
|
Globals should generally migrate into here - it's very likely that
|
||||||
we'll want to run more than one GdkRgbInfo context at the same time
|
we'll want to run more than one GdkRgbInfo context at the same time
|
||||||
@ -94,10 +112,6 @@ struct _GdkRgbInfo
|
|||||||
GdkVisual *visual;
|
GdkVisual *visual;
|
||||||
GdkColormap *cmap;
|
GdkColormap *cmap;
|
||||||
|
|
||||||
gulong *color_pixels;
|
|
||||||
gulong *gray_pixels;
|
|
||||||
gulong *reserved_pixels;
|
|
||||||
|
|
||||||
guint nred_shades;
|
guint nred_shades;
|
||||||
guint ngreen_shades;
|
guint ngreen_shades;
|
||||||
guint nblue_shades;
|
guint nblue_shades;
|
||||||
@ -131,23 +145,42 @@ struct _GdkRgbInfo
|
|||||||
|
|
||||||
GdkRgbConvFunc conv_indexed;
|
GdkRgbConvFunc conv_indexed;
|
||||||
GdkRgbConvFunc conv_indexed_d;
|
GdkRgbConvFunc conv_indexed_d;
|
||||||
|
|
||||||
|
gint n_images;
|
||||||
|
GdkImage *static_image[N_REGIONS];
|
||||||
|
gint static_image_idx;
|
||||||
|
|
||||||
|
/* In order to optimize filling fractions, we simultaneously fill in up
|
||||||
|
* to three regions of size REGION_WIDTH * REGION_HEIGHT: one
|
||||||
|
* for images that are taller than REGION_HEIGHT / 2, and must
|
||||||
|
* be tiled horizontally. One for images that are wider than
|
||||||
|
* REGION_WIDTH / 2 and must be tiled vertically, and a third
|
||||||
|
* for images smaller than REGION_HEIGHT / 2 x REGION_WIDTH x 2
|
||||||
|
* that we tile in horizontal rows.
|
||||||
|
*/
|
||||||
|
gint horiz_idx;
|
||||||
|
gint horiz_y;
|
||||||
|
gint vert_idx;
|
||||||
|
gint vert_x;
|
||||||
|
|
||||||
|
/* tile_y1 and tile_y2 define the horizontal band into
|
||||||
|
* which we are tiling images. tile_x is the x extent to
|
||||||
|
* which that is filled
|
||||||
|
*/
|
||||||
|
gint tile_idx;
|
||||||
|
gint tile_x;
|
||||||
|
gint tile_y1;
|
||||||
|
gint tile_y2;
|
||||||
|
|
||||||
|
guchar *colorcube;
|
||||||
|
guchar *colorcube_d;
|
||||||
};
|
};
|
||||||
|
|
||||||
static gboolean gdk_rgb_install_cmap = FALSE;
|
static gboolean gdk_rgb_install_cmap = FALSE;
|
||||||
static gint gdk_rgb_min_colors = 5 * 5 * 5;
|
static gint gdk_rgb_min_colors = 5 * 5 * 5;
|
||||||
static gboolean gdk_rgb_verbose = FALSE;
|
static gboolean gdk_rgb_verbose = FALSE;
|
||||||
|
|
||||||
#define IMAGE_WIDTH 256
|
|
||||||
#define STAGE_ROWSTRIDE (IMAGE_WIDTH * 3)
|
|
||||||
#define IMAGE_HEIGHT 64
|
|
||||||
#define N_IMAGES 6
|
|
||||||
|
|
||||||
static GdkRgbInfo *image_info = NULL;
|
static GdkRgbInfo *image_info = NULL;
|
||||||
static GdkImage *static_image[N_IMAGES];
|
|
||||||
static gint static_image_idx;
|
|
||||||
|
|
||||||
static guchar *colorcube;
|
|
||||||
static guchar *colorcube_d;
|
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
gdk_rgb_cmap_fail (const char *msg, GdkColormap *cmap, gulong *pixels)
|
gdk_rgb_cmap_fail (const char *msg, GdkColormap *cmap, gulong *pixels)
|
||||||
@ -174,7 +207,7 @@ gdk_rgb_make_colorcube (gulong *pixels, gint nr, gint ng, gint nb)
|
|||||||
guchar rt[16], gt[16], bt[16];
|
guchar rt[16], gt[16], bt[16];
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
colorcube = g_new (guchar, 4096);
|
image_info->colorcube = g_new (guchar, 4096);
|
||||||
for (i = 0; i < 16; i++)
|
for (i = 0; i < 16; i++)
|
||||||
{
|
{
|
||||||
rt[i] = ng * nb * ((i * 17 * (nr - 1) + 128) >> 8);
|
rt[i] = ng * nb * ((i * 17 * (nr - 1) + 128) >> 8);
|
||||||
@ -184,9 +217,9 @@ gdk_rgb_make_colorcube (gulong *pixels, gint nr, gint ng, gint nb)
|
|||||||
|
|
||||||
for (i = 0; i < 4096; i++)
|
for (i = 0; i < 4096; i++)
|
||||||
{
|
{
|
||||||
colorcube[i] = pixels[rt[i >> 8] + gt[(i >> 4) & 0x0f] + bt[i & 0x0f]];
|
image_info->colorcube[i] = pixels[rt[i >> 8] + gt[(i >> 4) & 0x0f] + bt[i & 0x0f]];
|
||||||
#ifdef VERBOSE
|
#ifdef VERBOSE
|
||||||
g_print ("%03x %02x %x %x %x\n", i, colorcube[i], rt[i >> 8], gt[(i >> 4) & 0x0f], bt[i & 0x0f]);
|
g_print ("%03x %02x %x %x %x\n", i, image-info->colorcube[i], rt[i >> 8], gt[(i >> 4) & 0x0f], bt[i & 0x0f]);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -198,13 +231,13 @@ gdk_rgb_make_colorcube_d (gulong *pixels, gint nr, gint ng, gint nb)
|
|||||||
gint r, g, b;
|
gint r, g, b;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
colorcube_d = g_new (guchar, 512);
|
image_info->colorcube_d = g_new (guchar, 512);
|
||||||
for (i = 0; i < 512; i++)
|
for (i = 0; i < 512; i++)
|
||||||
{
|
{
|
||||||
r = MIN (nr - 1, i >> 6);
|
r = MIN (nr - 1, i >> 6);
|
||||||
g = MIN (ng - 1, (i >> 3) & 7);
|
g = MIN (ng - 1, (i >> 3) & 7);
|
||||||
b = MIN (nb - 1, i & 7);
|
b = MIN (nb - 1, i & 7);
|
||||||
colorcube_d[i] = pixels[(r * ng + g) * nb + b];
|
image_info->colorcube_d[i] = pixels[(r * ng + g) * nb + b];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -366,7 +399,7 @@ gdk_rgb_colorcube_222 (void)
|
|||||||
else
|
else
|
||||||
cmap = gdk_colormap_get_system ();
|
cmap = gdk_colormap_get_system ();
|
||||||
|
|
||||||
colorcube_d = g_new (guchar, 512);
|
image_info->colorcube_d = g_new (guchar, 512);
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
@ -374,7 +407,7 @@ gdk_rgb_colorcube_222 (void)
|
|||||||
color.green = ((i & 2) >> 1) * 65535;
|
color.green = ((i & 2) >> 1) * 65535;
|
||||||
color.blue = (i & 1) * 65535;
|
color.blue = (i & 1) * 65535;
|
||||||
gdk_color_alloc (cmap, &color);
|
gdk_color_alloc (cmap, &color);
|
||||||
colorcube_d[((i & 4) << 4) | ((i & 2) << 2) | (i & 1)] = color.pixel;
|
image_info->colorcube_d[((i & 4) << 4) | ((i & 2) << 2) | (i & 1)] = color.pixel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -536,7 +569,7 @@ gdk_rgb_set_gray_cmap (GdkColormap *cmap)
|
|||||||
/* Now, we make fake colorcubes - we ultimately just use the pseudocolor
|
/* Now, we make fake colorcubes - we ultimately just use the pseudocolor
|
||||||
methods. */
|
methods. */
|
||||||
|
|
||||||
colorcube = g_new (guchar, 4096);
|
image_info->colorcube = g_new (guchar, 4096);
|
||||||
|
|
||||||
for (i = 0; i < 4096; i++)
|
for (i = 0; i < 4096; i++)
|
||||||
{
|
{
|
||||||
@ -547,10 +580,41 @@ gdk_rgb_set_gray_cmap (GdkColormap *cmap)
|
|||||||
b = (i << 4 & 0xf0);
|
b = (i << 4 & 0xf0);
|
||||||
b = b | b >> 4;
|
b = b | b >> 4;
|
||||||
gray = (g + ((r + b) >> 1)) >> 1;
|
gray = (g + ((r + b) >> 1)) >> 1;
|
||||||
colorcube[i] = pixels[gray];
|
image_info->colorcube[i] = pixels[gray];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gdk_rgb_allocate_images (gint n_images, gboolean shared)
|
||||||
|
{
|
||||||
|
gint i;
|
||||||
|
|
||||||
|
for (i = 0; i < n_images; i++)
|
||||||
|
{
|
||||||
|
if (image_info->bitmap)
|
||||||
|
/* Use malloc() instead of g_malloc since X will free() this mem */
|
||||||
|
image_info->static_image[i] = gdk_image_new_bitmap (image_info->visual,
|
||||||
|
(gpointer) malloc (REGION_WIDTH * REGION_HEIGHT >> 3),
|
||||||
|
REGION_WIDTH * (N_REGIONS / n_images), REGION_HEIGHT);
|
||||||
|
else
|
||||||
|
image_info->static_image[i] = gdk_image_new (shared ? GDK_IMAGE_SHARED : GDK_IMAGE_NORMAL,
|
||||||
|
image_info->visual,
|
||||||
|
REGION_WIDTH * (N_REGIONS / n_images), REGION_HEIGHT);
|
||||||
|
|
||||||
|
if (!image_info->static_image[i])
|
||||||
|
{
|
||||||
|
gint j;
|
||||||
|
|
||||||
|
for (j = 0; j <= i; j++)
|
||||||
|
gdk_image_unref (image_info->static_image[i]);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gdk_rgb_init (void)
|
gdk_rgb_init (void)
|
||||||
{
|
{
|
||||||
@ -573,10 +637,6 @@ gdk_rgb_init (void)
|
|||||||
image_info->visual = NULL;
|
image_info->visual = NULL;
|
||||||
image_info->cmap = NULL;
|
image_info->cmap = NULL;
|
||||||
|
|
||||||
image_info->color_pixels = NULL;
|
|
||||||
image_info->gray_pixels = NULL;
|
|
||||||
image_info->reserved_pixels = NULL;
|
|
||||||
|
|
||||||
image_info->nred_shades = 6;
|
image_info->nred_shades = 6;
|
||||||
image_info->ngreen_shades = 6;
|
image_info->ngreen_shades = 6;
|
||||||
image_info->nblue_shades = 4;
|
image_info->nblue_shades = 4;
|
||||||
@ -647,21 +707,33 @@ gdk_rgb_init (void)
|
|||||||
|
|
||||||
image_info->bitmap = (image_info->visual->depth == 1);
|
image_info->bitmap = (image_info->visual->depth == 1);
|
||||||
|
|
||||||
for (i = 0; i < N_IMAGES; i++)
|
/* Try to allocate as few possible shared images */
|
||||||
if (image_info->bitmap)
|
for (i=0; i < G_N_ELEMENTS (possible_n_images); i++)
|
||||||
/* Use malloc() instead of g_malloc since X will free() this mem */
|
{
|
||||||
static_image[i] = gdk_image_new_bitmap (image_info->visual,
|
if (gdk_rgb_allocate_images (possible_n_images[i], TRUE))
|
||||||
(gpointer) malloc (IMAGE_WIDTH * IMAGE_HEIGHT >> 3),
|
{
|
||||||
IMAGE_WIDTH, IMAGE_HEIGHT);
|
image_info->n_images = possible_n_images[i];
|
||||||
else
|
break;
|
||||||
static_image[i] = gdk_image_new (GDK_IMAGE_FASTEST,
|
}
|
||||||
image_info->visual,
|
}
|
||||||
IMAGE_WIDTH, IMAGE_HEIGHT);
|
|
||||||
|
|
||||||
image_info->bpp = static_image[0]->bpp;
|
/* If that fails, just allocate N_REGIONS normal images */
|
||||||
|
if (i == G_N_ELEMENTS (possible_n_images))
|
||||||
|
{
|
||||||
|
gdk_rgb_allocate_images (N_REGIONS, FALSE);
|
||||||
|
image_info->n_images = N_REGIONS;
|
||||||
|
}
|
||||||
|
|
||||||
gdk_rgb_select_conv (static_image[0]);
|
image_info->bpp = image_info->static_image[0]->bpp;
|
||||||
|
|
||||||
|
image_info->static_image_idx = 0;
|
||||||
|
|
||||||
|
image_info->horiz_y = REGION_HEIGHT;
|
||||||
|
image_info->vert_x = REGION_WIDTH;
|
||||||
|
image_info->tile_x = REGION_WIDTH;
|
||||||
|
image_info->tile_y1 = image_info->tile_y2 = REGION_HEIGHT;
|
||||||
|
|
||||||
|
gdk_rgb_select_conv (image_info->static_image[0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -678,15 +750,15 @@ gdk_rgb_xpixel_from_rgb (guint32 rgb)
|
|||||||
(rgb & 0xff) > 510;
|
(rgb & 0xff) > 510;
|
||||||
}
|
}
|
||||||
else if (image_info->visual->type == GDK_VISUAL_PSEUDO_COLOR)
|
else if (image_info->visual->type == GDK_VISUAL_PSEUDO_COLOR)
|
||||||
pixel = colorcube[((rgb & 0xf00000) >> 12) |
|
pixel = image_info->colorcube[((rgb & 0xf00000) >> 12) |
|
||||||
((rgb & 0xf000) >> 8) |
|
((rgb & 0xf000) >> 8) |
|
||||||
((rgb & 0xf0) >> 4)];
|
((rgb & 0xf0) >> 4)];
|
||||||
else if (image_info->visual->depth < 8 &&
|
else if (image_info->visual->depth < 8 &&
|
||||||
image_info->visual->type == GDK_VISUAL_STATIC_COLOR)
|
image_info->visual->type == GDK_VISUAL_STATIC_COLOR)
|
||||||
{
|
{
|
||||||
pixel = colorcube_d[((rgb & 0x800000) >> 17) |
|
pixel = image_info->colorcube_d[((rgb & 0x800000) >> 17) |
|
||||||
((rgb & 0x8000) >> 12) |
|
((rgb & 0x8000) >> 12) |
|
||||||
((rgb & 0x80) >> 7)];
|
((rgb & 0x80) >> 7)];
|
||||||
}
|
}
|
||||||
else if (image_info->visual->type == GDK_VISUAL_TRUE_COLOR ||
|
else if (image_info->visual->type == GDK_VISUAL_TRUE_COLOR ||
|
||||||
image_info->visual->type == GDK_VISUAL_DIRECT_COLOR)
|
image_info->visual->type == GDK_VISUAL_DIRECT_COLOR)
|
||||||
@ -758,6 +830,7 @@ gdk_rgb_convert_8 (GdkImage *image,
|
|||||||
guchar *obuf, *obptr;
|
guchar *obuf, *obptr;
|
||||||
guchar *bptr, *bp2;
|
guchar *bptr, *bp2;
|
||||||
gint r, g, b;
|
gint r, g, b;
|
||||||
|
guchar *colorcube = image_info->colorcube;
|
||||||
|
|
||||||
bptr = buf;
|
bptr = buf;
|
||||||
bpl = image->bpl;
|
bpl = image->bpl;
|
||||||
@ -833,6 +906,7 @@ gdk_rgb_convert_8 (GdkImage *image,
|
|||||||
guchar *obuf, *obptr;
|
guchar *obuf, *obptr;
|
||||||
guchar *bptr, *bp2;
|
guchar *bptr, *bp2;
|
||||||
gint r, g, b;
|
gint r, g, b;
|
||||||
|
guchar *colorcube = image_info->colorcube;
|
||||||
|
|
||||||
bptr = buf;
|
bptr = buf;
|
||||||
bpl = image->bpl;
|
bpl = image->bpl;
|
||||||
@ -1050,6 +1124,7 @@ gdk_rgb_convert_8_d666 (GdkImage *image,
|
|||||||
gint r, g, b;
|
gint r, g, b;
|
||||||
const guchar *dmp;
|
const guchar *dmp;
|
||||||
gint dith;
|
gint dith;
|
||||||
|
guchar *colorcube_d = image_info->colorcube_d;
|
||||||
|
|
||||||
bptr = buf;
|
bptr = buf;
|
||||||
bpl = image->bpl;
|
bpl = image->bpl;
|
||||||
@ -1091,6 +1166,7 @@ gdk_rgb_convert_8_d (GdkImage *image,
|
|||||||
const guchar *dmp;
|
const guchar *dmp;
|
||||||
gint dith;
|
gint dith;
|
||||||
gint rs, gs, bs;
|
gint rs, gs, bs;
|
||||||
|
guchar *colorcube_d = image_info->colorcube_d;
|
||||||
|
|
||||||
bptr = buf;
|
bptr = buf;
|
||||||
bpl = image->bpl;
|
bpl = image->bpl;
|
||||||
@ -2208,7 +2284,8 @@ gdk_rgb_convert_4 (GdkImage *image,
|
|||||||
gint r, g, b;
|
gint r, g, b;
|
||||||
const guchar *dmp;
|
const guchar *dmp;
|
||||||
gint dith;
|
gint dith;
|
||||||
|
guchar *colorcube_d = image_info->colorcube_d;
|
||||||
|
|
||||||
bptr = buf;
|
bptr = buf;
|
||||||
bpl = image->bpl;
|
bpl = image->bpl;
|
||||||
obuf = ((guchar *)image->mem) + y0 * bpl + x0;
|
obuf = ((guchar *)image->mem) + y0 * bpl + x0;
|
||||||
@ -2467,7 +2544,7 @@ static guchar *
|
|||||||
gdk_rgb_ensure_stage (void)
|
gdk_rgb_ensure_stage (void)
|
||||||
{
|
{
|
||||||
if (image_info->stage_buf == NULL)
|
if (image_info->stage_buf == NULL)
|
||||||
image_info->stage_buf = g_malloc (IMAGE_HEIGHT * STAGE_ROWSTRIDE);
|
image_info->stage_buf = g_malloc (REGION_HEIGHT * STAGE_ROWSTRIDE);
|
||||||
return image_info->stage_buf;
|
return image_info->stage_buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2856,15 +2933,6 @@ gdk_rgb_select_conv (GdkImage *image)
|
|||||||
image_info->conv_indexed_d = conv_indexed_d;
|
image_info->conv_indexed_d = conv_indexed_d;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gint horiz_idx;
|
|
||||||
static gint horiz_y = IMAGE_HEIGHT;
|
|
||||||
static gint vert_idx;
|
|
||||||
static gint vert_x = IMAGE_WIDTH;
|
|
||||||
static gint tile_idx;
|
|
||||||
static gint tile_x = IMAGE_WIDTH;
|
|
||||||
static gint tile_y1 = IMAGE_HEIGHT;
|
|
||||||
static gint tile_y2 = IMAGE_HEIGHT;
|
|
||||||
|
|
||||||
#ifdef VERBOSE
|
#ifdef VERBOSE
|
||||||
static gint sincelast;
|
static gint sincelast;
|
||||||
#endif
|
#endif
|
||||||
@ -2877,7 +2945,7 @@ static gint sincelast;
|
|||||||
static gint
|
static gint
|
||||||
gdk_rgb_alloc_scratch_image (void)
|
gdk_rgb_alloc_scratch_image (void)
|
||||||
{
|
{
|
||||||
if (static_image_idx == N_IMAGES)
|
if (image_info->static_image_idx == N_REGIONS)
|
||||||
{
|
{
|
||||||
#ifndef NO_FLUSH
|
#ifndef NO_FLUSH
|
||||||
gdk_flush ();
|
gdk_flush ();
|
||||||
@ -2886,13 +2954,18 @@ gdk_rgb_alloc_scratch_image (void)
|
|||||||
g_print ("flush, %d puts since last flush\n", sincelast);
|
g_print ("flush, %d puts since last flush\n", sincelast);
|
||||||
sincelast = 0;
|
sincelast = 0;
|
||||||
#endif
|
#endif
|
||||||
static_image_idx = 0;
|
image_info->static_image_idx = 0;
|
||||||
horiz_y = IMAGE_HEIGHT;
|
|
||||||
vert_x = IMAGE_WIDTH;
|
/* Mark all regions that we might be filling in as completely
|
||||||
tile_x = IMAGE_WIDTH;
|
* full, to force new tiles to be allocated for subsequent
|
||||||
tile_y1 = tile_y2 = IMAGE_HEIGHT;
|
* images
|
||||||
|
*/
|
||||||
|
image_info->horiz_y = REGION_HEIGHT;
|
||||||
|
image_info->vert_x = REGION_WIDTH;
|
||||||
|
image_info->tile_x = REGION_WIDTH;
|
||||||
|
image_info->tile_y1 = image_info->tile_y2 = REGION_HEIGHT;
|
||||||
}
|
}
|
||||||
return static_image_idx++;
|
return image_info->static_image_idx++;
|
||||||
}
|
}
|
||||||
|
|
||||||
static GdkImage *
|
static GdkImage *
|
||||||
@ -2901,9 +2974,9 @@ gdk_rgb_alloc_scratch (gint width, gint height, gint *x0, gint *y0)
|
|||||||
GdkImage *image;
|
GdkImage *image;
|
||||||
gint idx;
|
gint idx;
|
||||||
|
|
||||||
if (width >= (IMAGE_WIDTH >> 1))
|
if (width >= (REGION_WIDTH >> 1))
|
||||||
{
|
{
|
||||||
if (height >= (IMAGE_HEIGHT >> 1))
|
if (height >= (REGION_HEIGHT >> 1))
|
||||||
{
|
{
|
||||||
idx = gdk_rgb_alloc_scratch_image ();
|
idx = gdk_rgb_alloc_scratch_image ();
|
||||||
*x0 = 0;
|
*x0 = 0;
|
||||||
@ -2911,56 +2984,57 @@ gdk_rgb_alloc_scratch (gint width, gint height, gint *x0, gint *y0)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (height + horiz_y > IMAGE_HEIGHT)
|
if (height + image_info->horiz_y > REGION_HEIGHT)
|
||||||
{
|
{
|
||||||
horiz_idx = gdk_rgb_alloc_scratch_image ();
|
image_info->horiz_idx = gdk_rgb_alloc_scratch_image ();
|
||||||
horiz_y = 0;
|
image_info->horiz_y = 0;
|
||||||
}
|
}
|
||||||
idx = horiz_idx;
|
idx = image_info->horiz_idx;
|
||||||
*x0 = 0;
|
*x0 = 0;
|
||||||
*y0 = horiz_y;
|
*y0 = image_info->horiz_y;
|
||||||
horiz_y += height;
|
image_info->horiz_y += height;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (height >= (IMAGE_HEIGHT >> 1))
|
if (height >= (REGION_HEIGHT >> 1))
|
||||||
{
|
{
|
||||||
if (width + vert_x > IMAGE_WIDTH)
|
if (width + image_info->vert_x > REGION_WIDTH)
|
||||||
{
|
{
|
||||||
vert_idx = gdk_rgb_alloc_scratch_image ();
|
image_info->vert_idx = gdk_rgb_alloc_scratch_image ();
|
||||||
vert_x = 0;
|
image_info->vert_x = 0;
|
||||||
}
|
}
|
||||||
idx = vert_idx;
|
idx = image_info->vert_idx;
|
||||||
*x0 = vert_x;
|
*x0 = image_info->vert_x;
|
||||||
*y0 = 0;
|
*y0 = 0;
|
||||||
/* using 3 and -4 would be slightly more efficient on 32-bit machines
|
/* using 3 and -4 would be slightly more efficient on 32-bit machines
|
||||||
with > 1bpp displays */
|
with > 1bpp displays */
|
||||||
vert_x += (width + 7) & -8;
|
image_info->vert_x += (width + 7) & -8;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (width + tile_x > IMAGE_WIDTH)
|
if (width + image_info->tile_x > REGION_WIDTH)
|
||||||
{
|
{
|
||||||
tile_y1 = tile_y2;
|
image_info->tile_y1 = image_info->tile_y2;
|
||||||
tile_x = 0;
|
image_info->tile_x = 0;
|
||||||
}
|
}
|
||||||
if (height + tile_y1 > IMAGE_HEIGHT)
|
if (height + image_info->tile_y1 > REGION_HEIGHT)
|
||||||
{
|
{
|
||||||
tile_idx = gdk_rgb_alloc_scratch_image ();
|
image_info->tile_idx = gdk_rgb_alloc_scratch_image ();
|
||||||
tile_x = 0;
|
image_info->tile_x = 0;
|
||||||
tile_y1 = 0;
|
image_info->tile_y1 = 0;
|
||||||
tile_y2 = 0;
|
image_info->tile_y2 = 0;
|
||||||
}
|
}
|
||||||
if (height + tile_y1 > tile_y2)
|
if (height + image_info->tile_y1 > image_info->tile_y2)
|
||||||
tile_y2 = height + tile_y1;
|
image_info->tile_y2 = height + image_info->tile_y1;
|
||||||
idx = tile_idx;
|
idx = image_info->tile_idx;
|
||||||
*x0 = tile_x;
|
*x0 = image_info->tile_x;
|
||||||
*y0 = tile_y1;
|
*y0 = image_info->tile_y1;
|
||||||
tile_x += (width + 7) & -8;
|
image_info->tile_x += (width + 7) & -8;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
image = static_image[idx];
|
image = image_info->static_image[idx * image_info->n_images / N_REGIONS];
|
||||||
|
*x0 += REGION_WIDTH * (idx % (N_REGIONS / image_info->n_images));
|
||||||
#ifdef VERBOSE
|
#ifdef VERBOSE
|
||||||
g_print ("index %d, x %d, y %d (%d x %d)\n", idx, *x0, *y0, width, height);
|
g_print ("index %d, x %d, y %d (%d x %d)\n", idx, *x0, *y0, width, height);
|
||||||
sincelast++;
|
sincelast++;
|
||||||
@ -3003,12 +3077,12 @@ gdk_draw_rgb_image_core (GdkDrawable *drawable,
|
|||||||
}
|
}
|
||||||
gc = image_info->own_gc;
|
gc = image_info->own_gc;
|
||||||
}
|
}
|
||||||
for (y0 = 0; y0 < height; y0 += IMAGE_HEIGHT)
|
for (y0 = 0; y0 < height; y0 += REGION_HEIGHT)
|
||||||
{
|
{
|
||||||
height1 = MIN (height - y0, IMAGE_HEIGHT);
|
height1 = MIN (height - y0, REGION_HEIGHT);
|
||||||
for (x0 = 0; x0 < width; x0 += IMAGE_WIDTH)
|
for (x0 = 0; x0 < width; x0 += REGION_WIDTH)
|
||||||
{
|
{
|
||||||
width1 = MIN (width - x0, IMAGE_WIDTH);
|
width1 = MIN (width - x0, REGION_WIDTH);
|
||||||
buf_ptr = buf + y0 * rowstride + x0 * pixstride;
|
buf_ptr = buf + y0 * rowstride + x0 * pixstride;
|
||||||
|
|
||||||
image = gdk_rgb_alloc_scratch (width1, height1, &xs0, &ys0);
|
image = gdk_rgb_alloc_scratch (width1, height1, &xs0, &ys0);
|
||||||
@ -3153,9 +3227,9 @@ gdk_rgb_cmap_new (guint32 *colors, gint n_colors)
|
|||||||
((rgb & 0xf000) >> 8) |
|
((rgb & 0xf000) >> 8) |
|
||||||
((rgb & 0xf0) >> 4);
|
((rgb & 0xf0) >> 4);
|
||||||
#ifdef VERBOSE
|
#ifdef VERBOSE
|
||||||
g_print ("%d %x %x %d\n", i, j, colorcube[j]);
|
g_print ("%d %x %x %d\n", i, j, image_info->colorcube[j]);
|
||||||
#endif
|
#endif
|
||||||
cmap->lut[i] = colorcube[j];
|
cmap->lut[i] = image_info->colorcube[j];
|
||||||
}
|
}
|
||||||
return cmap;
|
return cmap;
|
||||||
}
|
}
|
||||||
|
@ -53,6 +53,8 @@
|
|||||||
#include <X11/extensions/XShm.h>
|
#include <X11/extensions/XShm.h>
|
||||||
#endif /* USE_SHM */
|
#endif /* USE_SHM */
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#include "gdk.h" /* For gdk_error_trap_* / gdk_flush_* */
|
#include "gdk.h" /* For gdk_error_trap_* / gdk_flush_* */
|
||||||
#include "gdkimage.h"
|
#include "gdkimage.h"
|
||||||
#include "gdkprivate.h"
|
#include "gdkprivate.h"
|
||||||
@ -142,28 +144,28 @@ gdk_image_new_bitmap(GdkVisual *visual, gpointer data, gint w, gint h)
|
|||||||
* Desc: create a new bitmap image
|
* Desc: create a new bitmap image
|
||||||
*/
|
*/
|
||||||
{
|
{
|
||||||
Visual *xvisual;
|
Visual *xvisual;
|
||||||
GdkImage *image;
|
GdkImage *image;
|
||||||
GdkImagePrivateX11 *private;
|
GdkImagePrivateX11 *private;
|
||||||
image = GDK_IMAGE (g_type_create_instance (gdk_image_get_type ()));
|
image = GDK_IMAGE (g_type_create_instance (gdk_image_get_type ()));
|
||||||
private = PRIVATE_DATA (image);
|
private = PRIVATE_DATA (image);
|
||||||
private->xdisplay = gdk_display;
|
private->xdisplay = gdk_display;
|
||||||
image->type = GDK_IMAGE_NORMAL;
|
image->type = GDK_IMAGE_NORMAL;
|
||||||
image->visual = visual;
|
image->visual = visual;
|
||||||
image->width = w;
|
image->width = w;
|
||||||
image->height = h;
|
image->height = h;
|
||||||
image->depth = 1;
|
image->depth = 1;
|
||||||
xvisual = ((GdkVisualPrivate*) visual)->xvisual;
|
xvisual = ((GdkVisualPrivate*) visual)->xvisual;
|
||||||
private->ximage = XCreateImage(private->xdisplay, xvisual, 1, XYBitmap,
|
private->ximage = XCreateImage(private->xdisplay, xvisual, 1, XYBitmap,
|
||||||
0, 0, w ,h, 8, 0);
|
0, 0, w ,h, 8, 0);
|
||||||
private->ximage->data = data;
|
private->ximage->data = data;
|
||||||
private->ximage->bitmap_bit_order = MSBFirst;
|
private->ximage->bitmap_bit_order = MSBFirst;
|
||||||
private->ximage->byte_order = MSBFirst;
|
private->ximage->byte_order = MSBFirst;
|
||||||
image->byte_order = MSBFirst;
|
image->byte_order = MSBFirst;
|
||||||
image->mem = private->ximage->data;
|
image->mem = private->ximage->data;
|
||||||
image->bpl = private->ximage->bytes_per_line;
|
image->bpl = private->ximage->bytes_per_line;
|
||||||
image->bpp = 1;
|
image->bpp = 1;
|
||||||
return(image);
|
return(image);
|
||||||
} /* gdk_image_new_bitmap() */
|
} /* gdk_image_new_bitmap() */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -265,13 +267,21 @@ gdk_image_new (GdkImageType type,
|
|||||||
|
|
||||||
if (x_shm_info->shmid == -1)
|
if (x_shm_info->shmid == -1)
|
||||||
{
|
{
|
||||||
g_warning ("shmget failed!");
|
/* EINVAL indicates, most likely, that the segment we asked for
|
||||||
|
* is bigger than SHMMAX, so we don't treat it as a permanently
|
||||||
|
* fatal error. ENOSPC and ENOMEM may also indicate this, but
|
||||||
|
* more likely are permanent errors.
|
||||||
|
*/
|
||||||
|
if (errno != EINVAL)
|
||||||
|
{
|
||||||
|
g_warning ("shmget failed!");
|
||||||
|
gdk_use_xshm = False;
|
||||||
|
}
|
||||||
|
|
||||||
XDestroyImage (private->ximage);
|
XDestroyImage (private->ximage);
|
||||||
g_free (private->x_shm_info);
|
g_free (private->x_shm_info);
|
||||||
g_free (image);
|
g_free (image);
|
||||||
|
|
||||||
gdk_use_xshm = False;
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user