Objectively
Ultra-lightweight object oriented framework for GNU C.
Loading...
Searching...
No Matches
OperationQueue.h
Go to the documentation of this file.
1/*
2 * Objectively: Ultra-lightweight object oriented framework for 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#pragma once
25
27#include <Objectively/Object.h>
29#include <Objectively/Thread.h>
30
36typedef struct OperationQueue OperationQueue;
37typedef struct OperationQueueInterface OperationQueueInterface;
38
45
50
55 OperationQueueInterface *interface;
56
60 struct {
61
66
71
76
77 } locals;
78
83};
84
88struct OperationQueueInterface {
89
93 ObjectInterface objectInterface;
94
102 void (*addOperation)(OperationQueue *self, Operation *operation);
103
113 Operation *(*addOperationWithFunction)(OperationQueue *self, OperationFunction function, ident data);
114
121 void (*cancelAllOperations)(OperationQueue *self);
122
131 OperationQueue *(*currentQueue)(void);
132
140 OperationQueue *(*init)(OperationQueue *self);
141
148 size_t (*operationCount)(const OperationQueue *self);
149
156 Array *(*operations)(const OperationQueue *self);
157
165 void (*removeOperation)(OperationQueue *self, Operation *operation);
166
173 void (*waitUntilAllOperationsAreFinished)(OperationQueue *self);
174};
175
POSIX Threads conditional variables.
static Data * data(void)
Definition Data.c:286
Object is the root Class of The Objectively Class hierarchy.
An abstraction for discrete units of work, or tasks.
void(* OperationFunction)(Operation *operation)
The function type for Operation execution.
Definition Operation.h:42
OBJECTIVELY_EXPORT Class * _OperationQueue(void)
POSIX Threads.
void * ident
The identity type, similar to Objective-C id.
Definition Types.h:49
#define OBJECTIVELY_EXPORT
Definition Types.h:36
Arrays.
Definition Array.h:56
The runtime representation of a Class.
Definition Class.h:95
POSIX Threads conditional variables.
Definition Condition.h:44
Object is the root Class of The Objectively Class hierarchy.
Definition Object.h:46
An abstraction for discrete units of work, or tasks.
Definition Operation.h:50
OperationQueues provide a thread of execution for Operations.
OperationQueueInterface * interface
The interface.
Thread * thread
The backing Thread.
bool isSuspended
When true, the queue will not start any new Operations.
Array * operations
The Operations.
Object object
The superclass.
Condition * condition
A condition signaled on addOperation and removeOperation.
POSIX Threads.
Definition Thread.h:53