2011-03-25 22:15:26 +01:00
|
|
|
/** @file
|
|
|
|
Implements statusbar interface functions.
|
|
|
|
|
2018-06-27 15:13:38 +02:00
|
|
|
Copyright (c) 2005 - 2018, Intel Corporation. All rights reserved. <BR>
|
2019-04-04 01:07:06 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#include "EditStatusBar.h"
|
|
|
|
#include "UefiShellDebug1CommandsLib.h"
|
|
|
|
|
2021-12-05 23:54:13 +01:00
|
|
|
CHAR16 *StatusString;
|
|
|
|
BOOLEAN StatusBarNeedRefresh;
|
|
|
|
BOOLEAN StatusStringChanged;
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
Initialization function for Status Bar.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The operation was successful.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES A memory allocation failed.
|
|
|
|
@sa StatusBarSetStatusString
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
StatusBarInit (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// initialize the statusbar
|
|
|
|
//
|
|
|
|
StatusString = NULL;
|
|
|
|
StatusBarNeedRefresh = TRUE;
|
|
|
|
StatusStringChanged = FALSE;
|
|
|
|
|
|
|
|
//
|
|
|
|
// status string set to ""
|
|
|
|
//
|
|
|
|
return (StatusBarSetStatusString (L""));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Cleanup function for the status bar.
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
StatusBarCleanup (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// free the status string and backvar's status string
|
|
|
|
//
|
|
|
|
SHELL_FREE_NON_NULL (StatusString);
|
|
|
|
}
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:13 +01:00
|
|
|
UINT32 Foreground : 4;
|
|
|
|
UINT32 Background : 3;
|
2011-03-25 22:15:26 +01:00
|
|
|
} STATUS_BAR_COLOR_ATTRIBUTES;
|
|
|
|
|
|
|
|
typedef union {
|
2021-12-05 23:54:13 +01:00
|
|
|
STATUS_BAR_COLOR_ATTRIBUTES Colors;
|
|
|
|
UINTN Data;
|
2011-03-25 22:15:26 +01:00
|
|
|
} STATUS_BAR_COLOR_UNION;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Cause the status bar to refresh it's printing on the screen.
|
|
|
|
|
2018-06-27 15:13:38 +02:00
|
|
|
@param[in] EditorFirst TRUE to indicate the first launch of the editor.
|
2011-03-25 22:15:26 +01:00
|
|
|
FALSE otherwise.
|
|
|
|
@param[in] LastRow LastPrintable row.
|
|
|
|
@param[in] LastCol Last printable column.
|
|
|
|
@param[in] FileRow Row in the file.
|
|
|
|
@param[in] FileCol Column in the file.
|
|
|
|
@param[in] InsertMode TRUE to indicate InsertMode. FALSE otherwise.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The operation was successful.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
StatusBarRefresh (
|
|
|
|
IN BOOLEAN EditorFirst,
|
|
|
|
IN UINTN LastRow,
|
|
|
|
IN UINTN LastCol,
|
|
|
|
IN UINTN FileRow,
|
|
|
|
IN UINTN FileCol,
|
|
|
|
IN BOOLEAN InsertMode
|
|
|
|
)
|
|
|
|
{
|
|
|
|
STATUS_BAR_COLOR_UNION Orig;
|
|
|
|
STATUS_BAR_COLOR_UNION New;
|
|
|
|
|
|
|
|
if (!StatusStringChanged && StatusBarNeedRefresh) {
|
|
|
|
StatusBarSetStatusString (L"\0");
|
|
|
|
}
|
2021-12-05 23:54:13 +01:00
|
|
|
|
2011-03-25 22:15:26 +01:00
|
|
|
//
|
|
|
|
// when it's called first time after editor launch, so refresh is mandatory
|
|
|
|
//
|
|
|
|
if (!StatusBarNeedRefresh && !StatusStringChanged) {
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// back up the screen attributes
|
|
|
|
//
|
|
|
|
Orig.Data = gST->ConOut->Mode->Attribute;
|
2013-06-12 00:07:03 +02:00
|
|
|
New.Data = 0;
|
2014-07-25 20:46:23 +02:00
|
|
|
New.Colors.Foreground = Orig.Colors.Background & 0xF;
|
|
|
|
New.Colors.Background = Orig.Colors.Foreground & 0x7;
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
gST->ConOut->EnableCursor (gST->ConOut, FALSE);
|
2014-07-25 20:46:23 +02:00
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, New.Data & 0x7F);
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// clear status bar
|
|
|
|
//
|
2011-07-20 22:10:45 +02:00
|
|
|
EditorClearLine (LastRow, LastCol, LastRow);
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// print row, column fields
|
|
|
|
//
|
2021-12-05 23:54:13 +01:00
|
|
|
if ((FileRow != (UINTN)(-1)) && (FileCol != (UINTN)(-1))) {
|
2011-04-12 23:55:07 +02:00
|
|
|
ShellPrintEx (
|
|
|
|
0,
|
2011-07-20 22:10:45 +02:00
|
|
|
(INT32)(LastRow) - 1,
|
|
|
|
L" %d,%d %s",
|
2011-04-12 23:55:07 +02:00
|
|
|
FileRow,
|
|
|
|
FileCol,
|
|
|
|
StatusString
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
ShellPrintEx (
|
|
|
|
0,
|
2011-07-20 22:10:45 +02:00
|
|
|
(INT32)(LastRow) - 1,
|
2011-04-12 23:55:07 +02:00
|
|
|
L" %s",
|
|
|
|
StatusString
|
|
|
|
);
|
|
|
|
}
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// print insert mode field
|
|
|
|
//
|
|
|
|
if (InsertMode) {
|
2011-07-20 22:10:45 +02:00
|
|
|
ShellPrintEx ((INT32)(LastCol) - 21, (INT32)(LastRow) - 1, L"|%s| Help: Ctrl-E", L"INS");
|
2011-03-25 22:15:26 +01:00
|
|
|
} else {
|
2011-07-20 22:10:45 +02:00
|
|
|
ShellPrintEx ((INT32)(LastCol) - 21, (INT32)(LastRow) - 1, L"|%s| Help: Ctrl-E", L"OVR");
|
2011-03-25 22:15:26 +01:00
|
|
|
}
|
2021-12-05 23:54:13 +01:00
|
|
|
|
2011-03-25 22:15:26 +01:00
|
|
|
//
|
|
|
|
// restore the old screen attributes
|
|
|
|
//
|
|
|
|
gST->ConOut->SetAttribute (gST->ConOut, Orig.Data);
|
|
|
|
|
|
|
|
//
|
|
|
|
// restore position in edit area
|
|
|
|
//
|
|
|
|
gST->ConOut->EnableCursor (gST->ConOut, TRUE);
|
|
|
|
|
2021-12-05 23:54:13 +01:00
|
|
|
StatusBarNeedRefresh = FALSE;
|
|
|
|
StatusStringChanged = FALSE;
|
2011-03-25 22:15:26 +01:00
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the status string text part.
|
|
|
|
|
|
|
|
@param[in] Str The string to use.
|
|
|
|
|
|
|
|
@retval EFI_SUCCESS The operation was successful.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES A memory allocation failed.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
StatusBarSetStatusString (
|
2021-12-05 23:54:13 +01:00
|
|
|
IN CHAR16 *Str
|
2011-03-25 22:15:26 +01:00
|
|
|
)
|
|
|
|
{
|
|
|
|
StatusStringChanged = TRUE;
|
|
|
|
|
|
|
|
//
|
|
|
|
// free the old status string
|
|
|
|
//
|
|
|
|
SHELL_FREE_NON_NULL (StatusString);
|
|
|
|
StatusString = CatSPrint (NULL, L"%s", Str);
|
|
|
|
if (StatusString == NULL) {
|
|
|
|
return EFI_OUT_OF_RESOURCES;
|
|
|
|
}
|
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Function to retrieve the current status string.
|
|
|
|
|
|
|
|
@return The string that is used.
|
|
|
|
**/
|
2021-12-05 23:54:13 +01:00
|
|
|
CONST CHAR16 *
|
2011-03-25 22:15:26 +01:00
|
|
|
StatusBarGetString (
|
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return (StatusString);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Function to set the need refresh boolean to TRUE.
|
|
|
|
**/
|
|
|
|
VOID
|
2021-12-05 23:54:13 +01:00
|
|
|
StatusBarSetRefresh (
|
2011-03-25 22:15:26 +01:00
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
StatusBarNeedRefresh = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Function to get the need refresh boolean to TRUE.
|
|
|
|
|
|
|
|
@retval TRUE The status bar needs to be refreshed.
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
2021-12-05 23:54:13 +01:00
|
|
|
StatusBarGetRefresh (
|
2011-03-25 22:15:26 +01:00
|
|
|
VOID
|
|
|
|
)
|
|
|
|
{
|
|
|
|
return (StatusBarNeedRefresh);
|
|
|
|
}
|