X-Git-Url: https://git.bzium.org/embe/choinka.git/blobdiff_plain/50dda836f33a45ca7ab9d053cf98b49cd68092a3..HEAD:/choinka.c diff --git a/choinka.c b/choinka.c index b10f073..4865cff 100644 --- a/choinka.c +++ b/choinka.c @@ -1,47 +1,62 @@ -#include +#include +#include #include #include #include #include +#include + +#define A_POGRUBIONY (1 << 0) + +#define KOLOR_BRAK -1 +#define KOLOR_CZARNY 0 +#define KOLOR_CZERWONY 1 +#define KOLOR_ZIELONY 2 +#define KOLOR_BRAZOWY 3 +#define KOLOR_NIEBIESKI 4 +#define KOLOR_MAGENTA 5 +#define KOLOR_CYJAN 6 +#define KOLOR_BIALY 7 typedef struct { int attr; int kolor; } atrybut; -atrybut const bombki[] = { - {A_BOLD, COLOR_RED}, - {A_BOLD, COLOR_BLUE}, - {A_BOLD, COLOR_YELLOW}, - {A_BOLD, COLOR_MAGENTA}, - {A_BOLD, COLOR_CYAN}, - {A_BOLD, COLOR_WHITE}, +static atrybut const bombki[] = { + {A_POGRUBIONY, KOLOR_CZERWONY}, + {A_POGRUBIONY, KOLOR_NIEBIESKI}, + {A_POGRUBIONY, KOLOR_BRAZOWY}, + {A_POGRUBIONY, KOLOR_MAGENTA}, + {A_POGRUBIONY, KOLOR_CYJAN}, + {A_POGRUBIONY, KOLOR_BIALY}, }; -int const ile_b = sizeof bombki / sizeof *bombki; +static int const ile_b = sizeof bombki / sizeof *bombki; -atrybut const choinka = {0, COLOR_GREEN}; -atrybut const podstawa = {0, COLOR_YELLOW}; -atrybut const podpis = {A_BOLD, COLOR_RED}; -atrybut const gwiazdka = {A_BOLD, COLOR_YELLOW}; +static atrybut const spacja = {0, KOLOR_BRAK}; +static atrybut const choinka = {0, KOLOR_ZIELONY}; +static atrybut const podstawa = {0, KOLOR_BRAZOWY}; +static atrybut const podpis = {A_POGRUBIONY, KOLOR_CZERWONY}; +static atrybut const gwiazdka = {A_POGRUBIONY, KOLOR_BRAZOWY}; -void inicjuj_rng() +static void inicjuj_rng() { - unsigned ziarno = 0; - FILE* f = fopen("/dev/urandom", "rb"); - if (f != NULL) { - unsigned nowe_ziarno; - if (fread(&nowe_ziarno, sizeof nowe_ziarno, 1, f) == 1) { - ziarno = nowe_ziarno; + bool ok = false; + unsigned ziarno; + int f = open("/dev/urandom", O_RDONLY); + if (f != -1) { + if (read(f, &ziarno, sizeof ziarno) == sizeof ziarno) { + ok = true; } - fclose(f); + close(f); } - if (ziarno == 0) { + if (!ok) { ziarno = time(NULL); } srand(ziarno); } -char const rysunek[] = +static char const rysunek[] = " *\n" " /.\\\n" " /..'\\\n" @@ -52,21 +67,23 @@ char const rysunek[] = " jgs ^^^[_]^^^\n" ; -void ustaw(atrybut const* attr) +static void ustaw(atrybut const* attr) { static atrybut ostatni = {-1, -1}; if (ostatni.attr == attr->attr && ostatni.kolor == attr->kolor) return; ostatni = *attr; - if (attr->attr & A_BOLD) { + putp(exit_attribute_mode); + if ((attr->attr & A_POGRUBIONY) != 0) { putp(enter_bold_mode); - } else { - putp(exit_attribute_mode); } - putp(tparm(set_a_foreground, attr->kolor)); + if (attr->kolor != KOLOR_BRAK) { + putp(tparm(set_a_foreground, attr->kolor)); + } } int main() { + setvbuf(stdout, NULL, _IOFBF, BUFSIZ); inicjuj_rng(); setupterm(NULL, 1, NULL); atrybut const* kolor = &choinka; @@ -77,6 +94,7 @@ int main() if (c >= 'a' && c <= 'z') akt = &podpis; if (c == '.') akt = &bombki[rand() % ile_b]; if (c == '*') akt = &gwiazdka; + if (c == ' ' || c == '\n') akt = &spacja; if (c == ']') kolor = &choinka; ustaw(akt); putchar(c);