|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [UNIKRAFT PATCH 5/5] lib/ukboot: ANSI-colored Unikraft banners
Provide two ANSI-colored versions (blue, gray) for each of the
"Powered by" banners.
Signed-off-by: Simon Kuenzer <simon.kuenzer@xxxxxxxxx>
---
lib/ukboot/Config.uk | 36 +++++++++++++++
lib/ukboot/banner.c | 106 +++++++++++++++++++++++++++++++++----------
2 files changed, 118 insertions(+), 24 deletions(-)
diff --git a/lib/ukboot/Config.uk b/lib/ukboot/Config.uk
index 55550fe3..57cf1e36 100644
--- a/lib/ukboot/Config.uk
+++ b/lib/ukboot/Config.uk
@@ -24,17 +24,53 @@ if LIBUKBOOT
config LIBUKBOOT_BANNER_POWEREDBY
bool "Powered by Unikraft"
+ config LIBUKBOOT_BANNER_POWEREDBY_ANSI
+ bool "Powered by Unikraft (blue, ANSI)"
+ help
+ Please make sure that your console display supports
+ ANSI colors
+
+ config LIBUKBOOT_BANNER_POWEREDBY_ANSI2
+ bool "Powered by Unikraft (gray, ANSI)"
+ help
+ Please make sure that your console display supports
+ ANSI colors
+
config LIBUKBOOT_BANNER_POWEREDBY_EA
bool "Powered by Unikraft (ASCII)"
help
Please make sure that your console display supports
extended ASCII characters
+ config LIBUKBOOT_BANNER_POWEREDBY_EAANSI
+ bool "Powered by Unikraft (ASCII, blue, ANSI)"
+ help
+ Please make sure that your console display supports
+ extended ASCII characters and ANSI colors
+
+ config LIBUKBOOT_BANNER_POWEREDBY_EAANSI2
+ bool "Powered by Unikraft (ASCII, gray, ANSI)"
+ help
+ Please make sure that your console display supports
+ extended ASCII characters and ANSI colors
+
config LIBUKBOOT_BANNER_POWEREDBY_U8
bool "Powered by Unikraft (UTF-8)"
help
Please make sure that your console display supports
UTF-8
+
+ config LIBUKBOOT_BANNER_POWEREDBY_U8ANSI
+ bool "Powered by Unikraft (UTF-8, blue, ANSI)"
+ help
+ Please make sure that your console display supports
+ UTF-8 and ANSI colors
+
+ config LIBUKBOOT_BANNER_POWEREDBY_U8ANSI2
+ bool "Powered by Unikraft (UTF-8, gray, ANSI)"
+ help
+ Please make sure that your console display supports
+ UTF-8 and ANSI colors
endchoice
config LIBUKBOOT_MAXNBARGS
diff --git a/lib/ukboot/banner.c b/lib/ukboot/banner.c
index bc45b6aa..16660822 100644
--- a/lib/ukboot/banner.c
+++ b/lib/ukboot/banner.c
@@ -35,38 +35,96 @@
*/
#include <uk/config.h>
+#include <uk/plat/console.h>
#include <stdio.h>
+/*
+ * Color palette
+ */
+#if CONFIG_LIBUKBOOT_BANNER_POWEREDBY_ANSI || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EAANSI || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8ANSI
+/* Blue version (ANSI) */
+#define B_RST UK_ANSI_MOD_RESET
+#define B_TXT UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_WHITE)
+#define B_LTR UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_BLUE)
+#define B_HL0 UK_ANSI_MOD_BOLD UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_RED)
+#define B_HL1 UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_RED)
+#define B_HL2 UK_ANSI_MOD_BOLD UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_BLUE)
+#define B_HL3 UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_BLUE)
+#elif CONFIG_LIBUKBOOT_BANNER_POWEREDBY_ANSI2 || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EAANSI2 || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8ANSI2
+/* Gray version (ANSI) */
+#define B_RST UK_ANSI_MOD_RESET
+#define B_TXT UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_WHITE)
+#define B_LTR UK_ANSI_MOD_BOLD UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_BLACK)
+#define B_HL0 UK_ANSI_MOD_BOLD UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_RED)
+#define B_HL1 UK_ANSI_MOD_RESET UK_ANSI_MOD_COLORFG(UK_ANSI_COLOR_RED)
+#define B_HL2 B_TXT
+#define B_HL3 B_LTR
+#else
+/* No colors */
+#define B_RST ""
+#define B_TXT B_RST
+#define B_LTR B_RST
+#define B_HL0 B_RST
+#define B_HL1 B_RST
+#define B_HL2 B_RST
+#define B_HL3 B_RST
+#endif
+
void print_banner(FILE *out) {
-#if CONFIG_LIBUKBOOT_BANNER_POWEREDBY
- fprintf(out, "Powered by\n");
- fprintf(out, "o. .o _ _ __ _\n");
- fprintf(out, "Oo Oo ___ (_) | __ __ __ _ ' _) :_\n");
- fprintf(out, "oO oO ' _ `| | |/ / _)' _` | |_| _)\n");
- fprintf(out, "oOo oOO| | | | | (| | | (_) | _) :_\n");
- fprintf(out, " OoOoO ._, ._:_:_,\\_._, .__,_:_, \\___)\n");
- fprintf(out, "%39s\n",
+#if CONFIG_LIBUKBOOT_BANNER_POWEREDBY || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_ANSI || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_ANSI2
+ fprintf(out, B_TXT "Powered by\n");
+ fprintf(out, B_HL2 "o" B_HL1 ". " B_HL2 "." B_HL3 "o"
+ B_LTR " _ _ __ _\n");
+ fprintf(out, B_HL0 "O" B_HL2 "o " B_HL1 "O" B_HL0 "o"
+ B_LTR " ___ (_) | __ __ __ _ ' _) :_\n");
+ fprintf(out, B_HL3 "o" B_HL0 "O " B_HL2 "o" B_HL3 "O"
+ B_LTR " ' _ `| | |/ / _)' _` | |_| _)\n");
+ fprintf(out, B_HL1 "o" B_HL2 "Oo " B_HL1 "o" B_HL3 "O" B_HL1 "O"
+ B_LTR "| | | | | (| | | (_) | _) :_\n");
+ fprintf(out, B_HL3 " O" B_HL0 "o" B_HL3 "O" B_HL2 "o" B_HL3 "O "
+ B_LTR "._, ._:_:_,\\_._, .__,_:_, \\___)\n");
+ fprintf(out, B_TXT "%39s" B_RST "\n",
STRINGIFY(UK_CODENAME) " " STRINGIFY(UK_FULLVERSION));
-#elif CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EA
- fprintf(out, "Powered by\n");
- fprintf(out, "\xDF\xFE \xFE\xDC _ _ __ _\n");
- fprintf(out, "\xDF\xFE \xDF\xDC ___ (_) | __ __ __ _ ' _) :_\n");
- fprintf(out, "\xDC\xDF \xDC\xFE ' _ `| | |/ / _)' _` | |_| _)\n");
- fprintf(out, "\xFE\xDF\xFE \xFE\xDC\xDF| | | | | (| | | (_) | _)
:_\n");
- fprintf(out, " \xFE\xDC\xDF\xDC\xFE ._, ._:_:_,\\_._, .__,_:_,
\\___)\n");
- fprintf(out, "%39s\n",
+#elif CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EA || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EAANSI || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_EAANSI2
+ fprintf(out, B_TXT "Powered by\n");
+ fprintf(out, B_HL2 "\xDF" B_HL1 "\xFE " B_HL2 "\xFE" B_HL3 "\xDC"
+ B_LTR " _ _ __ _\n");
+ fprintf(out, B_HL0 "\xDF" B_HL2 "\xFE " B_HL1 "\xDF" B_HL0 "\xDC"
+ B_LTR " ___ (_) | __ __ __ _ ' _) :_\n");
+ fprintf(out, B_HL3 "\xDC" B_HL0 "\xDF " B_HL2 "\xDC" B_HL3 "\xFE"
+ B_LTR " ' _ `| | |/ / _)' _` | |_| _)\n");
+ fprintf(out, B_HL1 "\xFE" B_HL2 "\xDF\xFE " B_HL1 "\xFE" B_HL3 "\xDC"
B_HL1 "\xDF"
+ B_LTR "| | | | | (| | | (_) | _) :_\n");
+ fprintf(out, B_HL3 " \xFE" B_HL0 "\xDC" B_HL3 "\xDF" B_HL2 "\xDC" B_HL3
"\xFE "
+ B_LTR "._, ._:_:_,\\_._, .__,_:_, \\___)\n");
+ fprintf(out, B_TXT "%39s" B_RST "\n",
STRINGIFY(UK_CODENAME) " " STRINGIFY(UK_FULLVERSION));
-#elif CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8
- fprintf(out, "Powered by\n");
- fprintf(out, "■▖ ▖■ _ _ __ _\n");
- fprintf(out, "■▚ ■▞ ___ (_) | __ __ __ _ ´ _) :_\n");
- fprintf(out, "▀■ ■▄ ´ _ `| | |/ / _)´ _` | |_| _)\n");
- fprintf(out, "▄▀▄ ▗▀▄| | | | | (| | | (_) | _) :_\n");
- fprintf(out, " ▚▄■▄▞ ._, ._:_:_,\\_._, .__,_:_, \\___)\n");
- fprintf(out, "%39s\n",
+#elif CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8 || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8ANSI || \
+ CONFIG_LIBUKBOOT_BANNER_POWEREDBY_U8ANSI2
+ fprintf(out, B_TXT "Powered by\n");
+ fprintf(out, B_HL2 "■" B_HL1 "▖ " B_HL2 "▖" B_HL3 "■"
+ B_LTR " _ _ __ _\n");
+ fprintf(out, B_HL0 "■" B_HL2 "▚ " B_HL1 "■" B_HL0 "▞"
+ B_LTR " ___ (_) | __ __ __ _ ´ _) :_\n");
+ fprintf(out, B_HL3 "▀" B_HL0 "■ " B_HL2 "■" B_HL3 "▄"
+ B_LTR " ´ _ `| | |/ / _)´ _` | |_| _)\n");
+ fprintf(out, B_HL1 "▄" B_HL2 "▀▄ " B_HL1 "▗" B_HL3 "▀" B_HL1 "▄"
+ B_LTR "| | | | | (| | | (_) | _) :_\n");
+ fprintf(out, B_HL3 " ▚" B_HL0 "▄" B_HL3 "■" B_HL2 "▄" B_HL3 "▞"
+ B_LTR " ._, ._:_:_,\\_._, .__,_:_, \\___)\n");
+ fprintf(out, B_TXT "%39s" B_RST "\n",
STRINGIFY(UK_CODENAME) " " STRINGIFY(UK_FULLVERSION));
#elif CONFIG_LIBUKBOOT_BANNER_CLASSIC
--
2.20.1
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |