|
@@ -1125,24 +1125,24 @@ Returns:
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
- case '0':
|
|
|
- Item.Pad = '0';
|
|
|
+ case ',':
|
|
|
+ Item.Comma = TRUE;
|
|
|
break;
|
|
|
|
|
|
case '-':
|
|
|
Item.PadBefore = FALSE;
|
|
|
break;
|
|
|
|
|
|
- case ',':
|
|
|
- Item.Comma = TRUE;
|
|
|
+ case '*':
|
|
|
+ *Item.WidthParse = va_arg(ps->args, UINTN);
|
|
|
break;
|
|
|
|
|
|
case '.':
|
|
|
Item.WidthParse = &Item.FieldWidth;
|
|
|
break;
|
|
|
|
|
|
- case '*':
|
|
|
- *Item.WidthParse = va_arg(ps->args, UINTN);
|
|
|
+ case '0':
|
|
|
+ Item.Pad = '0';
|
|
|
break;
|
|
|
|
|
|
case '1':
|
|
@@ -1170,52 +1170,23 @@ Returns:
|
|
|
}
|
|
|
break;
|
|
|
|
|
|
- case 's':
|
|
|
- Item.Item.pw = va_arg(ps->args, CHAR16 *);
|
|
|
- if (!Item.Item.pw) {
|
|
|
- Item.Item.pw = L"(null)";
|
|
|
- }
|
|
|
- break;
|
|
|
-
|
|
|
case 'c':
|
|
|
Item.Scratch[0] = (CHAR16) va_arg(ps->args, UINTN);
|
|
|
Item.Scratch[1] = 0;
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
- case 'l':
|
|
|
- Item.Long = TRUE;
|
|
|
- break;
|
|
|
-
|
|
|
- case 'X':
|
|
|
- Item.Width = Item.Long ? 16 : 8;
|
|
|
- Item.Pad = '0';
|
|
|
-#if __GNUC__ >= 7
|
|
|
- __attribute__ ((fallthrough));
|
|
|
-#endif
|
|
|
- case 'x':
|
|
|
- ValueToHex (
|
|
|
- Item.Scratch,
|
|
|
- Item.Long ? va_arg(ps->args, UINT64) : va_arg(ps->args, UINT32)
|
|
|
- );
|
|
|
- Item.Item.pw = Item.Scratch;
|
|
|
-
|
|
|
- break;
|
|
|
-
|
|
|
+ case 'D':
|
|
|
+ {
|
|
|
+ EFI_DEVICE_PATH *dp = va_arg(ps->args, EFI_DEVICE_PATH *);
|
|
|
+ CHAR16 *dpstr = DevicePathToStr(dp);
|
|
|
+ StrnCpy(Item.Scratch, dpstr, PRINT_ITEM_BUFFER_LEN);
|
|
|
+ Item.Scratch[PRINT_ITEM_BUFFER_LEN-1] = L'\0';
|
|
|
+ FreePool(dpstr);
|
|
|
|
|
|
- case 'g':
|
|
|
- GuidToString (Item.Scratch, va_arg(ps->args, EFI_GUID *));
|
|
|
- Item.Item.pw = Item.Scratch;
|
|
|
- break;
|
|
|
-
|
|
|
- case 'u':
|
|
|
- ValueToString (
|
|
|
- Item.Scratch,
|
|
|
- Item.Comma,
|
|
|
- Item.Long ? va_arg(ps->args, UINT64) : va_arg(ps->args, UINT32)
|
|
|
- );
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
+ }
|
|
|
|
|
|
case 'd':
|
|
|
ValueToString (
|
|
@@ -1226,17 +1197,13 @@ Returns:
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
- case 'D':
|
|
|
- {
|
|
|
- EFI_DEVICE_PATH *dp = va_arg(ps->args, EFI_DEVICE_PATH *);
|
|
|
- CHAR16 *dpstr = DevicePathToStr(dp);
|
|
|
- StrnCpy(Item.Scratch, dpstr, PRINT_ITEM_BUFFER_LEN);
|
|
|
- Item.Scratch[PRINT_ITEM_BUFFER_LEN-1] = L'\0';
|
|
|
- FreePool(dpstr);
|
|
|
+ case 'E':
|
|
|
+ Attr = ps->AttrError;
|
|
|
+ break;
|
|
|
|
|
|
- Item.Item.pw = Item.Scratch;
|
|
|
+ case 'e':
|
|
|
+ PSETATTR(ps, ps->AttrError);
|
|
|
break;
|
|
|
- }
|
|
|
|
|
|
case 'f':
|
|
|
FloatToString (
|
|
@@ -1247,38 +1214,69 @@ Returns:
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
- case 't':
|
|
|
- TimeToString (Item.Scratch, va_arg(ps->args, EFI_TIME *));
|
|
|
- Item.Item.pw = Item.Scratch;
|
|
|
- break;
|
|
|
-
|
|
|
- case 'r':
|
|
|
- StatusToString (Item.Scratch, va_arg(ps->args, EFI_STATUS));
|
|
|
+ case 'g':
|
|
|
+ GuidToString (Item.Scratch, va_arg(ps->args, EFI_GUID *));
|
|
|
Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
- case 'n':
|
|
|
- PSETATTR(ps, ps->AttrNorm);
|
|
|
+ case 'H':
|
|
|
+ Attr = ps->AttrHighlight;
|
|
|
break;
|
|
|
|
|
|
case 'h':
|
|
|
PSETATTR(ps, ps->AttrHighlight);
|
|
|
break;
|
|
|
|
|
|
- case 'e':
|
|
|
- PSETATTR(ps, ps->AttrError);
|
|
|
+ case 'l':
|
|
|
+ Item.Long = TRUE;
|
|
|
break;
|
|
|
|
|
|
case 'N':
|
|
|
Attr = ps->AttrNorm;
|
|
|
break;
|
|
|
|
|
|
- case 'H':
|
|
|
- Attr = ps->AttrHighlight;
|
|
|
+ case 'n':
|
|
|
+ PSETATTR(ps, ps->AttrNorm);
|
|
|
break;
|
|
|
|
|
|
- case 'E':
|
|
|
- Attr = ps->AttrError;
|
|
|
+ case 'r':
|
|
|
+ StatusToString (Item.Scratch, va_arg(ps->args, EFI_STATUS));
|
|
|
+ Item.Item.pw = Item.Scratch;
|
|
|
+ break;
|
|
|
+
|
|
|
+ case 's':
|
|
|
+ Item.Item.pw = va_arg(ps->args, CHAR16 *);
|
|
|
+ if (!Item.Item.pw) {
|
|
|
+ Item.Item.pw = L"(null)";
|
|
|
+ }
|
|
|
+ break;
|
|
|
+
|
|
|
+ case 't':
|
|
|
+ TimeToString (Item.Scratch, va_arg(ps->args, EFI_TIME *));
|
|
|
+ Item.Item.pw = Item.Scratch;
|
|
|
+ break;
|
|
|
+
|
|
|
+ case 'u':
|
|
|
+ ValueToString (
|
|
|
+ Item.Scratch,
|
|
|
+ Item.Comma,
|
|
|
+ Item.Long ? va_arg(ps->args, UINT64) : va_arg(ps->args, UINT32)
|
|
|
+ );
|
|
|
+ Item.Item.pw = Item.Scratch;
|
|
|
+ break;
|
|
|
+
|
|
|
+ case 'X':
|
|
|
+ Item.Width = Item.Long ? 16 : 8;
|
|
|
+ Item.Pad = '0';
|
|
|
+#if __GNUC__ >= 7
|
|
|
+ __attribute__ ((fallthrough));
|
|
|
+#endif
|
|
|
+ case 'x':
|
|
|
+ ValueToHex (
|
|
|
+ Item.Scratch,
|
|
|
+ Item.Long ? va_arg(ps->args, UINT64) : va_arg(ps->args, UINT32)
|
|
|
+ );
|
|
|
+ Item.Item.pw = Item.Scratch;
|
|
|
break;
|
|
|
|
|
|
default:
|