ObjectivelyMVC 0.1.0
Object oriented MVC framework for OpenGL, SDL2 and GNU C
Option.c
Go to the documentation of this file.
1/*
2 * ObjectivelyMVC: Object oriented MVC framework for OpenGL, SDL2 and GNU C.
3 * Copyright (C) 2014 Jay Dolan <jay@jaydolan.com>
4 *
5 * This software is provided 'as-is', without any express or implied
6 * warranty. In no event will the authors be held liable for any damages
7 * arising from the use of this software.
8 *
9 * Permission is granted to anyone to use this software for any purpose,
10 * including commercial applications, and to alter it and redistribute it
11 * freely, subject to the following restrictions:
12 *
13 * 1. The origin of this software must not be misrepresented; you must not
14 * claim that you wrote the original software. If you use this software
15 * in a product, an acknowledgment in the product documentation would be
16 * appreciated but is not required.
17 *
18 * 2. Altered source versions must be plainly marked as such, and must not be
19 * misrepresented as being the original software.
20 *
21 * 3. This notice may not be removed or altered from any source distribution.
22 */
23
24#include <assert.h>
25
26#include "Option.h"
27
28#define _Class _Option
29
30#pragma mark - Object
31
35static void dealloc(Object *self) {
36
37 Option *this = (Option *) self;
38
39 release(this->title);
40
41 super(Object, self, dealloc);
42}
43
47static String *description(const Object *self) {
48
49 View *this = (View *) self;
50
51 String *classNames = $((Object *) this->classNames, description);
52 String *description = str("%s@%p \"%s\" %s [%d, %d, %d, %d]",
53 this->identifier ?: classnameof(self),
54 self,
55 ((Option *) self)->title->text,
56 classNames->chars,
57 this->frame.x, this->frame.y, this->frame.w, this->frame.h);
58
59 release(classNames);
60 return description;
61}
62
63#pragma mark - View
64
68static _Bool acceptsFirstResponder(const View *self) {
69 return true;
70}
71
75static _Bool matchesSelector(const View *self, const SimpleSelector *simpleSelector) {
76
77 assert(simpleSelector);
78
79 const Option *this = (Option *) self;
80
81 switch (simpleSelector->type) {
83 if (strcmp("selected", simpleSelector->pattern) == 0) {
84 return this->isSelected;
85 }
86 break;
87 default:
88 break;
89 }
90
91 return super(View, self, matchesSelector, simpleSelector);
92}
93
94#pragma mark - Option
95
100static Option *initWithTitle(Option *self, const char *title, ident value) {
101
102 self = (Option *) super(View, self, initWithFrame, NULL);
103 if (self) {
104
105 self->title = $(alloc(Text), initWithText, title, NULL);
106 assert(self->title);
107
108 self->value = value;
109
110 $((View *) self, addSubview, (View *) self->title);
111 }
112
113 return self;
114}
115
120static void setSelected(Option *self, _Bool isSelected) {
121
122 if (self->isSelected != isSelected) {
123 self->isSelected = isSelected;
124
125 self->view.needsLayout = true;
126 }
127}
128
129#pragma mark - Class lifecycle
130
134static void initialize(Class *clazz) {
135
136 ((ObjectInterface *) clazz->interface)->dealloc = dealloc;
137 ((ObjectInterface *) clazz->interface)->description = description;
138
139 ((ViewInterface *) clazz->interface)->acceptsFirstResponder = acceptsFirstResponder;
140 ((ViewInterface *) clazz->interface)->matchesSelector = matchesSelector;
141
142 ((OptionInterface *) clazz->interface)->initWithTitle = initWithTitle;
143 ((OptionInterface *) clazz->interface)->setSelected = setSelected;
144
145}
146
151Class *_Option(void) {
152 static Class *clazz;
153 static Once once;
154
155 do_once(&once, {
156 clazz = _initialize(&(const ClassDef) {
157 .name = "Option",
158 .superclass = _View(),
159 .instanceSize = sizeof(Option),
160 .interfaceOffset = offsetof(Option, interface),
161 .interfaceSize = sizeof(OptionInterface),
163 });
164 });
165
166 return clazz;
167}
168
169#undef _Class
170
static String * description(const Object *self)
Definition: Option.c:47
static void dealloc(Object *self)
Definition: Option.c:35
static void initialize(Class *clazz)
Definition: Option.c:134
Select Options.
@ SimpleSelectorTypePseudo
Box * initWithFrame(Box *self, const SDL_Rect *frame)
Initializes this Box with the given frame.
Definition: Box.c:92
Button * initWithTitle(Button *self, const char *title)
Initializes this Button with the specified title.
Definition: Button.c:135
void setSelected(CollectionItemView *self, _Bool isSelected)
Sets the selected state of this item.
_Bool isSelected(const Control *self)
Definition: Control.c:325
Label * initWithText(Label *self, const char *text, Font *font)
Initializes this Label with the given text and Font.
Definition: Label.c:96
Select Options.
Definition: Option.h:41
Text * title
The title.
Definition: Option.h:62
_Bool isSelected
True if this Option is selected, false otherwise.
Definition: Option.h:57
Class * _Option(void)
The Option archetype.
Definition: Option.c:151
View view
The superclass.
Definition: Option.h:46
ident value
The value.
Definition: Option.h:67
The SimpleSelector type.
SimpleSelectorType type
The SimpleSelectorType.
char * pattern
The pattern, as provided by the user.
Text rendered with TrueType fonts.
Definition: Text.h:41
Views are the fundamental building blocks of ObjectivelyMVC user interfaces.
Definition: View.h:133
_Bool needsLayout
If true, this View will layout its subviews before it is drawn.
Definition: View.h:221
Class * _View(void)
The View archetype.
Definition: View.c:1769
void addSubview(View *self, View *subview)
Adds a subview to this view, to be drawn above its siblings.
Definition: PageView.c:35
_Bool matchesSelector(const View *self, const SimpleSelector *simpleSelector)
_Bool acceptsFirstResponder(const View *self)
Definition: Control.c:68