summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--new/newcontrol_darwin.m81
-rw-r--r--new/ui_darwin.h4
-rw-r--r--new/uipriv_darwin.h3
3 files changed, 48 insertions, 40 deletions
diff --git a/new/newcontrol_darwin.m b/new/newcontrol_darwin.m
index 77c23ca..f53ef58 100644
--- a/new/newcontrol_darwin.m
+++ b/new/newcontrol_darwin.m
@@ -1,32 +1,33 @@
// 7 april 2015
#include "uipriv_darwin.h"
-typedef struct uiSingleViewControl uiSingleViewControl;
+typedef struct singleView singleView;
-struct uiSingleViewControl {
- uiControl control;
+struct singleView {
NSView *view;
NSScrollView *scrollView;
NSView *immediate; // the control that is added to the parent container; either view or scrollView
uintptr_t parent;
};
-#define S(c) ((uiSingleViewControl *) (c))
-
// TODO this will need to change if we want to provide removal
static void singleDestroy(uiControl *c)
{
- [S(c)->view removeFromSuperview];
+ singleView *s = (singleView *) (c->internal);
+
+ [s->view removeFromSuperview];
}
static uintptr_t singleHandle(uiControl *c)
{
- return (uintptr_t) (S(c)->view);
+ singleView *s = (singleView *) (c->internal);
+
+ return (uintptr_t) (s->view);
}
static void singleSetParent(uiControl *c, uintptr_t parent)
{
- uiSingleViewControl *s = S(c);
+ singleView *s = (singleView *) (c->internal);
NSView *parentView;
s->parent = parent;
@@ -37,7 +38,7 @@ static void singleSetParent(uiControl *c, uintptr_t parent)
static void singleRemoveParent(uiControl *c)
{
- uiSingleViewControl *s = S(c);
+ singleView *s = (singleView *) (c->internal);
uintptr_t oldparent;
oldparent = s->parent;
@@ -47,69 +48,75 @@ static void singleRemoveParent(uiControl *c)
}
// also good for NSBox and NSProgressIndicator
-static uiSize singlePreferredSize(uiControl *c, uiSizing *d)
+static void singlePreferredSize(uiControl *c, uiSizing *d, intmax_t *width, intmax_t *height)
{
- uiSize size;
+ singleView *s = (singleView *) (c->internal);
NSControl *control;
NSRect r;
- control = (NSControl *) (S(c)->view);
+ control = (NSControl *) (s->view);
[control sizeToFit];
// use alignmentRect here instead of frame because we'll be resizing based on that
r = [control alignmentRectForFrame:[control frame]];
- size.width = (intmax_t) r.size.width;
- size.height = (intmax_t) r.size.height;
- return size;
+ *width = (intmax_t) r.size.width;
+ *height = (intmax_t) r.size.height;
}
static void singleResize(uiControl *c, intmax_t x, intmax_t y, intmax_t width, intmax_t height, uiSizing *d)
{
+ singleView *s = (singleView *) (c->internal);
NSRect frame;
frame.origin.x = x;
// mac os x coordinate system has (0,0) in the lower-left
- frame.origin.y = ([[S(c)->immediate superview] bounds].size.height - height) - y;
+ frame.origin.y = ([[s->immediate superview] bounds].size.height - height) - y;
frame.size.width = width;
frame.size.height = height;
- frame = [S(c)->immediate frameForAlignmentRect:frame];
- [S(c)->immediate setFrame:frame];
+ frame = [s->immediate frameForAlignmentRect:frame];
+ [s->immediate setFrame:frame];
}
uiControl *uiDarwinNewControl(Class class, BOOL inScrollView, BOOL scrollViewHasBorder)
{
- uiSingleViewControl *c;
+ uiControl *c;
+ singleView *s;
- c = uiNew(uiSingleViewControl);
+ s = uiNew(singleView);
// thanks to autoxr and arwyn in irc.freenode.net/#macdev
- c->view = (NSView *) [[class alloc] initWithFrame:NSZeroRect];
- c->immediate = c->view;
+ s->view = (NSView *) [[class alloc] initWithFrame:NSZeroRect];
+ s->immediate = s->view;
if (inScrollView) {
- c->scrollView = [[NSScrollView alloc] initWithFrame:NSZeroRect];
- [c->scrollView setDocumentView:c->view];
- [c->scrollView setHasHorizontalScroller:YES];
- [c->scrollView setHasVerticalScroller:YES];
- [c->scrollView setAutohidesScrollers:YES];
+ s->scrollView = [[NSScrollView alloc] initWithFrame:NSZeroRect];
+ [s->scrollView setDocumentView:s->view];
+ [s->scrollView setHasHorizontalScroller:YES];
+ [s->scrollView setHasVerticalScroller:YES];
+ [s->scrollView setAutohidesScrollers:YES];
if (scrollViewHasBorder)
- [c->scrollView setBorderType:NSBezelBorder];
+ [s->scrollView setBorderType:NSBezelBorder];
else
- [c->scrollView setBorderType:NSNoBorder];
- c->immediate = (NSView *) (c->scrollView);
+ [s->scrollView setBorderType:NSNoBorder];
+ s->immediate = (NSView *) (s->scrollView);
}
- c->control.destroy = singleDestroy;
- c->control.handle = singleHandle;
- c->control.setParent = singleSetParent;
- c->control.removeParent = singleRemoveParent;
- c->control.preferredSize = singlePreferredSize;
- c->control.resize = singleResize;
+ c = uiNew(uiControl);
+ c->internal = s;
+ c->destroy = singleDestroy;
+ c->handle = singleHandle;
+ c->setParent = singleSetParent;
+ c->removeParent = singleRemoveParent;
+ c->preferredSize = singlePreferredSize;
+ c->resize = singleResize;
- return (uiControl *) c;
+ return c;
}
BOOL uiDarwinControlFreeWhenAppropriate(uiControl *c, NSView *newSuperview)
{
+ singleView *s = (singleView *) (c->internal);
+
if (newSuperview == nil) {
+ uiFree(s);
uiFree(c);
return YES;
}
diff --git a/new/ui_darwin.h b/new/ui_darwin.h
index f94261a..672eb63 100644
--- a/new/ui_darwin.h
+++ b/new/ui_darwin.h
@@ -15,4 +15,8 @@ This file assumes that you have imported <Cocoa/Cocoa.h> and "ui.h" beforehand.
extern uiControl *uiDarwinNewControl(Class class, BOOL inScrollView, BOOL scrollViewHasBorder);
extern BOOL uiDarwinControlFreeWhenAppropriate(uiControl *c, NSView *newSuperview);
+struct uiSizingSys {
+ // this structure currently left blank
+};
+
#endif
diff --git a/new/uipriv_darwin.h b/new/uipriv_darwin.h
index 52d5b38..ced12fc 100644
--- a/new/uipriv_darwin.h
+++ b/new/uipriv_darwin.h
@@ -32,9 +32,6 @@
extern void setStandardControlFont(NSControl *);
// container_darwin.m
-struct uiSizing {
- uiSizingCommon
-};
@interface uiContainer : NSView
// TODO rename to uiChild
@property uiControl *child;