mirror of
https://github.com/kiedtl/fire.git
synced 2024-11-15 20:46:38 +00:00
partial refactor with termbox_next
This commit is contained in:
parent
03cc3bc723
commit
4ed14729d8
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[submodule "sub/termbox_next"]
|
||||||
|
path = sub/termbox_next
|
||||||
|
url = https://github.com/cylgom/termbox_next
|
63
args.h
63
args.h
@ -1,63 +0,0 @@
|
|||||||
//
|
|
||||||
// Copy me if you can.
|
|
||||||
// by 20h
|
|
||||||
//
|
|
||||||
// Copied by kiedtl
|
|
||||||
// on 2019-12-11 1516
|
|
||||||
//
|
|
||||||
|
|
||||||
// This file is was proudly stol^Hborrowed
|
|
||||||
// from the st project and is copyright all
|
|
||||||
// st contributors. View the LICENSE at:
|
|
||||||
// https://git.suckless.org/st/file/LICENSE.html
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef ARGS_INCLUDED
|
|
||||||
#define ARGS_INCLUDED
|
|
||||||
#include "bool.h"
|
|
||||||
|
|
||||||
extern char *argv0;
|
|
||||||
|
|
||||||
//typedef struct Options {
|
|
||||||
//} Options;
|
|
||||||
|
|
||||||
/* use main(int argc, char *argv[]) */
|
|
||||||
#define ARGBEGIN for (argv0 = *argv, argv++, argc--;\
|
|
||||||
argv[0] && argv[0][0] == '-'\
|
|
||||||
&& argv[0][1];\
|
|
||||||
argc--, argv++) {\
|
|
||||||
char argc_;\
|
|
||||||
char **argv_;\
|
|
||||||
int brk_;\
|
|
||||||
if (argv[0][1] == '-' && argv[0][2] == '\0') {\
|
|
||||||
argv++;\
|
|
||||||
argc--;\
|
|
||||||
break;\
|
|
||||||
}\
|
|
||||||
int i_;\
|
|
||||||
for (i_ = 1, brk_ = 0, argv_ = argv;\
|
|
||||||
argv[0][i_] && !brk_;\
|
|
||||||
i_++) {\
|
|
||||||
if (argv_ != argv)\
|
|
||||||
break;\
|
|
||||||
argc_ = argv[0][i_];\
|
|
||||||
switch (argc_)
|
|
||||||
|
|
||||||
#define ARGEND }\
|
|
||||||
}
|
|
||||||
|
|
||||||
#define ARGC() argc_
|
|
||||||
|
|
||||||
#define EARGF(x) ((argv[0][i_+1] == '\0' && argv[1] == NULL)?\
|
|
||||||
((x), abort(), (char *)0) :\
|
|
||||||
(brk_ = 1, (argv[0][i_+1] != '\0')?\
|
|
||||||
(&argv[0][i_+1]) :\
|
|
||||||
(argc--, argv++, argv[0])))
|
|
||||||
|
|
||||||
#define ARGF() ((argv[0][i_+1] == '\0' && argv[1] == NULL)?\
|
|
||||||
(char *)0 :\
|
|
||||||
(brk_ = 1, (argv[0][i_+1] != '\0')?\
|
|
||||||
(&argv[0][i_+1]) :\
|
|
||||||
(argc--, argv++, argv[0])))
|
|
||||||
|
|
||||||
#endif
|
|
86
main.c
86
main.c
@ -3,58 +3,58 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/ioctl.h>
|
|
||||||
|
|
||||||
#define BOOL unsigned char
|
#include "termbox.h"
|
||||||
#define TRUE 1
|
#include "bool.h"
|
||||||
#define FALSE 0
|
#include "outp.h"
|
||||||
#define PRINT(...) fprintf(stderr, __VA_ARGS__);
|
#include "type.h"
|
||||||
|
|
||||||
// I miss the Rust type system :(
|
#define STEPS 13
|
||||||
typedef uint8_t u8;
|
|
||||||
typedef uint16_t u16;
|
|
||||||
typedef uint32_t u32;
|
|
||||||
|
|
||||||
#if UINTPTR_MAX == 0xffff
|
|
||||||
typedef uint16_t usize;
|
|
||||||
#elif UINTPTR_MAX == 0xffffffff
|
|
||||||
typedef uint32_t usize;
|
|
||||||
#elif UINTPTR_MAX == 0xffffffffffffffff
|
|
||||||
typedef uint64_t usize;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
char esc = (char) 27;
|
|
||||||
usize width;
|
|
||||||
usize height;
|
|
||||||
usize palette[] = { 0x00, 0xff0000, 0xff6611, 0xffff66, 0xffffff };
|
|
||||||
usize *pixels;
|
|
||||||
|
|
||||||
|
void init ( struct term_buf buf );
|
||||||
void dofire ( void );
|
void dofire ( void );
|
||||||
void draw ( void );
|
void draw ( void );
|
||||||
|
|
||||||
int
|
int
|
||||||
main ( void )
|
main ( void )
|
||||||
{
|
{
|
||||||
// populate width and height
|
// initialize termbox
|
||||||
struct winsize w;
|
tb_init();
|
||||||
ioctl(0, TIOCGWINSZ, &w);
|
tb_select_output_mode(TB_OUTPUT_NORMAL);
|
||||||
|
tb_clear();
|
||||||
|
|
||||||
width = w.ws_row;
|
struct term_buf buf;
|
||||||
height = w.ws_col;
|
draw_init(&buf);
|
||||||
|
|
||||||
pixels = (usize*) calloc((width * height), sizeof(usize));
|
// initialize drawing
|
||||||
|
|
||||||
// init pixels
|
|
||||||
for (usize i = 0; i < width; i++)
|
|
||||||
{
|
|
||||||
pixels[((width * height) - width) + i] = palette[4];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
draw();
|
||||||
dofire();
|
dofire();
|
||||||
|
|
||||||
|
// cleanup termbox
|
||||||
|
tb_shutdown();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
init ( struct term_buf buf )
|
||||||
|
{
|
||||||
|
buf->init_width = buf->width;
|
||||||
|
buf->init_height = buf->height;
|
||||||
|
|
||||||
|
usize len = buf->width * buf->height;
|
||||||
|
buf->tmp_buf = malloc(len);
|
||||||
|
len -= buf->width;
|
||||||
|
|
||||||
|
if (buf->tmp_buf == NULL)
|
||||||
|
PRINT("fire: error: unable to malloc() memory for buffer\n");
|
||||||
|
|
||||||
|
memset(buf->tmp_buf, 0, len);
|
||||||
|
memset(buf->tmp_buf + len, STEPS - 1, buf->width);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
dofire ( void )
|
dofire ( void )
|
||||||
{
|
{
|
||||||
@ -63,14 +63,19 @@ dofire ( void )
|
|||||||
for (usize y = 0; y < height; y++)
|
for (usize y = 0; y < height; y++)
|
||||||
{
|
{
|
||||||
usize src = y * width + x;
|
usize src = y * width + x;
|
||||||
usize random = (rand() % 7) & 3;
|
usize random = 0;//(rand() % 7) & 3;
|
||||||
usize dest = src - random + 1;
|
usize dest = src - random + 1;
|
||||||
usize color;
|
usize color;
|
||||||
|
|
||||||
if (width > dest ) dest = 0;
|
if (width > dest ) dest = 0;
|
||||||
else dest -= width;
|
else dest -= width;
|
||||||
|
|
||||||
pixels[dest] = pixels[src] - (random & 1);
|
color = pixels[src];
|
||||||
|
|
||||||
|
if (color == 0 || color == (usize) NULL)
|
||||||
|
pixels[(src - width) % ((width * height) - 1)] = palette[0];
|
||||||
|
else
|
||||||
|
pixels[(dest - width) % ((width * height) - 1)] = pixels[src] - (random & 1);
|
||||||
draw();
|
draw();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -83,11 +88,14 @@ draw ( void )
|
|||||||
PRINT("%c[2J", esc);
|
PRINT("%c[2J", esc);
|
||||||
|
|
||||||
// draw pixels onto screen
|
// draw pixels onto screen
|
||||||
for (usize x = 0; x < width; x++)
|
for (usize y = 0; y < height; y++)
|
||||||
{
|
{
|
||||||
for (usize y = 0; y < height; y++)
|
for (usize x = 0; x < width; x++)
|
||||||
{
|
{
|
||||||
usize color = pixels[y * width + x];
|
usize color = pixels[y * width + x];
|
||||||
|
if (color == (usize) NULL) continue;
|
||||||
|
|
||||||
|
// extract RGB value from color
|
||||||
u8 blue = color % 256;
|
u8 blue = color % 256;
|
||||||
u8 green = ((color - blue) / 256) % 256;
|
u8 green = ((color - blue) / 256) % 256;
|
||||||
u8 red = ((color - blue) / (int)pow((double)256, (double)2))-(green / 256);
|
u8 red = ((color - blue) / (int)pow((double)256, (double)2))-(green / 256);
|
||||||
|
15
makefile
15
makefile
@ -8,8 +8,13 @@ NAME = fire
|
|||||||
WARNING = -Wall -Wextra -pedantic -Wmissing-prototypes \
|
WARNING = -Wall -Wextra -pedantic -Wmissing-prototypes \
|
||||||
-Wold-style-definition -Werror
|
-Wold-style-definition -Werror
|
||||||
|
|
||||||
|
SRCDIR = src
|
||||||
|
SUBDIR = sub
|
||||||
|
|
||||||
|
INC = -I$(SUBDIR)/termbox_next/
|
||||||
|
|
||||||
CC = clang
|
CC = clang
|
||||||
CFLAGS = -g -std=c99 $(WARNING)
|
CFLAGS = -g -std=c99 $(WARNING) $(INC)
|
||||||
LDFLAGS = -fuse-ld=lld
|
LDFLAGS = -fuse-ld=lld
|
||||||
|
|
||||||
SRC = main.c
|
SRC = main.c
|
||||||
@ -18,14 +23,14 @@ OBJ = $(SRC:.c=.o)
|
|||||||
all: $(NAME)
|
all: $(NAME)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f $(NAME) $(OBJ)
|
rm -f $(SRCDIR)/$(NAME) $(SRCDIR)/$(OBJ)
|
||||||
|
|
||||||
.c.o:
|
.c.o:
|
||||||
@echo "\tCC\t\t$@"
|
@echo "\tCC\t\t$@"
|
||||||
@$(CC) $(CFLAGS) -c $<
|
@$(CC) $(CFLAGS) -c $< -o $@
|
||||||
|
|
||||||
$(NAME): $(OBJ)
|
$(NAME): $(SRCDIR)/$(OBJ)
|
||||||
@echo "\tLD\t\t$(NAME)"
|
@echo "\tLD\t\t$(NAME)"
|
||||||
@$(CC) -o $@ $^ $(CFLAGS) $(LDFLAGS)
|
@$(CC) -o $(SRCDIR)/$@ $^ $(CFLAGS) $(LDFLAGS)
|
||||||
|
|
||||||
.PHONY: all clean
|
.PHONY: all clean
|
||||||
|
16
src/bool.h
Normal file
16
src/bool.h
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
//
|
||||||
|
// bool.h: defined the boolean type.
|
||||||
|
// this file is part of the LPTSTR common C header collection, and
|
||||||
|
// is licensed under the MIT license.
|
||||||
|
// (c) Kied Llaentenn and LPTSTR contributors.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef BOOL_INCLUDED
|
||||||
|
#define BOOL_INCLUDED
|
||||||
|
|
||||||
|
#define TRUE 1
|
||||||
|
#define FALSE 0
|
||||||
|
|
||||||
|
typedef char bool
|
||||||
|
|
||||||
|
#endif
|
109
src/main.c
Normal file
109
src/main.c
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
#include <math.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
|
||||||
|
#define BOOL unsigned char
|
||||||
|
#define TRUE 1
|
||||||
|
#define FALSE 0
|
||||||
|
#define PRINT(...) fprintf(stderr, __VA_ARGS__);
|
||||||
|
|
||||||
|
// I miss the Rust type system :(
|
||||||
|
typedef uint8_t u8;
|
||||||
|
typedef uint16_t u16;
|
||||||
|
typedef uint32_t u32;
|
||||||
|
|
||||||
|
#if UINTPTR_MAX == 0xffff
|
||||||
|
typedef uint16_t usize;
|
||||||
|
#elif UINTPTR_MAX == 0xffffffff
|
||||||
|
typedef uint32_t usize;
|
||||||
|
#elif UINTPTR_MAX == 0xffffffffffffffff
|
||||||
|
typedef uint64_t usize;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
char esc = (char) 27;
|
||||||
|
usize width;
|
||||||
|
usize height;
|
||||||
|
usize palette[] = { 0x00, 0xff0000, 0xff6611, 0xffff66, 0xffffff };
|
||||||
|
usize *pixels;
|
||||||
|
|
||||||
|
void dofire ( void );
|
||||||
|
void draw ( void );
|
||||||
|
|
||||||
|
int
|
||||||
|
main ( void )
|
||||||
|
{
|
||||||
|
// populate width and height
|
||||||
|
struct winsize w;
|
||||||
|
ioctl(0, TIOCGWINSZ, &w);
|
||||||
|
|
||||||
|
width = w.ws_col;
|
||||||
|
height = w.ws_row;
|
||||||
|
|
||||||
|
pixels = (usize*) calloc((width * height), sizeof(usize));
|
||||||
|
|
||||||
|
// init pixels
|
||||||
|
for (usize c = 0; c < (width * height); c++) pixels[c] = (usize) NULL;
|
||||||
|
for (usize i = 0; i < width; i++)
|
||||||
|
{
|
||||||
|
pixels[((width * (height - 1)) - width) + i] = palette[4];
|
||||||
|
}
|
||||||
|
|
||||||
|
draw();
|
||||||
|
dofire();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
dofire ( void )
|
||||||
|
{
|
||||||
|
for (usize x = 0; x < width; x++)
|
||||||
|
{
|
||||||
|
for (usize y = 0; y < height; y++)
|
||||||
|
{
|
||||||
|
usize src = y * width + x;
|
||||||
|
usize random = 0;//(rand() % 7) & 3;
|
||||||
|
usize dest = src - random + 1;
|
||||||
|
usize color;
|
||||||
|
|
||||||
|
if (width > dest ) dest = 0;
|
||||||
|
else dest -= width;
|
||||||
|
|
||||||
|
color = pixels[src];
|
||||||
|
|
||||||
|
if (color == 0 || color == (usize) NULL)
|
||||||
|
pixels[(src - width) % ((width * height) - 1)] = palette[0];
|
||||||
|
else
|
||||||
|
pixels[(dest - width) % ((width * height) - 1)] = pixels[src] - (random & 1);
|
||||||
|
draw();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
draw ( void )
|
||||||
|
{
|
||||||
|
// clear screen
|
||||||
|
PRINT("%c[2J", esc);
|
||||||
|
|
||||||
|
// draw pixels onto screen
|
||||||
|
for (usize y = 0; y < height; y++)
|
||||||
|
{
|
||||||
|
for (usize x = 0; x < width; x++)
|
||||||
|
{
|
||||||
|
usize color = pixels[y * width + x];
|
||||||
|
if (color == (usize) NULL) continue;
|
||||||
|
|
||||||
|
// extract RGB value from color
|
||||||
|
u8 blue = color % 256;
|
||||||
|
u8 green = ((color - blue) / 256) % 256;
|
||||||
|
u8 red = ((color - blue) / (int)pow((double)256, (double)2))-(green / 256);
|
||||||
|
|
||||||
|
PRINT("%c[48;2;%i;%i;%im %c[0m", esc, red, blue, green, esc);
|
||||||
|
}
|
||||||
|
PRINT("\n");
|
||||||
|
}
|
||||||
|
}
|
6
src/outp.h
Normal file
6
src/outp.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef OUTP_H
|
||||||
|
#define OUTP_H
|
||||||
|
|
||||||
|
#define PRINT(...) fprintf(stderr, __VA_ARGS__);
|
||||||
|
|
||||||
|
#endif
|
40
src/type.h
Normal file
40
src/type.h
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
//
|
||||||
|
// type.h: defines integer types.
|
||||||
|
// this file is part of the LPTSTR common C header collection, and
|
||||||
|
// is licensed under the MIT license.
|
||||||
|
// (c) Kied Llaentenn and LPTSTR contributors.
|
||||||
|
//
|
||||||
|
|
||||||
|
// why?
|
||||||
|
// I miss the Rust type system :P
|
||||||
|
|
||||||
|
#ifndef TYPE_H
|
||||||
|
#define TYPE_H
|
||||||
|
|
||||||
|
typedef uint8_t u8;
|
||||||
|
typedef uint16_t u16;
|
||||||
|
typedef uint32_t u32;
|
||||||
|
typedef uint64_t u64;
|
||||||
|
|
||||||
|
typedef int8_t i8;
|
||||||
|
typedef int16_t i16;
|
||||||
|
typedef int32_t i32;
|
||||||
|
typedef int64_t i64;
|
||||||
|
|
||||||
|
#if UINTPTR_MAX == 0xffff
|
||||||
|
typedef uint16_t usize;
|
||||||
|
#elif UINTPTR_MAX == 0xffffffff
|
||||||
|
typedef uint32_t usize;
|
||||||
|
#elif UINTPTR_MAX == 0xffffffffffffffff
|
||||||
|
typedef uint64_t usize;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if INTPTR_MAX == 0xffff
|
||||||
|
typedef int16_t isize;
|
||||||
|
#elif INTPTR_MAX == 0xffffffff
|
||||||
|
typedef int32_t isize;
|
||||||
|
#elif INTPTR_MAX == 0xffffffffffffffff
|
||||||
|
typedef int64_t isize;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
1
sub/termbox_next
Submodule
1
sub/termbox_next
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 2312da153e44face7bb45aa2798ec284289c17ca
|
Loading…
Reference in New Issue
Block a user