X-Git-Url: https://git.bzium.org/embe/choinka.git/blobdiff_plain/7107640dca11d91726c59920b368e66aa4f2f72e..HEAD:/choinka.c?ds=sidebyside diff --git a/choinka.c b/choinka.c index 26f6c43..4865cff 100644 --- a/choinka.c +++ b/choinka.c @@ -1,10 +1,14 @@ +#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 @@ -19,7 +23,7 @@ typedef struct { int kolor; } atrybut; -atrybut const bombki[] = { +static atrybut const bombki[] = { {A_POGRUBIONY, KOLOR_CZERWONY}, {A_POGRUBIONY, KOLOR_NIEBIESKI}, {A_POGRUBIONY, KOLOR_BRAZOWY}, @@ -27,31 +31,32 @@ atrybut const bombki[] = { {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, KOLOR_ZIELONY}; -atrybut const podstawa = {0, KOLOR_BRAZOWY}; -atrybut const podpis = {A_POGRUBIONY, KOLOR_CZERWONY}; -atrybut const gwiazdka = {A_POGRUBIONY, KOLOR_BRAZOWY}; +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" @@ -62,7 +67,7 @@ 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; @@ -71,11 +76,14 @@ void ustaw(atrybut const* attr) if ((attr->attr & A_POGRUBIONY) != 0) { putp(enter_bold_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; @@ -86,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);