mirror of
https://github.com/gnustep/libs-back.git
synced 2025-05-30 17:00:52 +00:00
Clean up and better error check and reporting on cairo and malloc calls.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/back/trunk@26391 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
1742579fbf
commit
19dda8e5a7
7 changed files with 196 additions and 119 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2008-03-29 Fred Kiefer <FredKiefer@gmx.de>
|
||||||
|
|
||||||
|
* Source/cairo/CairoFontEnumerator.m,
|
||||||
|
* Source/cairo/CairoFaceInfo.m,
|
||||||
|
* Source/cairo/Win32CairoSurface.m,
|
||||||
|
* Source/cairo/CairoFontInfo.m,
|
||||||
|
* Source/cairo/Win32CairoGlitzSurface.m,
|
||||||
|
* Source/cairo/CairoGState.m:
|
||||||
|
Clean up and better error check and reporting on cairo and malloc calls.
|
||||||
|
|
||||||
2008-03-19 Adam Fedor <fedor@gnu.org>
|
2008-03-19 Adam Fedor <fedor@gnu.org>
|
||||||
|
|
||||||
* Version 0.13.2
|
* Version 0.13.2
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include <cairo-ft.h>
|
#include <cairo-ft.h>
|
||||||
#include <AppKit/NSFontManager.h>
|
#include <AppKit/NSFontManager.h>
|
||||||
|
|
||||||
@ implementation CairoFaceInfo
|
@implementation CairoFaceInfo
|
||||||
|
|
||||||
- (id) initWithfamilyName: (NSString *)familyName
|
- (id) initWithfamilyName: (NSString *)familyName
|
||||||
weight: (int)weight
|
weight: (int)weight
|
||||||
|
@ -103,21 +103,20 @@
|
||||||
FcResult result;
|
FcResult result;
|
||||||
FcPattern *resolved;
|
FcPattern *resolved;
|
||||||
|
|
||||||
FcConfigSubstitute (NULL, _pattern, FcMatchPattern);
|
FcConfigSubstitute(NULL, _pattern, FcMatchPattern);
|
||||||
FcDefaultSubstitute(_pattern);
|
FcDefaultSubstitute(_pattern);
|
||||||
resolved = FcFontMatch(NULL, _pattern, &result);
|
resolved = FcFontMatch(NULL, _pattern, &result);
|
||||||
|
|
||||||
_fontFace = cairo_ft_font_face_create_for_pattern(resolved);
|
_fontFace = cairo_ft_font_face_create_for_pattern(resolved);
|
||||||
FcPatternDestroy(resolved);
|
FcPatternDestroy(resolved);
|
||||||
|
|
||||||
if ((!_fontFace)
|
if (cairo_font_face_status(_fontFace) != CAIRO_STATUS_SUCCESS)
|
||||||
|| (cairo_font_face_status(_fontFace) != CAIRO_STATUS_SUCCESS))
|
{
|
||||||
{
|
NSLog(@"Creating a font face failed %@", _familyName);
|
||||||
NSLog(@"Creating a font face failed %@", _familyName);
|
cairo_font_face_destroy(_fontFace);
|
||||||
cairo_font_face_destroy(_fontFace);
|
_fontFace = NULL;
|
||||||
_fontFace = NULL;
|
return NULL;
|
||||||
return NULL;
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return _fontFace;
|
return _fontFace;
|
||||||
|
|
|
@ -62,7 +62,7 @@ NSMutableDictionary * __allFonts;
|
||||||
return face;
|
return face;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make a GNUStep style font descriptor from a FcPattern
|
// Make a GNUstep style font descriptor from a FcPattern
|
||||||
static NSArray *faFromFc(FcPattern *pat)
|
static NSArray *faFromFc(FcPattern *pat)
|
||||||
{
|
{
|
||||||
int weight, slant, spacing, nsweight;
|
int weight, slant, spacing, nsweight;
|
||||||
|
@ -87,42 +87,42 @@ static NSArray *faFromFc(FcPattern *pat)
|
||||||
switch (weight)
|
switch (weight)
|
||||||
{
|
{
|
||||||
case FC_WEIGHT_LIGHT:
|
case FC_WEIGHT_LIGHT:
|
||||||
[style appendString: @"Light"];
|
[style appendString: @"Light"];
|
||||||
nsweight = 3;
|
nsweight = 3;
|
||||||
break;
|
break;
|
||||||
case FC_WEIGHT_MEDIUM:
|
case FC_WEIGHT_MEDIUM:
|
||||||
nsweight = 6;
|
nsweight = 6;
|
||||||
break;
|
break;
|
||||||
case FC_WEIGHT_DEMIBOLD:
|
case FC_WEIGHT_DEMIBOLD:
|
||||||
[style appendString: @"Demibold"];
|
[style appendString: @"Demibold"];
|
||||||
nsweight = 7;
|
nsweight = 7;
|
||||||
break;
|
break;
|
||||||
case FC_WEIGHT_BOLD:
|
case FC_WEIGHT_BOLD:
|
||||||
[style appendString: @"Bold"];
|
[style appendString: @"Bold"];
|
||||||
nsweight = 9;
|
nsweight = 9;
|
||||||
nstraits |= NSBoldFontMask;
|
nstraits |= NSBoldFontMask;
|
||||||
break;
|
break;
|
||||||
case FC_WEIGHT_BLACK:
|
case FC_WEIGHT_BLACK:
|
||||||
[style appendString: @"Black"];
|
[style appendString: @"Black"];
|
||||||
nsweight = 12;
|
nsweight = 12;
|
||||||
nstraits |= NSBoldFontMask;
|
nstraits |= NSBoldFontMask;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
nsweight = 6;
|
nsweight = 6;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (slant)
|
switch (slant)
|
||||||
{
|
{
|
||||||
case FC_SLANT_ROMAN:
|
case FC_SLANT_ROMAN:
|
||||||
break;
|
break;
|
||||||
case FC_SLANT_ITALIC:
|
case FC_SLANT_ITALIC:
|
||||||
[style appendString: @"Italic"];
|
[style appendString: @"Italic"];
|
||||||
nstraits |= NSItalicFontMask;
|
nstraits |= NSItalicFontMask;
|
||||||
break;
|
break;
|
||||||
case FC_SLANT_OBLIQUE:
|
case FC_SLANT_OBLIQUE:
|
||||||
[style appendString: @"Oblique"];
|
[style appendString: @"Oblique"];
|
||||||
nstraits |= NSItalicFontMask;
|
nstraits |= NSItalicFontMask;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ([style length] > 0)
|
if ([style length] > 0)
|
||||||
|
@ -161,7 +161,7 @@ static NSArray *faFromFc(FcPattern *pat)
|
||||||
char *family;
|
char *family;
|
||||||
|
|
||||||
if (FcPatternGetString(fs->fonts[i], FC_FAMILY, 0, (FcChar8 **)&family)
|
if (FcPatternGetString(fs->fonts[i], FC_FAMILY, 0, (FcChar8 **)&family)
|
||||||
== FcResultMatch)
|
== FcResultMatch)
|
||||||
{
|
{
|
||||||
NSArray *fontArray;
|
NSArray *fontArray;
|
||||||
|
|
||||||
|
@ -176,19 +176,19 @@ static NSArray *faFromFc(FcPattern *pat)
|
||||||
familyArray = [fcxft_allFontFamilies objectForKey: familyString];
|
familyArray = [fcxft_allFontFamilies objectForKey: familyString];
|
||||||
if (familyArray == nil)
|
if (familyArray == nil)
|
||||||
{
|
{
|
||||||
NSDebugLog(@"Found font family %@", familyString);
|
NSDebugLog(@"Found font family %@", familyString);
|
||||||
familyArray = [[NSMutableArray alloc] init];
|
familyArray = [[NSMutableArray alloc] init];
|
||||||
[fcxft_allFontFamilies setObject: familyArray
|
[fcxft_allFontFamilies setObject: familyArray
|
||||||
forKey: familyString];
|
forKey: familyString];
|
||||||
RELEASE(familyArray);
|
RELEASE(familyArray);
|
||||||
}
|
}
|
||||||
NSDebugLog(@"fc enumerator: adding font: %@", name);
|
NSDebugLog(@"fc enumerator: adding font: %@", name);
|
||||||
[familyArray addObject: fontArray];
|
[familyArray addObject: fontArray];
|
||||||
[fcxft_allFontNames addObject: name];
|
[fcxft_allFontNames addObject: name];
|
||||||
aFont = [[CairoFaceInfo alloc] initWithfamilyName: familyString
|
aFont = [[CairoFaceInfo alloc] initWithfamilyName: familyString
|
||||||
weight: [[fontArray objectAtIndex: 2] intValue]
|
weight: [[fontArray objectAtIndex: 2] intValue]
|
||||||
traits: [[fontArray objectAtIndex: 3] unsignedIntValue]
|
traits: [[fontArray objectAtIndex: 3] unsignedIntValue]
|
||||||
pattern: fs->fonts[i]];
|
pattern: fs->fonts[i]];
|
||||||
[fcxft_allFonts setObject: aFont forKey: name];
|
[fcxft_allFonts setObject: aFont forKey: name];
|
||||||
RELEASE(aFont);
|
RELEASE(aFont);
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,16 +42,22 @@
|
||||||
_cacheSize = size;
|
_cacheSize = size;
|
||||||
if (_cachedSizes)
|
if (_cachedSizes)
|
||||||
{
|
{
|
||||||
free(_cachedSizes);
|
objc_free(_cachedSizes);
|
||||||
}
|
}
|
||||||
if (_cachedGlyphs)
|
if (_cachedGlyphs)
|
||||||
{
|
{
|
||||||
free(_cachedGlyphs);
|
objc_free(_cachedGlyphs);
|
||||||
|
}
|
||||||
|
_cachedSizes = objc_malloc(sizeof(NSSize) * size);
|
||||||
|
if (_cachedSizes)
|
||||||
|
{
|
||||||
|
memset(_cachedSizes, 0, sizeof(NSSize) * size);
|
||||||
|
}
|
||||||
|
_cachedGlyphs = objc_malloc(sizeof(unsigned int) * size);
|
||||||
|
if (_cachedGlyphs)
|
||||||
|
{
|
||||||
|
memset(_cachedGlyphs, 0, sizeof(unsigned int) * size);
|
||||||
}
|
}
|
||||||
_cachedSizes = malloc(sizeof(NSSize) * size);
|
|
||||||
memset(_cachedSizes, 0, sizeof(NSSize) * size);
|
|
||||||
_cachedGlyphs = malloc(sizeof(unsigned int) * size);
|
|
||||||
memset(_cachedGlyphs, 0, sizeof(unsigned int) * size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL) setupAttributes
|
- (BOOL) setupAttributes
|
||||||
|
@ -62,16 +68,13 @@
|
||||||
cairo_matrix_t ctm;
|
cairo_matrix_t ctm;
|
||||||
cairo_font_options_t *options;
|
cairo_font_options_t *options;
|
||||||
|
|
||||||
/* do not forget to check for font specific
|
|
||||||
* cache size from face info FIXME FIXME
|
|
||||||
*/
|
|
||||||
ASSIGN(_faceInfo, [CairoFontEnumerator fontWithName: fontName]);
|
ASSIGN(_faceInfo, [CairoFontEnumerator fontWithName: fontName]);
|
||||||
if (!_faceInfo)
|
if (!_faceInfo)
|
||||||
{
|
{
|
||||||
return NO;
|
return NO;
|
||||||
}
|
}
|
||||||
|
|
||||||
_cachedSizes = NULL;
|
// check for font specific cache size from face info
|
||||||
[self setCacheSize: [_faceInfo cacheSize]];
|
[self setCacheSize: [_faceInfo cacheSize]];
|
||||||
|
|
||||||
/* setting GSFontInfo:
|
/* setting GSFontInfo:
|
||||||
|
@ -91,6 +94,7 @@
|
||||||
cairo_matrix_init(&font_matrix, matrix[0], matrix[1], matrix[2],
|
cairo_matrix_init(&font_matrix, matrix[0], matrix[1], matrix[2],
|
||||||
matrix[3], matrix[4], matrix[5]);
|
matrix[3], matrix[4], matrix[5]);
|
||||||
cairo_matrix_init_identity(&ctm);
|
cairo_matrix_init_identity(&ctm);
|
||||||
|
|
||||||
// FIXME: Should get default font options from somewhere
|
// FIXME: Should get default font options from somewhere
|
||||||
options = cairo_font_options_create();
|
options = cairo_font_options_create();
|
||||||
face = [_faceInfo fontFace];
|
face = [_faceInfo fontFace];
|
||||||
|
@ -98,6 +102,7 @@
|
||||||
{
|
{
|
||||||
return NO;
|
return NO;
|
||||||
}
|
}
|
||||||
|
|
||||||
_scaled = cairo_scaled_font_create(face, &font_matrix, &ctm, options);
|
_scaled = cairo_scaled_font_create(face, &font_matrix, &ctm, options);
|
||||||
cairo_font_options_destroy(options);
|
cairo_font_options_destroy(options);
|
||||||
if (!_scaled)
|
if (!_scaled)
|
||||||
|
@ -122,8 +127,9 @@
|
||||||
matrix: (const float *)fmatrix
|
matrix: (const float *)fmatrix
|
||||||
screenFont: (BOOL)p_screenFont
|
screenFont: (BOOL)p_screenFont
|
||||||
{
|
{
|
||||||
//NSLog(@"initWithFontName %@",name);
|
self = [super init];
|
||||||
[super init];
|
if (!self)
|
||||||
|
return nil;
|
||||||
|
|
||||||
_screenFont = p_screenFont;
|
_screenFont = p_screenFont;
|
||||||
fontName = [name copy];
|
fontName = [name copy];
|
||||||
|
@ -155,8 +161,10 @@
|
||||||
{
|
{
|
||||||
cairo_scaled_font_destroy(_scaled);
|
cairo_scaled_font_destroy(_scaled);
|
||||||
}
|
}
|
||||||
free(_cachedSizes);
|
if (_cachedSizes)
|
||||||
free(_cachedGlyphs);
|
objc_free(_cachedSizes);
|
||||||
|
if (_cachedGlyphs)
|
||||||
|
objc_free(_cachedGlyphs);
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,21 +208,30 @@ BOOL _cairo_extents_for_NSGlyph(cairo_scaled_font_t *scaled_font, NSGlyph glyph,
|
||||||
- (NSSize) advancementForGlyph: (NSGlyph)glyph
|
- (NSSize) advancementForGlyph: (NSGlyph)glyph
|
||||||
{
|
{
|
||||||
cairo_text_extents_t ctext;
|
cairo_text_extents_t ctext;
|
||||||
int entry;
|
|
||||||
|
|
||||||
entry = glyph % _cacheSize;
|
if (_cachedSizes)
|
||||||
|
|
||||||
if (_cachedGlyphs[entry] == glyph)
|
|
||||||
{
|
{
|
||||||
return _cachedSizes[entry];
|
int entry = glyph % _cacheSize;
|
||||||
|
|
||||||
|
if (_cachedGlyphs[entry] == glyph)
|
||||||
|
{
|
||||||
|
return _cachedSizes[entry];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_cairo_extents_for_NSGlyph(_scaled, glyph, &ctext))
|
||||||
|
{
|
||||||
|
_cachedGlyphs[entry] = glyph;
|
||||||
|
_cachedSizes[entry] = NSMakeSize(ctext.x_advance, ctext.y_advance);
|
||||||
|
|
||||||
|
return _cachedSizes[entry];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
if (_cairo_extents_for_NSGlyph(_scaled, glyph, &ctext))
|
|
||||||
{
|
{
|
||||||
_cachedGlyphs[entry] = glyph;
|
if (_cairo_extents_for_NSGlyph(_scaled, glyph, &ctext))
|
||||||
_cachedSizes[entry] = NSMakeSize(ctext.x_advance, ctext.y_advance);
|
{
|
||||||
|
return NSMakeSize(ctext.x_advance, ctext.y_advance);
|
||||||
return _cachedSizes[entry];
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return NSZeroSize;
|
return NSZeroSize;
|
||||||
|
@ -294,24 +311,60 @@ BOOL _cairo_extents_for_NSGlyph(cairo_scaled_font_t *scaled_font, NSGlyph glyph,
|
||||||
}
|
}
|
||||||
|
|
||||||
cdata = objc_malloc(sizeof(char) * 4 * ix * iy);
|
cdata = objc_malloc(sizeof(char) * 4 * ix * iy);
|
||||||
|
if (!cdata)
|
||||||
|
{
|
||||||
|
NSLog(@"Could not allocate drawing space for glyphs");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
isurface = cairo_image_surface_create_for_data(cdata, format, ix, iy, 4*ix);
|
isurface = cairo_image_surface_create_for_data(cdata, format, ix, iy, 4*ix);
|
||||||
status = cairo_surface_status(isurface);
|
status = cairo_surface_status(isurface);
|
||||||
if (status != CAIRO_STATUS_SUCCESS)
|
if (status != CAIRO_STATUS_SUCCESS)
|
||||||
{
|
{
|
||||||
|
NSLog(@"Error while creating surface: %s",
|
||||||
|
cairo_status_to_string(status));
|
||||||
cairo_surface_destroy(isurface);
|
cairo_surface_destroy(isurface);
|
||||||
objc_free(cdata);
|
objc_free(cdata);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ct = cairo_create(isurface);
|
ct = cairo_create(isurface);
|
||||||
|
if (cairo_status(ct) != CAIRO_STATUS_SUCCESS)
|
||||||
|
{
|
||||||
|
NSLog(@"Error while creating context: %s",
|
||||||
|
cairo_status_to_string(cairo_status(ct)));
|
||||||
|
cairo_destroy(ct);
|
||||||
|
cairo_surface_destroy(isurface);
|
||||||
|
objc_free(cdata);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cairo_matrix_init(&font_matrix, matrix[0], matrix[1], matrix[2],
|
cairo_matrix_init(&font_matrix, matrix[0], matrix[1], matrix[2],
|
||||||
matrix[3], matrix[4], matrix[5]);
|
matrix[3], matrix[4], matrix[5]);
|
||||||
cairo_set_font_matrix(ct, &font_matrix);
|
cairo_set_font_matrix(ct, &font_matrix);
|
||||||
|
if (cairo_status(ct) != CAIRO_STATUS_SUCCESS)
|
||||||
|
{
|
||||||
|
NSLog(@"Error while setting font matrix: %s",
|
||||||
|
cairo_status_to_string(cairo_status(ct)));
|
||||||
|
cairo_destroy(ct);
|
||||||
|
cairo_surface_destroy(isurface);
|
||||||
|
objc_free(cdata);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
cairo_set_font_face(ct, [_faceInfo fontFace]);
|
||||||
|
if (cairo_status(ct) != CAIRO_STATUS_SUCCESS)
|
||||||
|
{
|
||||||
|
NSLog(@"Error while setting font face: %s",
|
||||||
|
cairo_status_to_string(cairo_status(ct)));
|
||||||
|
cairo_destroy(ct);
|
||||||
|
cairo_surface_destroy(isurface);
|
||||||
|
objc_free(cdata);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cairo_text_path(ct, str);
|
cairo_text_path(ct, str);
|
||||||
status = cairo_status(ct);
|
if (cairo_status(ct) == CAIRO_STATUS_SUCCESS)
|
||||||
if (status == CAIRO_STATUS_SUCCESS)
|
|
||||||
{
|
{
|
||||||
cairo_path_t *cpath;
|
cairo_path_t *cpath;
|
||||||
cairo_path_data_t *data;
|
cairo_path_data_t *data;
|
||||||
|
@ -381,6 +434,7 @@ BOOL _cairo_extents_for_NSGlyph(cairo_scaled_font_t *scaled_font, NSGlyph glyph,
|
||||||
cairo_status_to_string(cairo_status(ct)));
|
cairo_status_to_string(cairo_status(ct)));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
cairo_set_font_face(ct, [_faceInfo fontFace]);
|
cairo_set_font_face(ct, [_faceInfo fontFace]);
|
||||||
if (cairo_status(ct) != CAIRO_STATUS_SUCCESS)
|
if (cairo_status(ct) != CAIRO_STATUS_SUCCESS)
|
||||||
{
|
{
|
||||||
|
|
|
@ -135,7 +135,7 @@ static float floatToUserSpace(NSAffineTransform *ctm, float f)
|
||||||
if (status != CAIRO_STATUS_SUCCESS)
|
if (status != CAIRO_STATUS_SUCCESS)
|
||||||
{
|
{
|
||||||
NSLog(@"Cairo status '%s' in copy", cairo_status_to_string(status));
|
NSLog(@"Cairo status '%s' in copy", cairo_status_to_string(status));
|
||||||
_ct = NULL;
|
copy->_ct = NULL;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -999,8 +999,14 @@ _set_op(cairo_t *ct, NSCompositingOperation op)
|
||||||
switch (bitsPerPixel)
|
switch (bitsPerPixel)
|
||||||
{
|
{
|
||||||
case 32:
|
case 32:
|
||||||
rowData = (unsigned char *)data[0];
|
|
||||||
tmp = objc_malloc(pixels * 4);
|
tmp = objc_malloc(pixels * 4);
|
||||||
|
if (!tmp)
|
||||||
|
{
|
||||||
|
NSLog(@"Could not allocate drawing space for image");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
rowData = (unsigned char *)data[0];
|
||||||
index = 0;
|
index = 0;
|
||||||
|
|
||||||
for (i = 0; i < pixelsHigh; i++)
|
for (i = 0; i < pixelsHigh; i++)
|
||||||
|
@ -1027,8 +1033,14 @@ _set_op(cairo_t *ct, NSCompositingOperation op)
|
||||||
format = CAIRO_FORMAT_ARGB32;
|
format = CAIRO_FORMAT_ARGB32;
|
||||||
break;
|
break;
|
||||||
case 24:
|
case 24:
|
||||||
rowData = (unsigned char *)data[0];
|
|
||||||
tmp = objc_malloc(pixels * 4);
|
tmp = objc_malloc(pixels * 4);
|
||||||
|
if (!tmp)
|
||||||
|
{
|
||||||
|
NSLog(@"Could not allocate drawing space for image");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
rowData = (unsigned char *)data[0];
|
||||||
index = 0;
|
index = 0;
|
||||||
|
|
||||||
for (i = 0; i < pixelsHigh; i++)
|
for (i = 0; i < pixelsHigh; i++)
|
||||||
|
|
|
@ -35,35 +35,40 @@
|
||||||
|
|
||||||
@implementation Win32CairoGlitzSurface
|
@implementation Win32CairoGlitzSurface
|
||||||
|
|
||||||
|
+ (void) initialize
|
||||||
|
{
|
||||||
|
NSLog(@"Win32CairoGlitzSurface : %d : glitz_wgl_init", __LINE__);
|
||||||
|
glitz_wgl_init(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
- (id) initWithDevice: (void *)device
|
- (id) initWithDevice: (void *)device
|
||||||
{
|
{
|
||||||
WIN_INTERN *win;
|
WIN_INTERN *win;
|
||||||
|
|
||||||
static BOOL first_time = YES;
|
|
||||||
|
|
||||||
unsigned long mask = 0;
|
unsigned long mask = 0;
|
||||||
glitz_drawable_format_t dtempl;
|
glitz_drawable_format_t dtempl;
|
||||||
|
|
||||||
//static
|
//static
|
||||||
glitz_drawable_format_t *dformat = NULL;
|
glitz_drawable_format_t *dformat = NULL;
|
||||||
static unsigned count = 0;
|
|
||||||
glitz_drawable_t *drawable = NULL;
|
glitz_drawable_t *drawable = NULL;
|
||||||
glitz_format_t *format = NULL;
|
glitz_format_t *format = NULL;
|
||||||
glitz_surface_t *surface = NULL;
|
glitz_surface_t *surface = NULL;
|
||||||
RECT sz;
|
RECT sz;
|
||||||
|
|
||||||
count++;
|
|
||||||
|
|
||||||
gsDevice = device;
|
gsDevice = device;
|
||||||
GetClientRect(GSWINDEVICE,&sz);
|
GetClientRect(GSWINDEVICE, &sz);
|
||||||
win = (WIN_INTERN *)GetWindowLong(GSWINDEVICE, GWL_USERDATA);
|
win = (WIN_INTERN *)GetWindowLong(GSWINDEVICE, GWL_USERDATA);
|
||||||
|
if (win && win->useHDC)
|
||||||
|
{
|
||||||
|
HGDIOBJ old;
|
||||||
|
|
||||||
if(first_time)
|
old = SelectObject(win->hdc, win->old);
|
||||||
{
|
DeleteObject(old);
|
||||||
NSLog(@"Win32CairoGlitzSurface : %d (%d) : glitz_wgl_init",__LINE__,count);
|
DeleteDC(win->hdc);
|
||||||
glitz_wgl_init(NULL);
|
win->hdc = NULL;
|
||||||
first_time=NO;
|
win->old = NULL;
|
||||||
}
|
win->useHDC = NO;
|
||||||
|
}
|
||||||
|
|
||||||
//NSLog(@"Win32CairoGlitzSurface : init window %d (%d,%d-%d,%d)",GSWINDEVICE,sz.left,sz.top,sz.right,sz.bottom);
|
//NSLog(@"Win32CairoGlitzSurface : init window %d (%d,%d-%d,%d)",GSWINDEVICE,sz.left,sz.top,sz.right,sz.bottom);
|
||||||
|
|
||||||
|
@ -85,23 +90,10 @@ count++;
|
||||||
dtempl.doublebuffer = 0;
|
dtempl.doublebuffer = 0;
|
||||||
mask |= GLITZ_FORMAT_DOUBLEBUFFER_MASK;
|
mask |= GLITZ_FORMAT_DOUBLEBUFFER_MASK;
|
||||||
|
|
||||||
if(win && win->useHDC)
|
dformat = glitz_wgl_find_window_format(mask, &dtempl, 0);
|
||||||
{
|
|
||||||
HGDIOBJ old;
|
|
||||||
|
|
||||||
old = SelectObject(win->hdc, win->old);
|
|
||||||
DeleteObject(old);
|
|
||||||
DeleteDC(win->hdc);
|
|
||||||
win->hdc = NULL;
|
|
||||||
win->old = NULL;
|
|
||||||
win->useHDC = NO;
|
|
||||||
}
|
|
||||||
|
|
||||||
dformat = glitz_wgl_find_window_format(mask,&dtempl,0);
|
|
||||||
|
|
||||||
if (!dformat)
|
if (!dformat)
|
||||||
{
|
{
|
||||||
NSLog(@"Win32CairoGlitzSurface : %d (%d) : no format for drawable",__LINE__,count);
|
NSLog(@"Win32CairoGlitzSurface : %d : no format for drawable",__LINE__);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,12 +114,11 @@ count++;
|
||||||
drawable = glitz_wgl_create_drawable_for_window(
|
drawable = glitz_wgl_create_drawable_for_window(
|
||||||
dformat,
|
dformat,
|
||||||
GSWINDEVICE,
|
GSWINDEVICE,
|
||||||
sz.right-sz.left,
|
sz.right - sz.left,
|
||||||
sz.bottom-sz.top);
|
sz.bottom - sz.top);
|
||||||
|
|
||||||
if (!drawable)
|
if (!drawable)
|
||||||
{
|
{
|
||||||
NSLog(@"Win32CairoGlitzSurface : %d (%d) : no glitz drawable",__LINE__,count);
|
NSLog(@"Win32CairoGlitzSurface : %d : no glitz drawable",__LINE__);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,17 +131,21 @@ count++;
|
||||||
|
|
||||||
surface = glitz_surface_create(
|
surface = glitz_surface_create(
|
||||||
drawable, format,
|
drawable, format,
|
||||||
sz.right-sz.left,
|
sz.right - sz.left,
|
||||||
sz.bottom-sz.top,
|
sz.bottom - sz.top,
|
||||||
0, NULL);
|
0, NULL);
|
||||||
|
|
||||||
if (!surface)
|
if (!surface)
|
||||||
{
|
{
|
||||||
NSLog(@"Win32CairoGlitzSurface : %d (%d) : couldn't create glitz surface",__LINE__,count);
|
NSLog(@"Win32CairoGlitzSurface : %d : couldn't create glitz surface",__LINE__);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
glitz_surface_attach(surface, drawable, GLITZ_DRAWABLE_BUFFER_FRONT_COLOR);
|
glitz_surface_attach(surface, drawable, GLITZ_DRAWABLE_BUFFER_FRONT_COLOR);
|
||||||
_surface = cairo_glitz_surface_create(surface);
|
_surface = cairo_glitz_surface_create(surface);
|
||||||
|
if (cairo_surface_status(_surface))
|
||||||
|
{
|
||||||
|
DESTROY(self);
|
||||||
|
}
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
@ -158,8 +153,9 @@ count++;
|
||||||
- (NSSize) size
|
- (NSSize) size
|
||||||
{
|
{
|
||||||
RECT sz;
|
RECT sz;
|
||||||
GetClientRect(GSWINDEVICE,&sz);
|
|
||||||
return NSMakeSize(sz.right-sz.left, sz.bottom-sz.top);
|
GetClientRect(GSWINDEVICE, &sz);
|
||||||
|
return NSMakeSize(sz.right - sz.left, sz.bottom - sz.top);
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
|
@ -40,19 +40,24 @@
|
||||||
gsDevice = device;
|
gsDevice = device;
|
||||||
|
|
||||||
win = (WIN_INTERN *)GetWindowLong(GSWINDEVICE, GWL_USERDATA);
|
win = (WIN_INTERN *)GetWindowLong(GSWINDEVICE, GWL_USERDATA);
|
||||||
if(win && win->useHDC)
|
if (win && win->useHDC)
|
||||||
hDC = win->hdc;
|
hDC = win->hdc;
|
||||||
else
|
else
|
||||||
hDC = GetDC(GSWINDEVICE);
|
hDC = GetDC(GSWINDEVICE);
|
||||||
|
|
||||||
if( !hDC )
|
if (!hDC)
|
||||||
{
|
{
|
||||||
NSLog(@"Win32CairoSurface : %d : no device context",__LINE__);
|
NSLog(@"Win32CairoSurface : %d : no device context",__LINE__);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
_surface = cairo_win32_surface_create(hDC);
|
_surface = cairo_win32_surface_create(hDC);
|
||||||
if(!(win && win->useHDC))
|
if (!(win && win->useHDC))
|
||||||
ReleaseDC(GSWINDEVICE,hDC);
|
ReleaseDC(GSWINDEVICE, hDC);
|
||||||
|
if (cairo_surface_status(_surface))
|
||||||
|
{
|
||||||
|
DESTROY(self);
|
||||||
|
}
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
@ -60,8 +65,9 @@
|
||||||
- (NSSize) size
|
- (NSSize) size
|
||||||
{
|
{
|
||||||
RECT sz;
|
RECT sz;
|
||||||
GetClientRect(GSWINDEVICE,&sz);
|
|
||||||
return NSMakeSize(sz.right-sz.left, sz.top-sz.bottom);
|
GetClientRect(GSWINDEVICE, &sz);
|
||||||
|
return NSMakeSize(sz.right - sz.left, sz.top - sz.bottom);
|
||||||
}
|
}
|
||||||
|
|
||||||
@end
|
@end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue