-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkd.h
executable file
·361 lines (314 loc) · 18 KB
/
kd.h
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
/*
SIGNATURE:
v0.0.5 - KD Core Library
INFO:
Author: Krzysztof "Sejoslaw" Dobrzyński
Source: https://github.com/Sejoslaw/kdc
DESCRIPTION:
- Core library which I use for my personal projects.
LICENSE:
'Public License'
See at the end of the file for more info.
*/
#ifdef KD_IMPLEMENTATION
#ifdef __cplusplus
extern "C" {
#endif // __cplusplus
/*
/////////////////////////////////////////////////////////////////
// //
// //
// Libraries //
// //
// //
/////////////////////////////////////////////////////////////////
*/
#ifndef KD_SKIP_C99
#include <assert.h> // Contains the assert macro, used to assist with detecting logical errors and other types of bugs in debugging versions of a program.
#include <complex.h> // A set of functions for manipulating complex numbers.
#include <ctype.h> // Defines set of functions used to classify characters by their types or to convert between upper and lower case in a way that is independent of the used character set (typically ASCII or one of its extensions, although implementations utilizing EBCDIC are also known).
#include <errno.h> // For testing error codes reported by library functions.
#include <fenv.h> // Defines a set of functions for controlling floating-point environment.
#include <float.h> // Defines macro constants specifying the implementation-specific properties of the floating-point library.
#include <inttypes.h> // Defines exact-width integer types.
#include <iso646.h> // Defines several macros that implement alternative ways to express several standard tokens. For programming in ISO 646 variant character sets.
#include <limits.h> // Defines macro constants specifying the implementation-specific properties of the integer types.
#include <locale.h> // Defines localization functions.
#include <math.h> // Defines common mathematical functions.
#include <signal.h> // Defines signal-handling functions.
#include <stdarg.h> // For accessing a varying number of arguments passed to functions.
#include <stdbool.h> // Defines a boolean data type.
#include <stddef.h> // Defines several useful types and macros.
#include <stdint.h> // Defines exact-width integer types.
#include <stdio.h> // Defines core input and output functions.
#include <stdlib.h> // Defines numeric conversion functions, pseudo-random numbers generation functions, memory allocation, process control functions.
#include <string.h> // Defines string-handling functions.
#include <tgmath.h> // Defines type-generic mathematical functions.
#include <time.h> // Defines date- and time-handling functions.
#include <wchar.h> // Defines wide-string-handling functions.
#include <wctype.h> // Defines set of functions used to classify wide characters by their types or to convert between upper and lower case.
#endif // KD_SKIP_C99
#ifndef KD_SKIP_C11
#include <stdalign.h> // For querying and specifying the alignment of objects.
#include <stdatomic.h> // For atomic operations on data shared between threads.
#include <stdnoreturn.h> // For specifying non-returning functions.
#include <threads.h> // Defines functions for managing multiple threads, mutexes and condition variables.
#include <uchar.h> // Types and functions for manipulating Unicode characters
#endif // KD_SKIP_C11
#ifndef KD_SKIP_POSIX
#include <aio.h> // Asynchronous input and output.
#include <arpa/inet.h> // Functions for manipulating numeric IP addresses (part of Berkeley sockets).
#include <cpio.h> // Magic numbers for the cpio archive format.
#include <dirent.h> // Allows the opening and listing of directories.
#include <dlfcn.h> // Dynamic linking.
#include <fcntl.h> // File opening, locking and other operations.
#include <fmtmsg.h> // Message display structures.
#include <fnmatch.h> // Filename matching.
#include <ftw.h> // File tree traversal.
#include <glob.h> // Pathname "globbing" (pattern-matching).
#include <grp.h> // User group information and control.
#include <iconv.h> // Codeset conversion facility.
#include <langinfo.h> // Language information constants – builds on C localization functions.
#include <libgen.h> // Pathname manipulation.
#include <monetary.h> // String formatting of monetary units.
#include <mqueue.h> // Message queue.
#include <net/if.h> // Listing of local network interfaces.
#include <netdb.h> // Translating protocol and host names into numeric addresses (part of Berkeley sockets).
#include <netinet/in.h> // Defines Internet protocol and address family (part of Berkeley sockets).
#include <netinet/tcp.h> // Additional TCP control options (part of Berkeley sockets).
#include <nl_types.h> // Localization message catalog functions.
#include <poll.h> // Asynchronous file descriptor multiplexing.
#include <pthread.h> // Defines an API for creating and manipulating POSIX threads.
#include <pwd.h> // passwd (user information) access and control.
#include <regex.h> // Regular expression matching.
#include <sched.h> // Execution scheduling.
#include <search.h> // Search tables.
#include <semaphore.h> // POSIX semaphores.
#include <spawn.h> // Process spawning.
#include <strings.h> // Case-insensitive string comparisons.
#include <sys/ipc.h> // Inter-process communication (IPC).
#include <sys/mman.h> // Memory management, including POSIX shared memory and memory mapped files.
#include <sys/msg.h> // POSIX message queues.
#include <sys/resource.h> // Resource usage, priorities, and limiting.
#include <sys/select.h> // Synchronous I/O multiplexing.
#include <sys/sem.h> // XSI (SysV style) semaphores.
#include <sys/shm.h> // XSI (SysV style) shared memory.
#include <sys/socket.h> // Main Berkeley sockets header.
#include <sys/stat.h> // File information (stat et al.).
#include <sys/statvfs.h> // File System information.
#include <sys/time.h> // Time and date functions and structures.
#include <sys/times.h> // File access and modification times.
#include <sys/types.h> // Various data types used elsewhere.
#include <sys/uio.h> // Vectored I/O operations.
#include <sys/un.h> // Unix domain sockets.
#include <sys/utsname.h> // Operating system information, including uname.
#include <sys/wait.h> // Status of terminated child processes.
#include <syslog.h> // System error logging.
#include <tar.h> // Magic numbers for the tar archive format.
#include <termios.h> // Allows terminal I/O interfaces.
#include <unistd.h> // Various essential POSIX functions and constants.
#include <utime.h> // inode access and modification times.
#include <utmpx.h> // User accounting database functions.
#include <wordexp.h> // Word-expansion like the shell would perform.
#endif // KD_SKIP_POSIX
/*
/////////////////////////////////////////////////////////////////
// //
// //
// Color //
// //
// //
/////////////////////////////////////////////////////////////////
*/
#define KD_COLOR_RED "\x1B[31m"
#define KD_COLOR_GREEN "\x1B[32m"
#define KD_COLOR_YELLOW "\x1B[33m"
#define KD_COLOR_BLUE "\x1B[34m"
#define KD_COLOR_MAGENTA "\x1B[35m"
#define KD_COLOR_CYAN "\x1B[36m"
#define KD_COLOR_WHITE "\x1B[37m"
#define KD_COLOR_RESET "\x1B[0m"
#define KD_PRINT_COLOR_CHAR(text, KD_COLOR) printf(KD_COLOR "%c" KD_COLOR_RESET, text);
#define KD_PRINT_COLOR_TEXT(text, KD_COLOR) printf(KD_COLOR "%s" KD_COLOR_RESET, text);
/*
/////////////////////////////////////////////////////////////////
// //
// //
// Files //
// //
// //
/////////////////////////////////////////////////////////////////
*/
#define KD_FILE_READ "r"
#define KD_FILE_READ_BINARY "rb"
#define KD_FILE_WRITE "w"
#define KD_FILE_WRITE_BINARY "wb"
#define KD_FILE_APPEND "a"
#define KD_FILE_APPEND_BINARY "ab"
#define KD_FILE_READ_WRITE "r+"
#define KD_FILE_READ_WRITE_BINARY "r+b"
#define KD_FILE_READ_WRITE_CREATE "w+"
#define KD_FILE_READ_WRITE_CREATE_BINARY "w+b"
#define KD_FILE_READ_WRITE_CREATE_APPEND "a+"
#define KD_FILE_READ_WRITE_CREATE_APPEND_BINARY "a+b"
/*
Opens file in KD_FILE_READ mode.
*/
FILE *kd_file_open_read(const char *path) {
FILE *file = fopen(path, KD_FILE_READ);
return file;
}
/*
Returns file size in bytes.
*/
long kd_file_size(FILE *file) {
long current_position = ftell(file);
fseek(file, 0L, SEEK_END);
long last_position = ftell(file);
fseek(file, current_position, SEEK_SET);
return last_position;
}
/*
Reads file content and stores it in given buffer.
*/
void kd_file_read_text(FILE *file, char *buffer) {
int index = 0;
int ch;
while ((ch = fgetc(file)) != EOF) {
buffer[index] = ch;
index++;
}
}
/*
Reads a content of a file in a given path.
*/
char *kd_file_read_content(const char *path) {
FILE *file = kd_file_open_read(path);
long file_size = kd_file_size(file);
char *buf = (char *) malloc(sizeof(char) * file_size);
kd_file_read_text(file, buf);
fclose(file);
return buf;
}
/*
/////////////////////////////////////////////////////////////////
// //
// //
// Collections + LINQ //
// //
// //
/////////////////////////////////////////////////////////////////
*/
#define KD_LIST_ACTION void (*kd_list_action)(kd_list_t *, void *)
#define KD_LIST_PREDICATE bool (*kd_list_predicate)(kd_list_t *, void *)
#define KD_LIST_PREDICATE_WHILE bool (*kd_list_predicate_while)(kd_list_t *, void *, kd_list_index_t)
#define KD_LIST_COMPARER int (*kd_list_comparer)(kd_list_t *, void *, void *)
#define KD_LIST_EQUALITY_COMPARER bool (*kd_list_equals)(kd_list_t *, void *, void *)
#define KD_LIST_FUNCTION void *(*kd_list_function)(kd_list_t *, void *)
#define KD_LIST_FUNCTION_2 void *(*kd_list_function_2)(kd_list_t *, void *, void *)
#define KD_LIST_SELECTOR void *(*kd_list_selector)(kd_list_t *, void *)
#define KD_LIST_SELECTOR_SECOND void *(*kd_list_selector_second)(kd_list_t *, void *)
#define KD_LIST_SELECTOR_2 void *(*kd_list_selector_2)(kd_list_t *, void *, void *)
#define KD_LIST_SELECTOR_MANY kd_list_t *(*kd_list_selector_many)(kd_list_t *, void *)
typedef long double kd_list_count_t;
typedef long double kd_list_index_t;
typedef struct kd_list_node_t {
void *data;
kd_list_node_t *next;
} kd_list_node_t;
typedef struct kd_list_t {
// Properties
kd_list_node_t *head;
// List Functions
void (*add)(kd_list_t *, void *); // list, data
void (*add_front)(kd_list_t *, void *); // list, data
void (*add_range)(kd_list_t *, kd_list_t *); // list, data
void (*add_range_raw)(kd_list_t *, void **, kd_list_count_t); // list, table, size
void (*clear)(kd_list_t *); // list
bool (*contains)(kd_list_t *, void *); // list, data
kd_list_index_t (*find_index)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
kd_list_index_t (*find_last_index)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
void (*for_each)(kd_list_t *, KD_LIST_ACTION); // list, action
void *(*get)(kd_list_t *, kd_list_index_t); // list, index
kd_list_t *(*get_range)(kd_list_t *, kd_list_index_t, kd_list_count_t); // list, index, count
kd_list_index_t (*index_of)(kd_list_t *, void *); // list, data
void (*insert)(kd_list_t *, kd_list_index_t, void *); // list, index, data
void (*insert_range)(kd_list_t *, kd_list_index_t, kd_list_t *); // list, index, data
kd_list_index_t (*last_index_of)(kd_list_t *, void *); // list, data
void (*remove)(kd_list_t *, void *); // list, data
void (*remove_all)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
void (*remove_at)(kd_list_t *, kd_list_index_t); // list, index
void (*remove_range)(kd_list_t *, kd_list_index_t, kd_list_count_t); // list, index, count
kd_list_t *(*reverse)(kd_list_t *); // list
kd_list_t *(*reverse_multiple)(kd_list_t *, kd_list_index_t, kd_list_count_t); // list, index, count
void (*set)(kd_list_t *, kd_list_index_t, void *); // list, index, data
void (*sort)(kd_list_t *, KD_LIST_COMPARER); // list, comparer
void **(*to_array)(kd_list_t *, kd_list_count_t *); // list, count_out
// LINQ Functions
void *(*aggregate)(kd_list_t *, KD_LIST_FUNCTION_2); // list, function
bool (*all)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
bool (*any)(kd_list_t *); // list
bool (*any_predicate)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
// TODO: as_parallel
void *(*average)(kd_list_t *, KD_LIST_SELECTOR); // list, selector
kd_list_t **(*chunk)(kd_list_t *, kd_list_count_t, kd_list_count_t); // list, size, count_out
kd_list_t *(*concat)(kd_list_t *, kd_list_t *); // list, second
bool (*contains_equals)(kd_list_t *, void *, KD_LIST_EQUALITY_COMPARER); // list, data, comparer
kd_list_count_t (*count)(kd_list_t *); // list
kd_list_count_t (*count_predicate)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
kd_list_t *(*distinct)(kd_list_t *, KD_LIST_EQUALITY_COMPARER); // list, comparer
kd_list_t *(*except)(kd_list_t *, kd_list_t *, KD_LIST_EQUALITY_COMPARER); // list, second, comparer
void *(*first)(kd_list_t *); // list
void *(*first_predicate)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
// TODO: group by
// TODO: group join
kd_list_t *(*intersect)(kd_list_t *, kd_list_t *, KD_LIST_EQUALITY_COMPARER); // list, second, comparer
kd_list_t *(*join)(kd_list_t *, kd_list_t *, KD_LIST_SELECTOR, KD_LIST_SELECTOR_SECOND, KD_LIST_SELECTOR_2); // list, second, list_key_selector, second_key_selector, result_selector
kd_list_t *(*join_equals)(kd_list_t *, kd_list_t *, KD_LIST_SELECTOR, KD_LIST_SELECTOR_SECOND, KD_LIST_SELECTOR_2, KD_LIST_EQUALITY_COMPARER); // list, second, list_key_selector, second_key_selector, result_selector, comparer
void *(*last)(kd_list_t *); // list
void *(*last_predicate)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
void *(*max)(kd_list_t *, KD_LIST_COMPARER); // list, comparer
void *(*min)(kd_list_t *, KD_LIST_COMPARER); // list, comparer
kd_list_t *(*order)(kd_list_t *, KD_LIST_COMPARER); // list, comparer
kd_list_t *(*order_descending)(kd_list_t *, KD_LIST_COMPARER); // list, comparer
kd_list_t *(*select)(kd_list_t *, KD_LIST_SELECTOR); // list, selector
kd_list_t *(*select_many)(kd_list_t *, KD_LIST_SELECTOR_MANY); // list, selector
bool (*sequence_equal)(kd_list_t *, KD_LIST_EQUALITY_COMPARER); // list, comparer
kd_list_t *(*skip)(kd_list_t *, kd_list_count_t); // list, count
kd_list_t *(*skip_last)(kd_list_t *, kd_list_count_t); // list, count
kd_list_t *(*skip_while)(kd_list_t *, KD_LIST_PREDICATE_WHILE); // list, predicate
void *(*sum)(kd_list_t *, KD_LIST_SELECTOR); // list, selector
kd_list_t *(*take)(kd_list_t *, kd_list_count_t); // list, count
kd_list_t *(*take_last)(kd_list_t *, kd_list_count_t); // list, count
kd_list_t *(*take_while)(kd_list_t *, KD_LIST_PREDICATE_WHILE); // list, predicate
kd_list_t *(*union_list)(kd_list_t *, kd_list_t *, KD_LIST_EQUALITY_COMPARER); // list, second, comparer
kd_list_t *(*where)(kd_list_t *, KD_LIST_PREDICATE); // list, predicate
kd_list_t *(*zip)(kd_list_t *, kd_list_t *, KD_LIST_SELECTOR_2); // list, second, selector
} kd_list_t;
// --== Method Signatures ==--
// --== End Method Signatures ==--
kd_list_node_t *kd_list_node_create(void *data) {
kd_list_node_t *node = (kd_list_node_t *) malloc(sizeof(kd_list_node_t));
node->data = data;
node->next = NULL;
return node;
}
kd_list_t *kd_list_create() {
kd_list_t *list = (kd_list_t *) malloc(sizeof(kd_list_t));
// Properties
list->head = NULL;
// List Functions
// list->add = kd_list_add;
// LINQ Functions
// list->aggregate = kd_list_aggregate;
return list;
}
#ifdef __cplusplus
}
#endif // __cplusplus
#endif // KD_IMPLEMENTATION
/*
This software is dual-licensed to the public domain and under the following
license: you are granted a perpetual, irrevocable license to copy, modify,
publish, and distribute this file as you see fit.
*/