This commit is contained in:
2025-06-04 14:44:24 +02:00
parent 8ca37b89eb
commit 549b623896
5 changed files with 45 additions and 37 deletions
+2 -1
View File
@@ -1,3 +1,4 @@
build build
.vscode .vscode
*.bmp *.bmp
!images/*
+1 -1
View File
@@ -1,6 +1,6 @@
TARGET ?= margen TARGET ?= margen
INSTALL_DIR ?= $(HOME)/.local/bin INSTALL_DIR ?= $(HOME)/.local/bin
TEST_ARGS ?= -w=100 TEST_ARGS ?=
SHELL := /bin/bash SHELL := /bin/bash
.PHONY: build .PHONY: build
+13
View File
@@ -0,0 +1,13 @@
# margen
> Marble-like pattern generator, blazing fast
![](./images/sample1.bmp)
Written in pure C without librairies.
## TODO
- monochrome
- select corner (currently bottom left)
- better starting parameters for convergeance
Binary file not shown.

After

Width:  |  Height:  |  Size: 5.9 MiB

+29 -35
View File
@@ -40,13 +40,8 @@ void invalid_arg(char *arg) {
print_help(1); print_help(1);
} }
void invalid_value(char *arg, char *subarg, char *value) { void invalid_value(char *arg, char *value) {
if (subarg == NULL) { fprintf(stderr, "invalid value for argument '%s': '%s'\n\n", arg, value);
fprintf(stderr, "invalid value for argument '%s': '%s'\n\n", arg, value);
} else {
fprintf(stderr, "invalid value for argument '%s' %s: '%s'\n\n", arg, subarg,
value);
}
print_help(1); print_help(1);
} }
@@ -59,7 +54,7 @@ char *split_arg_value(char *arg) {
bool is_digit(char c) { return c >= '0' && c <= '9'; } bool is_digit(char c) { return c >= '0' && c <= '9'; }
bool is_number(char *value, char *max) { bool is_number(char *value) {
if (value == NULL) { if (value == NULL) {
return false; return false;
} }
@@ -70,26 +65,34 @@ bool is_number(char *value, char *max) {
return false; return false;
} }
} }
return strcmp(value, max) <= 0; return true;
} }
unsigned char parse_char(char *arg, char *value) { unsigned char parse_char(char *arg, char *value) {
if (!is_number(value, "255")) { if (!is_number(value)) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
return (char)atoi(value); unsigned long long tmp_value = (unsigned long long)atoll(value);
if (tmp_value >= 256) {
invalid_value(arg, value);
}
return (unsigned char)tmp_value;
} }
unsigned short parse_ushort(char *arg, char *value) { unsigned short parse_ushort(char *arg, char *value) {
if (!is_number(value, "65535")) { if (!is_number(value)) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
return (unsigned short)atoi(value); unsigned long long tmp_value = (unsigned long long)atoll(value);
if (tmp_value >= 65536) {
invalid_value(arg, value);
}
return (unsigned short)tmp_value;
} }
unsigned short parse_ulong(char *arg, char *value) { unsigned short parse_ulong(char *arg, char *value) {
if (!is_number(value, "18446744073709551615")) { if (!is_number(value)) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
return (unsigned long)atoll(value); return (unsigned long)atoll(value);
} }
@@ -97,20 +100,11 @@ unsigned short parse_ulong(char *arg, char *value) {
void parse_color(char *arg, char *value, unsigned char color[3]) { void parse_color(char *arg, char *value, unsigned char color[3]) {
char *tmp; char *tmp;
tmp = strtok(value, ","); tmp = strtok(value, ",");
if (!is_number(tmp, "255")) { color[0] = parse_char(arg, tmp);
invalid_value(arg, "(R)", tmp);
}
color[0] = (char)atoi(tmp);
tmp = strtok(NULL, ","); tmp = strtok(NULL, ",");
if (!is_number(tmp, "255")) { color[1] = parse_char(arg, tmp);
invalid_value(arg, "(G)", tmp);
}
color[1] = (char)atoi(tmp);
tmp = strtok(NULL, ","); tmp = strtok(NULL, ",");
if (!is_number(tmp, "255")) { color[2] = parse_char(arg, tmp);
invalid_value(arg, "(B)", tmp);
}
color[2] = (char)atoi(tmp);
} }
parameters parse_args(int argc, char **argv) { parameters parse_args(int argc, char **argv) {
@@ -141,7 +135,7 @@ parameters parse_args(int argc, char **argv) {
} else if (is_arg(arg, "-w") || is_arg(arg, "--width")) { } else if (is_arg(arg, "-w") || is_arg(arg, "--width")) {
params.width = parse_ushort(arg, value); params.width = parse_ushort(arg, value);
if (params.width == 0) { if (params.width == 0) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
if (params.height == 0) { if (params.height == 0) {
params.height = params.width; params.height = params.width;
@@ -149,7 +143,7 @@ parameters parse_args(int argc, char **argv) {
} else if (is_arg(arg, "-h") || is_arg(arg, "--height")) { } else if (is_arg(arg, "-h") || is_arg(arg, "--height")) {
params.height = parse_ushort(arg, value); params.height = parse_ushort(arg, value);
if (params.height == 0) { if (params.height == 0) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
if (params.width == 0) { if (params.width == 0) {
params.width = params.height; params.width = params.height;
@@ -161,7 +155,7 @@ parameters parse_args(int argc, char **argv) {
} else if (is_arg(arg, "-p") || is_arg(arg, "--pixel")) { } else if (is_arg(arg, "-p") || is_arg(arg, "--pixel")) {
params.size = parse_ushort(arg, value); params.size = parse_ushort(arg, value);
if (params.size == 0) { if (params.size == 0) {
invalid_value(arg, NULL, value); invalid_value(arg, value);
} }
size_set = true; size_set = true;
} else if (is_arg(arg, "-s") || is_arg(arg, "--slope")) { } else if (is_arg(arg, "-s") || is_arg(arg, "--slope")) {
@@ -202,9 +196,9 @@ parameters parse_args(int argc, char **argv) {
} }
if (!var_set) { if (!var_set) {
params.var[0] = rand_uchar(30); params.var[0] = rand_uchar(20);
params.var[1] = rand_uchar(30); params.var[1] = rand_uchar(20);
params.var[2] = rand_uchar(30); params.var[2] = rand_uchar(20);
} }
return params; return params;