2011-10-08 04:44:59 +02:00
|
|
|
/** @file
|
|
|
|
Implementation of translation upon PC ANSI.
|
|
|
|
|
|
|
|
Copyright (c) 2006 - 2008, Intel Corporation. All rights reserved.<BR>
|
|
|
|
This program and the accompanying materials
|
|
|
|
are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
which accompanies this distribution. The full text of the license may be found at
|
|
|
|
http://opensource.org/licenses/bsd-license.php
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
|
|
|
|
#include "Terminal.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Translate all raw data in the Raw FIFO into unicode, and insert
|
|
|
|
them into Unicode FIFO.
|
|
|
|
|
|
|
|
@param TerminalDevice The terminal device.
|
|
|
|
|
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
AnsiRawDataToUnicode (
|
|
|
|
IN TERMINAL_DEV *TerminalDevice
|
|
|
|
)
|
|
|
|
{
|
|
|
|
UINT8 RawData;
|
|
|
|
|
|
|
|
//
|
|
|
|
// pop the raw data out from the raw fifo,
|
|
|
|
// and translate it into unicode, then push
|
|
|
|
// the unicode into unicode fifo, until the raw fifo is empty.
|
|
|
|
//
|
|
|
|
while (!IsRawFiFoEmpty (TerminalDevice) && !IsUnicodeFiFoFull (TerminalDevice)) {
|
|
|
|
|
|
|
|
RawFiFoRemoveOneKey (TerminalDevice, &RawData);
|
|
|
|
|
|
|
|
UnicodeFiFoInsertOneKey (TerminalDevice, (UINT16) RawData);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Check if input string is valid Ascii string, valid EFI control characters
|
|
|
|
or valid text graphics.
|
|
|
|
|
|
|
|
@param TerminalDevice The terminal device.
|
|
|
|
@param WString The input string.
|
|
|
|
|
|
|
|
@retval EFI_UNSUPPORTED If not all input characters are valid.
|
|
|
|
@retval EFI_SUCCESS If all input characters are valid.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
AnsiTestString (
|
|
|
|
IN TERMINAL_DEV *TerminalDevice,
|
|
|
|
IN CHAR16 *WString
|
|
|
|
)
|
|
|
|
{
|
|
|
|
CHAR8 GraphicChar;
|
|
|
|
|
|
|
|
//
|
|
|
|
// support three kind of character:
|
|
|
|
// valid ascii, valid efi control char, valid text graphics.
|
|
|
|
//
|
|
|
|
for (; *WString != CHAR_NULL; WString++) {
|
|
|
|
|
|
|
|
if ( !(TerminalIsValidAscii (*WString) ||
|
|
|
|
TerminalIsValidEfiCntlChar (*WString) ||
|
|
|
|
TerminalIsValidTextGraphics (*WString, &GraphicChar, NULL) )) {
|
|
|
|
|
|
|
|
return EFI_UNSUPPORTED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return EFI_SUCCESS;
|
|
|
|
}
|