forked from rpms/plymouth
114 lines
2.7 KiB
Diff
114 lines
2.7 KiB
Diff
commit d10b3eb6da0521dc1bb0a2a1d62f619a2460d73c
|
|
Author: Ray Strode <rstrode@redhat.com>
|
|
Date: Wed Jul 9 17:36:44 2008 -0400
|
|
|
|
Add debugging feature to restore text palette
|
|
|
|
diff --git a/src/libplybootsplash/ply-window.c b/src/libplybootsplash/ply-window.c
|
|
index 90f9cc6..d718203 100644
|
|
--- a/src/libplybootsplash/ply-window.c
|
|
+++ b/src/libplybootsplash/ply-window.c
|
|
@@ -45,6 +45,7 @@
|
|
#include "ply-logger.h"
|
|
#include "ply-utils.h"
|
|
|
|
+#define KEY_CTRL_P ('\100' ^'P')
|
|
#define KEY_CTRL_T ('\100' ^'T')
|
|
#define KEY_CTRL_U ('\100' ^'U')
|
|
#define KEY_CTRL_W ('\100' ^'W')
|
|
@@ -143,6 +144,40 @@ ply_window_new (int vt_number)
|
|
return window;
|
|
}
|
|
|
|
+static bool
|
|
+ply_window_look_up_color_palette (ply_window_t *window)
|
|
+{
|
|
+ if (ioctl (window->tty_fd, GIO_CMAP, window->color_palette) < 0)
|
|
+ return false;
|
|
+
|
|
+ return true;
|
|
+}
|
|
+
|
|
+static bool
|
|
+ply_window_change_color_palette (ply_window_t *window)
|
|
+{
|
|
+ if (ioctl (window->tty_fd, PIO_CMAP, window->color_palette) < 0)
|
|
+ return false;
|
|
+
|
|
+ return true;
|
|
+}
|
|
+
|
|
+static void
|
|
+ply_window_save_color_palette (ply_window_t *window)
|
|
+{
|
|
+ memcpy (window->original_color_palette, window->color_palette,
|
|
+ TEXT_PALETTE_SIZE);
|
|
+}
|
|
+
|
|
+static void
|
|
+ply_window_restore_color_palette (ply_window_t *window)
|
|
+{
|
|
+ memcpy (window->color_palette, window->original_color_palette,
|
|
+ TEXT_PALETTE_SIZE);
|
|
+
|
|
+ ply_window_change_color_palette (window);
|
|
+}
|
|
+
|
|
static void
|
|
process_backspace (ply_window_t *window)
|
|
{
|
|
@@ -188,6 +223,12 @@ process_keyboard_input (ply_window_t *window,
|
|
{
|
|
switch (key)
|
|
{
|
|
+
|
|
+ case KEY_CTRL_P:
|
|
+ ply_trace ("restore text palette to original value!");
|
|
+ ply_window_restore_color_palette (window);
|
|
+ return;
|
|
+
|
|
case KEY_CTRL_T:
|
|
ply_trace ("toggle text mode!");
|
|
window->should_force_text_mode = !window->should_force_text_mode;
|
|
@@ -362,40 +403,6 @@ ply_window_look_up_geometry (ply_window_t *window)
|
|
return true;
|
|
}
|
|
|
|
-static bool
|
|
-ply_window_look_up_color_palette (ply_window_t *window)
|
|
-{
|
|
- if (ioctl (window->tty_fd, GIO_CMAP, window->color_palette) < 0)
|
|
- return false;
|
|
-
|
|
- return true;
|
|
-}
|
|
-
|
|
-static bool
|
|
-ply_window_change_color_palette (ply_window_t *window)
|
|
-{
|
|
- if (ioctl (window->tty_fd, PIO_CMAP, window->color_palette) < 0)
|
|
- return false;
|
|
-
|
|
- return true;
|
|
-}
|
|
-
|
|
-static void
|
|
-ply_window_save_color_palette (ply_window_t *window)
|
|
-{
|
|
- memcpy (window->original_color_palette, window->color_palette,
|
|
- TEXT_PALETTE_SIZE);
|
|
-}
|
|
-
|
|
-static void
|
|
-ply_window_restore_color_palette (ply_window_t *window)
|
|
-{
|
|
- memcpy (window->color_palette, window->original_color_palette,
|
|
- TEXT_PALETTE_SIZE);
|
|
-
|
|
- ply_window_change_color_palette (window);
|
|
-}
|
|
-
|
|
bool
|
|
ply_window_open (ply_window_t *window)
|
|
{
|