Awesome
Limine Terminal
Based on limine bootloader and flanterm
Building
First of all, clone this repo with --recursive
flag to download terminal submodule
Meson
dependency('limine_terminal')
Everything else
- Add directory
src
to your include path (optionallyfonts
) - Compile these files:
src/flanterm/backends/fb.c
src/flanterm/flanterm.c
src/stb_image.c
src/image.c
src/term.c
Usage
#include <limine_terminal/term.h>
void *term_alloc(size_t size) { /* allocate memory */ }
void *term_realloc(void *oldptr, size_t size) { /* reallocate memory. used for stb_image */ }
// size is the same value that was passed to term_alloc()
void term_free(void *ptr, size_t size) { /* free memory with size */ }
void term_freensz(void *ptr) { /* free memory. used for stb_image */ }
void *term_memcpy(void *dest, const void *src, size_t size) { /* memcpy */ }
void *term_memset(void *dest, int val, size_t count) { /* memset */ }
struct image_t *image = image_open(/* Background file address (BMP, PNG, or JPEG) */, /* Background file size */);
struct framebuffer_t frm =
{
/* Address */
/* Width */
/* Height */
/* Pitch */
/* Red mask size or TERM_MASK_SIZE */
/* Red mask shift or TERM_MASK_SHIFT_R */
/* Green mask size or TERM_MASK_SIZE */
/* Green mask shift or TERM_MASK_SHIFT_G */
/* Blue mask size or TERM_MASK_SIZE */
/* Blue mask shift or TERM_MASK_SHIFT_B */
};
struct font_t font =
{
/* Address */,
/* Width */,
/* Height */,
TERM_FONT_SPACING,
TERM_FONT_SCALE_X,
TERM_FONT_SCALE_Y,
};
struct style_t style =
{
TERM_ANSI_COLOURS,
TERM_ANSI_BRIGHT_COLOURS,
TERM_BACKGROUND,
TERM_FOREGROUND_BRIGHT,
TERM_BACKGROUND_BRIGHT,
TERM_FOREGROUND_BRIGHT,
TERM_MARGIN,
TERM_MARGIN_GRADIENT
};
struct background_t back =
{
image, /* You can set this to NULL to disable background */
/* IMAGE_CENTERED/STRETCHED/TILED */,
TERM_BACKDROP
};
term_t *term = term_init(frm, font, style, back);
term_write(term, "abcdefg", 7);
term->clear(term, true /* Move the cursor or not */);
term_write(term, "Hello, World!", 13);
size_t x, y;
term->get_cursor_pos(term, &x, &y);
/* ... */