read fragment shader from file at argument path

This commit is contained in:
2025-09-12 19:39:24 +02:00
parent f90e842bd8
commit ff0a4ebdae
5 changed files with 45 additions and 26 deletions
+21 -15
View File
@@ -7,18 +7,19 @@
#include "config.h"
void print_help(int status_code) {
puts(PACKAGE
" " VERSION "\n\n"
"usage: " PACKAGE " "
"[--help] "
"[-v] "
"[-s=SCREEN] "
"\n\n"
"Fusion Of Real-time Generative Effects.\n\n"
"options:\n"
" --help show this help message and exit\n"
" -v, --version print version\n"
" -s, --screen output screen number (default: primary)\n");
puts(PACKAGE " " VERSION "\n\n"
"usage: " PACKAGE " "
"[--help] "
"[-v] "
"[-s=SCREEN] "
"[-f=FRAG_PATH] "
"\n\n"
"Fusion Of Real-time Generative Effects.\n\n"
"options:\n"
" --help show this help message and exit\n"
" -v, --version print version\n"
" -s, --screen output screen number (default: primary)\n"
" -f, --frag fragment shader path (default: TODO)\n");
exit(status_code);
}
@@ -67,9 +68,7 @@ unsigned char parse_uchar(char *arg, char *value) {
}
Parameters parse_args(int argc, char **argv) {
Parameters params;
params.screen = 0;
Parameters params = {0, 0};
int i;
char *arg;
@@ -84,10 +83,17 @@ Parameters parse_args(int argc, char **argv) {
exit(EXIT_SUCCESS);
} else if (is_arg(arg, "-s") || is_arg(arg, "--screen")) {
params.screen = parse_uchar(arg, value);
} else if (is_arg(arg, "-f") || is_arg(arg, "--frag")) {
params.frag_path = value;
} else {
invalid_arg(arg);
}
}
if (params.frag_path == 0) {
fprintf(stderr, "required argument -f/--frag\n\n");
exit(EXIT_FAILURE);
}
return params;
}
+1 -1
View File
@@ -181,7 +181,7 @@ void loop(GLFWwindow *window, ShaderProgram program) {
void forge_run(Parameters params) {
GLFWwindow *window;
File fragment_shader = read_file("shaders/tmp.glsl");
File fragment_shader = read_file(params.frag_path);
if (fragment_shader.error) {
fprintf(stderr, "Cannot read file\n");
+1
View File
@@ -9,6 +9,7 @@
typedef struct Parameters {
unsigned char screen;
char *frag_path;
} Parameters;
typedef struct Vertex {