demake 0.1.2 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/bin/demake +503 -579
- data/lib/apps/example/Makefile +374 -0
- data/lib/apps/example/demake/applications +3 -0
- data/lib/apps/example/demake/brief_description +1 -0
- data/lib/apps/example/demake/license +19 -0
- data/lib/apps/example/demake/settings.rb +62 -0
- data/lib/apps/example/demake/suggestion +1 -0
- data/lib/apps/example/demake/test-target.rb +8 -0
- data/lib/apps/example/src/goodbye.c +12 -0
- data/lib/apps/example/src/hello.c +12 -0
- data/lib/apps/example/src/string/string.c +12 -0
- data/lib/apps/example/src/string/string.h +7 -0
- data/lib/apps/oreo/Makefile +260 -0
- data/lib/apps/oreo/demake/applications +1 -0
- data/lib/apps/oreo/demake/brief_description +1 -0
- data/lib/apps/oreo/demake/license +19 -0
- data/lib/apps/oreo/demake/settings.rb +62 -0
- data/lib/apps/oreo/demake/suggestion +1 -0
- data/lib/apps/oreo/demake/test-target.rb +9 -0
- data/lib/apps/oreo/oreo_test.txt +1 -0
- data/lib/apps/oreo/src/defines.h +29 -0
- data/lib/apps/oreo/src/fast_read_file.h +259 -0
- data/lib/apps/oreo/src/oreo.c +102 -0
- data/lib/apps/oreo/src/typedefs.h +61 -0
- data/lib/data/libsrc/auto_bits.h +33 -0
- data/lib/data/libsrc/base.h +10 -0
- data/lib/data/libsrc/cpu_mark_check.h +267 -0
- data/lib/data/libsrc/defines.h +29 -0
- data/lib/data/libsrc/fast_read_file.h +259 -0
- data/lib/data/libsrc/fast_sha2.h +1840 -0
- data/lib/data/libsrc/parse_arguments.h +0 -0
- data/lib/data/libsrc/rb_library.c +140 -0
- data/lib/data/libsrc/typedefs.h +61 -0
- data/lib/template/build_target.rb +6 -0
- data/lib/template/clean_target.rb +6 -0
- data/lib/template/debug_executable_target.rb +14 -0
- data/lib/template/debug_library_target.rb +14 -0
- data/lib/template/debug_target.rb +4 -0
- data/lib/template/dependency_targets.rb +22 -0
- data/lib/template/executable_debug_target.rb +6 -0
- data/lib/template/executable_target.rb +14 -0
- data/lib/template/generic_dependency_targets.rb +26 -0
- data/lib/template/library_debug_target.rb +6 -0
- data/lib/template/library_target.rb +6 -0
- data/lib/template/license_target.rb +10 -0
- data/lib/template/link_library_target.rb +14 -0
- data/lib/template/strip_build.rb +8 -0
- metadata +54 -7
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
/*
|
|
2
|
+
|
|
3
|
+
fast_read_file.h -- *Full Library* Header File
|
|
4
|
+
|
|
5
|
+
For reading the entire contents of a file into 64-bit aligned memory.
|
|
6
|
+
|
|
7
|
+
See the end of this file for examples.
|
|
8
|
+
|
|
9
|
+
Public Functions: ** DON'T FORGET TO FREE YOUR MEMORY AFTER USE **
|
|
10
|
+
|
|
11
|
+
c8 *fast_read_all_file_mapped(FILE *file, u64 *total_bytes); ** READ ONLY **
|
|
12
|
+
void free_all_mapped_read_memory(c8 *data, u64 *total_bytes);
|
|
13
|
+
|
|
14
|
+
c8 *fast_read_all_file_aligned(FILE *file, u64 *total_bytes); ** READ/WRITE **
|
|
15
|
+
void free_all_aligned_read_memory(c8 *data);
|
|
16
|
+
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
#ifndef FAST_READ_FILE_H_Minaswan /* Prevent multiple inclusions */
|
|
20
|
+
#define FAST_READ_FILE_H_Minaswan
|
|
21
|
+
#define FAST_READ_FILE_VERSION "0.1.0"
|
|
22
|
+
#ifndef TYPEDEFS_H_Minaswan /* Header guard for typedefs.h */
|
|
23
|
+
#define TYPEDEFS_H_Minaswan
|
|
24
|
+
#include <stdint.h>
|
|
25
|
+
typedef uint8_t b8; /* Booleans */
|
|
26
|
+
typedef uint16_t b16;
|
|
27
|
+
typedef uint32_t b32;
|
|
28
|
+
typedef uint64_t b64;
|
|
29
|
+
|
|
30
|
+
typedef char c8; /* Characters */
|
|
31
|
+
typedef unsigned char uc8;
|
|
32
|
+
|
|
33
|
+
typedef uint8_t u8; /* Unsigned Numbers */
|
|
34
|
+
typedef uint16_t u16;
|
|
35
|
+
typedef uint32_t u32;
|
|
36
|
+
typedef uint64_t u64;
|
|
37
|
+
|
|
38
|
+
typedef int8_t i8; /* Signed Numbers */
|
|
39
|
+
typedef int16_t i16;
|
|
40
|
+
typedef int32_t i32;
|
|
41
|
+
typedef int64_t i64;
|
|
42
|
+
|
|
43
|
+
typedef float f32; /* Floating Point Numbers */
|
|
44
|
+
typedef double f64;
|
|
45
|
+
#endif /* TYPEDEFS_H_Minaswan */
|
|
46
|
+
|
|
47
|
+
#include <stdio.h>
|
|
48
|
+
|
|
49
|
+
/* Public Functions */
|
|
50
|
+
void free_all_mapped_read_memory(c8 *data, u64 *total_bytes);
|
|
51
|
+
void free_all_aligned_read_memory(c8 *data);
|
|
52
|
+
c8 *fast_read_all_file_mapped(FILE *file, u64 *total_bytes);
|
|
53
|
+
c8 *fast_read_all_file_aligned(FILE *file, u64 *total_bytes);
|
|
54
|
+
|
|
55
|
+
#ifdef FAST_READ_FILE_IMPLEMENTATION /* Effectively read_all_file.c */
|
|
56
|
+
#include <stdlib.h>
|
|
57
|
+
#include <string.h>
|
|
58
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
59
|
+
#include <windows.h>
|
|
60
|
+
#else
|
|
61
|
+
#include <sys/mman.h>
|
|
62
|
+
#include <sys/stat.h>
|
|
63
|
+
#include <fcntl.h>
|
|
64
|
+
#include <unistd.h>
|
|
65
|
+
#endif
|
|
66
|
+
|
|
67
|
+
extern i32 fileno(FILE *stream);
|
|
68
|
+
|
|
69
|
+
#define FAST_READ_FILE_BUFFER_SIZE 4096
|
|
70
|
+
|
|
71
|
+
#ifndef FALSE
|
|
72
|
+
#define FALSE 0
|
|
73
|
+
#endif
|
|
74
|
+
|
|
75
|
+
#ifndef TRUE
|
|
76
|
+
#define TRUE 1
|
|
77
|
+
#endif
|
|
78
|
+
|
|
79
|
+
#ifndef NULL
|
|
80
|
+
#define NULL ((void *) 0)
|
|
81
|
+
#endif
|
|
82
|
+
|
|
83
|
+
#ifndef MIN
|
|
84
|
+
#define MIN(a, b) ((a) < (b) ? a : b)
|
|
85
|
+
#endif
|
|
86
|
+
|
|
87
|
+
void *fast_file_align64_malloc(size_t size)
|
|
88
|
+
{
|
|
89
|
+
void *result = NULL;
|
|
90
|
+
|
|
91
|
+
if(size == 0)
|
|
92
|
+
return(NULL);
|
|
93
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
94
|
+
result = _aligned_malloc(size, 64);
|
|
95
|
+
#else
|
|
96
|
+
#if(defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE >= 200112L) || \
|
|
97
|
+
(defined(_XOPEN_SOURCE) && _XOPEN_SOURCE >= 600)
|
|
98
|
+
if(posix_memalign(&result, 64, size) != 0)
|
|
99
|
+
return(NULL);
|
|
100
|
+
#else
|
|
101
|
+
result = malloc(size);
|
|
102
|
+
#endif
|
|
103
|
+
#endif
|
|
104
|
+
return(result);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
void *fast_file_align64_calloc(size_t size)
|
|
108
|
+
{
|
|
109
|
+
void *result = fast_file_align64_malloc(size);
|
|
110
|
+
|
|
111
|
+
if(result)
|
|
112
|
+
memset(result, 0, size);
|
|
113
|
+
return(result);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
void *fast_file_align64_realloc(void *existing_memory, size_t old_size, size_t new_size)
|
|
117
|
+
{
|
|
118
|
+
void *new_memory = fast_file_align64_calloc(new_size);
|
|
119
|
+
|
|
120
|
+
if(new_memory && existing_memory) {
|
|
121
|
+
memcpy(new_memory, existing_memory, MIN(new_size, old_size));
|
|
122
|
+
free(existing_memory);
|
|
123
|
+
return(new_memory);
|
|
124
|
+
}
|
|
125
|
+
return(NULL);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
c8 *fast_read_all_file_aligned(FILE *file, u64 *total_bytes)
|
|
129
|
+
{
|
|
130
|
+
size_t bytes = 0, count = 0;
|
|
131
|
+
c8 buffer[FAST_READ_FILE_BUFFER_SIZE + 1];
|
|
132
|
+
c8 *data = NULL;
|
|
133
|
+
|
|
134
|
+
bytes = fread(buffer, sizeof(c8), FAST_READ_FILE_BUFFER_SIZE, file);
|
|
135
|
+
while(bytes) {
|
|
136
|
+
if(data) {
|
|
137
|
+
data = fast_file_align64_realloc(data, *total_bytes + 1, *total_bytes + bytes + 1);
|
|
138
|
+
count = 0;
|
|
139
|
+
while(count < bytes) {
|
|
140
|
+
*(data + *total_bytes + count) = buffer[count];
|
|
141
|
+
count++;
|
|
142
|
+
}
|
|
143
|
+
} else {
|
|
144
|
+
data = fast_file_align64_calloc(bytes + 1);
|
|
145
|
+
count = 0;
|
|
146
|
+
while(count < bytes) {
|
|
147
|
+
*(data + *total_bytes + count) = buffer[count];
|
|
148
|
+
count++;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
*total_bytes += (u32)bytes;
|
|
152
|
+
*(data + *total_bytes) = '\0';
|
|
153
|
+
bytes = fread(buffer, sizeof(c8), FAST_READ_FILE_BUFFER_SIZE, file);
|
|
154
|
+
}
|
|
155
|
+
return(data);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
c8 *fast_read_all_file_mapped(FILE *file, u64 *total_bytes)
|
|
159
|
+
{
|
|
160
|
+
c8 *data = NULL;
|
|
161
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
162
|
+
HANDLE windows_file_handle = {0};
|
|
163
|
+
HANDLE windows_map_handle = {0};
|
|
164
|
+
LARGE_INTEGER windows_file_size = {0};
|
|
165
|
+
#else
|
|
166
|
+
i32 file_descriptor = fileno(file);
|
|
167
|
+
struct stat st = {0};
|
|
168
|
+
#endif
|
|
169
|
+
|
|
170
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
171
|
+
windows_file_handle = (HANDLE)_get_osfhandle(fileno(file));
|
|
172
|
+
if(windows_file_handle == INVALID_HANDLE_VALUE)
|
|
173
|
+
return(NULL);
|
|
174
|
+
if(!GetFileSizeEx(windows_file_handle, &windows_file_size) ||
|
|
175
|
+
windows_file_size.QuadPart == 0) {
|
|
176
|
+
CloseHandle(windows_file_handle);
|
|
177
|
+
return(NULL);
|
|
178
|
+
}
|
|
179
|
+
*total_bytes = (u64)windows_file_size.QuadPart;
|
|
180
|
+
windows_map_handle = CreateFileMapping(windows_file_handle,
|
|
181
|
+
NULL, PAGE_READONLY, 0, 0, NULL);
|
|
182
|
+
data = MapViewOfFile(windows_map_handle, FILE_MAP_READ, 0, 0, 0);
|
|
183
|
+
CloseHandle(windows_file_handle);
|
|
184
|
+
CloseHandle(windows_map_handle);
|
|
185
|
+
#else
|
|
186
|
+
if(file_descriptor == -1)
|
|
187
|
+
return(NULL);
|
|
188
|
+
if(fstat(file_descriptor, &st) == -1 || st.st_size == 0) {
|
|
189
|
+
close(file_descriptor);
|
|
190
|
+
return(NULL);
|
|
191
|
+
}
|
|
192
|
+
*total_bytes = (u64)st.st_size;
|
|
193
|
+
data = mmap(NULL, *total_bytes, PROT_READ, MAP_PRIVATE,
|
|
194
|
+
file_descriptor, 0);
|
|
195
|
+
if(data == MAP_FAILED) {
|
|
196
|
+
close(file_descriptor);
|
|
197
|
+
return(NULL);
|
|
198
|
+
}
|
|
199
|
+
#ifdef POSIX_FADV_SEQUENTIAL
|
|
200
|
+
posix_fadvise(file_descriptor, 0, (i64)*total_bytes,
|
|
201
|
+
POSIX_FADV_SEQUENTIAL);
|
|
202
|
+
#endif
|
|
203
|
+
#ifdef MADV_SEQUENTIAL
|
|
204
|
+
madvise(data, *total_bytes, MADV_SEQUENTIAL);
|
|
205
|
+
#endif
|
|
206
|
+
close(file_descriptor);
|
|
207
|
+
#endif
|
|
208
|
+
return(data);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
void free_all_mapped_read_memory(c8 *data, u64 *total_bytes)
|
|
212
|
+
{
|
|
213
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
214
|
+
UnmapViewOfFile(data);
|
|
215
|
+
#else
|
|
216
|
+
munmap(data, *total_bytes);
|
|
217
|
+
#endif
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
void free_all_aligned_read_memory(c8 *data)
|
|
221
|
+
{
|
|
222
|
+
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
|
|
223
|
+
_aligned_free(data);
|
|
224
|
+
#else
|
|
225
|
+
free(data);
|
|
226
|
+
#endif
|
|
227
|
+
}
|
|
228
|
+
#endif /* FAST_READ_FILE_IMPLEMENTATION */
|
|
229
|
+
#endif /* FAST_READ_FILE_H_Minaswan */
|
|
230
|
+
|
|
231
|
+
/*
|
|
232
|
+
|
|
233
|
+
Examples: ** DON'T FORGET TO FREE YOUR MEMORY AFTER USE **
|
|
234
|
+
|
|
235
|
+
#define FAST_READ_FILE_IMPLEMENTATION
|
|
236
|
+
#include "fast_read_file.h"
|
|
237
|
+
|
|
238
|
+
// Read everything from file example:
|
|
239
|
+
|
|
240
|
+
FILE *file = fopen(argv[1], "rb");
|
|
241
|
+
u64 total_bytes = 0;
|
|
242
|
+
c8 *data = fast_read_all_file_mapped(file, &total_bytes);
|
|
243
|
+
use(string);
|
|
244
|
+
free_all_mapped_read_memory(string); // Note: Doesn't use malloc/free
|
|
245
|
+
|
|
246
|
+
// Read everything from stdin / non-kernal mapping example:
|
|
247
|
+
|
|
248
|
+
u64 total_bytes = 0;
|
|
249
|
+
c8 *data = fast_read_all_file_aligned(stdin, &total_bytes);
|
|
250
|
+
use(string);
|
|
251
|
+
free_all_aligned_read_memory(string); // Note: Might not use malloc/free
|
|
252
|
+
|
|
253
|
+
FILE *file = fopen(argv[1], "rb");
|
|
254
|
+
u64 total_bytes = 0;
|
|
255
|
+
c8 *data = fast_read_all_file_aligned(file, &total_bytes);
|
|
256
|
+
use(string);
|
|
257
|
+
free_all_aligned_read_memory(string); // Note: Might not use malloc/free
|
|
258
|
+
|
|
259
|
+
*/
|