Merge pull request #2 from kavulox/main

Updated with new features
This commit is contained in:
AngelJumbo 2022-10-17 10:10:25 -05:00 committed by GitHub
commit 8075c76e6c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

101
lavat.c
View File

@ -6,20 +6,20 @@
#include <string.h>
#include <time.h>
#include <unistd.h>
typedef struct ball {
#include <stdbool.h>
typedef struct {
int x;
int y;
int dx;
int dy;
} Ball;
static char *custom = NULL;
static short color = TB_DEFAULT;
static int nballs = 10;
static short speedMult = 1;
static short rim = 0;
static float radius = 100;
static bool ova = false;
int parse_options(int argc, char *argv[]);
void print_help();
@ -32,7 +32,7 @@ int main(int argc, char *argv[]) {
rim = 0;
time_t t;
Ball *balls = (Ball *)malloc(sizeof(Ball) * nballs);
Ball *balls = malloc(sizeof(Ball) * nballs);
struct tb_event event = {0};
@ -85,26 +85,71 @@ int main(int argc, char *argv[]) {
(y - balls[k].y) * (y - balls[k].y)));
}
}
if (sum[0] > radius) {
if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "");
} else {
tb_printf(i, j, color | TB_BOLD, 0, "");
}
} else if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "");
}
if (rim) {
if (sum[0] > innerRadius) {
if (sum[1] > innerRadius) {
tb_printf(i, j, color, 0, "");
if (ova) {
if (sum[0] > radius) {
if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "%e");
} else {
tb_printf(i, j, color | TB_BOLD, color, "");
tb_printf(i, j, color | TB_BOLD, 0, "%e");
}
} else if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "%e");
}
if (rim) {
if (sum[0] > innerRadius) {
if (sum[1] > innerRadius) {
tb_printf(i, j, color, 0, "%e");
} else {
tb_printf(i, j, color | TB_BOLD, color, "%e");
}
} else if (sum[1] > innerRadius) {
tb_printf(i, j, color | TB_BOLD, color, "%e");
}
}
} else if (!custom) {
if (sum[0] > radius) {
if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "");
} else {
tb_printf(i, j, color | TB_BOLD, 0, "");
}
} else if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, "");
}
if (rim) {
if (sum[0] > innerRadius) {
if (sum[1] > innerRadius) {
tb_printf(i, j, color, 0, "");
} else {
tb_printf(i, j, color | TB_BOLD, color, "");
}
} else if (sum[1] > innerRadius) {
tb_printf(i, j, color | TB_BOLD, color, "");
}
}
} else {
if (sum[0] > radius) {
if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, custom);
} else {
tb_printf(i, j, color | TB_BOLD, 0, custom);
}
} else if (sum[1] > radius) {
tb_printf(i, j, color | TB_BOLD, 0, custom);
}
if (rim) {
if (sum[0] > innerRadius) {
if (sum[1] > innerRadius) {
tb_printf(i, j, color, 0, custom);
} else {
tb_printf(i, j, color | TB_BOLD, color, custom);
}
} else if (sum[1] > innerRadius) {
tb_printf(i, j, color | TB_BOLD, color, custom);
}
} else if (sum[1] > innerRadius) {
tb_printf(i, j, color | TB_BOLD, color, "");
}
}
}
@ -128,7 +173,7 @@ int parse_options(int argc, char *argv[]) {
if (argc == 1)
return 1;
int c;
while ((c = getopt(argc, argv, ":c:s:r:R:b:h")) != -1) {
while ((c = getopt(argc, argv, ":c:s:r:R:b:F:th")) != -1) {
switch (c) {
case 'c':
if (strcmp(optarg, "red") == 0) {
@ -179,6 +224,12 @@ int parse_options(int argc, char *argv[]) {
return 0;
}
break;
case 'F':
custom = optarg;
break;
case 't':
ova = true;
break;
case 'h':
print_help();
return 0;
@ -211,6 +262,8 @@ void print_help() {
" This option does not work with the default color\n"
" -b NBALLS Set the number of metaballs in the simulation, from "
"2 to 20. (default: 10)\n"
" -F CHARS Allows for a custom set of chars to be used\n"
" -t Toggles a 3d appearance\n"
" -h Print help.\n"
"From a tty the rim will not work well.\n");
}