summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--redo/area_darwin.go5
-rw-r--r--redo/area_darwin.m11
-rw-r--r--redo/objc_darwin.h2
3 files changed, 12 insertions, 6 deletions
diff --git a/redo/area_darwin.go b/redo/area_darwin.go
index ba466e1..970c83a 100644
--- a/redo/area_darwin.go
+++ b/redo/area_darwin.go
@@ -51,9 +51,12 @@ func areaView_drawRect(self C.id, rect C.struct_xrect, data unsafe.Pointer) {
return
}
i := a.handler.Paint(cliprect)
- C.drawImage(
+ success := C.drawImage(
unsafe.Pointer(pixelData(i)), C.intptr_t(i.Rect.Dx()), C.intptr_t(i.Rect.Dy()), C.intptr_t(i.Stride),
C.intptr_t(cliprect.Min.X), C.intptr_t(cliprect.Min.Y))
+ if success == C.NO {
+ panic("error drawing into Area (exactly what is unknown)")
+ }
}
func parseModifiers(e C.id) (m Modifiers) {
diff --git a/redo/area_darwin.m b/redo/area_darwin.m
index 7035ed5..d4933d0 100644
--- a/redo/area_darwin.m
+++ b/redo/area_darwin.m
@@ -112,10 +112,11 @@ id newArea(void *goarea)
return (id) a;
}
-void drawImage(void *pixels, intptr_t width, intptr_t height, intptr_t stride, intptr_t xdest, intptr_t ydest)
+BOOL drawImage(void *pixels, intptr_t width, intptr_t height, intptr_t stride, intptr_t xdest, intptr_t ydest)
{
unsigned char *planes[1]; // NSBitmapImageRep wants an array of planes; we have one plane
NSBitmapImageRep *bitmap;
+ BOOL success;
planes[0] = (unsigned char *) pixels;
bitmap = [[NSBitmapImageRep alloc]
@@ -126,18 +127,20 @@ void drawImage(void *pixels, intptr_t width, intptr_t height, intptr_t stride, i
samplesPerPixel:4
hasAlpha:YES
isPlanar:NO
- colorSpaceName:NSCalibratedRGBColorSpace // TODO NSDeviceRGBColorSpace?
+ // NSCalibratedRGBColorSpace changes the colors; let's not
+ // thanks to JtRip in irc.freenode.net/#macdev
+ colorSpaceName:NSDeviceRGBColorSpace
bitmapFormat:0 // this is where the flag for placing alpha first would go if alpha came first; the default is alpha last, which is how we're doing things (otherwise the docs say "Color planes are arranged in the standard order—for example, red before green before blue for RGB color."); this is also where the flag for non-premultiplied colors would go if we used it (the default is alpha-premultiplied)
bytesPerRow:toNSInteger(stride)
bitsPerPixel:32];
- // TODO this CAN fali; check error
- [bitmap drawInRect:NSMakeRect((CGFloat) xdest, (CGFloat) ydest, (CGFloat) width, (CGFloat) height)
+ success = [bitmap drawInRect:NSMakeRect((CGFloat) xdest, (CGFloat) ydest, (CGFloat) width, (CGFloat) height)
fromRect:NSZeroRect // draw whole image
operation:NSCompositeSourceOver
fraction:1.0
respectFlipped:YES
hints:nil];
[bitmap release];
+ return success;
}
uintptr_t modifierFlags(id e)
diff --git a/redo/objc_darwin.h b/redo/objc_darwin.h
index f92f7b5..e531e39 100644
--- a/redo/objc_darwin.h
+++ b/redo/objc_darwin.h
@@ -100,7 +100,7 @@ extern struct xrect frame(id);
/* area_darwin.h */
extern Class getAreaClass(void);
extern id newArea(void *);
-extern void drawImage(void *, intptr_t, intptr_t, intptr_t, intptr_t, intptr_t);
+extern BOOL drawImage(void *, intptr_t, intptr_t, intptr_t, intptr_t, intptr_t);
extern uintptr_t modifierFlags(id);
extern struct xpoint getTranslatedEventPoint(id, id);
extern intptr_t buttonNumber(id);