-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathqueue.c
More file actions
117 lines (105 loc) · 3.51 KB
/
queue.c
File metadata and controls
117 lines (105 loc) · 3.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/*
Routines for CBUS FLiM operations - part of CBUS libraries for PIC 18F
This work is licensed under the:
Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.
To view a copy of this license, visit:
http://creativecommons.org/licenses/by-nc-sa/4.0/
or send a letter to Creative Commons, PO Box 1866, Mountain View, CA 94042, USA.
License summary:
You are free to:
Share, copy and redistribute the material in any medium or format
Adapt, remix, transform, and build upon the material
The licensor cannot revoke these freedoms as long as you follow the license terms.
Attribution : You must give appropriate credit, provide a link to the license,
and indicate if changes were made. You may do so in any reasonable manner,
but not in any way that suggests the licensor endorses you or your use.
NonCommercial : You may not use the material for commercial purposes. **(see note below)
ShareAlike : If you remix, transform, or build upon the material, you must distribute
your contributions under the same license as the original.
No additional restrictions : You may not apply legal terms or technological measures that
legally restrict others from doing anything the license permits.
** For commercial use, please contact the original copyright holder(s) to agree licensing terms
**************************************************************************************************************
The FLiM routines have no code or definitions that are specific to any
module, so they can be used to provide FLiM facilities for any module
using these libraries.
*/
/*
* File: actionQueue.c
* Author: Ian
*
* Created on 04 December 2017, 21:45
*
* A queue of consumed actions.
*/
#include "module.h"
#include "queue.h"
/**
* Push an item onto the action queue.
* @param q
* @param a
* @return
*/
BOOL push(Queue * q, COMPUTE_ACTION_T a) {
if (((q->writeIdx+1)&((q->size)-1)) == q->readIdx) return FALSE; // buffer full
q->queue[q->writeIdx++] = a;
if (q->writeIdx >= q->size) q->writeIdx = 0;
return TRUE;
}
/**
* Pull the next action from the buffer.
*
* @return the next action
*/
COMPUTE_ACTION_T pop(Queue * q) {
COMPUTE_ACTION_T ret;
if (q->writeIdx == q->readIdx) {
return NO_ACTION; // buffer empty
}
ret = q->queue[q->readIdx++];
if (q->readIdx >= q->size) q->readIdx = 0;
return ret;
}
/**
* Peek into the buffer.
*
* @return the action
*/
COMPUTE_ACTION_T peek(Queue * q, unsigned char index) {
if (q->readIdx == q->writeIdx) return NO_ACTION; // empty
index += q->readIdx;
// index -= 1;
if (index >= q->size) {
index -= q->size;
}
if (index == q->writeIdx) return NO_ACTION; // at end
return q->queue[index];
}
/**
* Change the last value.
* @param q
* @param newVal
*/
void change(Queue * q, COMPUTE_ACTION_T newVal) {
if (q->readIdx == q->writeIdx) return; // empty
q->queue[q->readIdx] = newVal;
}
/**
* Return number of items in the queue.
*/
unsigned char quantity(Queue * q) {
return (q->writeIdx - q->readIdx) & (q->size -1);
}
/**
* Delete an item in the queue. Replace the item with NO_ACTION.
* @param index the item index within the queue
*/
void delete(Queue * q, unsigned char index) {
if (index >= q->size) return;
index += q->readIdx;
//index -= 1;
if (index >= q->size) {
index -= q->size;
}
q->queue[index] = NO_ACTION;
}