mirror of
https://github.com/reactos/reactos.git
synced 2025-02-20 15:35:04 +00:00
Fixed output of various date/time stuff ($D and $T in prompt, %DATE% and %TIME% variables, DATE /T and TIME /T commands) to be more compatible with Windows.
svn path=/trunk/; revision=40050
This commit is contained in:
parent
80c1384089
commit
6f8ec7004e
8 changed files with 80 additions and 82 deletions
|
@ -928,27 +928,12 @@ GetEnvVarOrSpecial ( LPCTSTR varName )
|
|||
/* %TIME% */
|
||||
else if (_tcsicmp(varName,_T("time")) ==0)
|
||||
{
|
||||
SYSTEMTIME t;
|
||||
if ( !GrowIfNecessary ( MAX_PATH, &ret, &retlen ) )
|
||||
return NULL;
|
||||
GetSystemTime(&t);
|
||||
_sntprintf ( ret, retlen, _T("%02d%c%02d%c%02d%c%02d"),
|
||||
t.wHour, cTimeSeparator, t.wMinute, cTimeSeparator,
|
||||
t.wSecond, cDecimalSeparator, t.wMilliseconds / 10);
|
||||
return ret;
|
||||
return GetTimeString();
|
||||
}
|
||||
/* %DATE% */
|
||||
else if (_tcsicmp(varName,_T("date")) ==0)
|
||||
{
|
||||
|
||||
if ( !GrowIfNecessary ( GetDateFormat(LOCALE_USER_DEFAULT, DATE_SHORTDATE, NULL, NULL, NULL, 0), &ret, &retlen ) )
|
||||
return NULL;
|
||||
|
||||
size = GetDateFormat(LOCALE_USER_DEFAULT, DATE_SHORTDATE, NULL, NULL, ret, retlen);
|
||||
|
||||
if ( !size )
|
||||
return NULL;
|
||||
return ret;
|
||||
return GetDateString();
|
||||
}
|
||||
|
||||
/* %RANDOM% */
|
||||
|
@ -1155,12 +1140,9 @@ GetEnhancedVar(TCHAR **pFormat, LPTSTR (*GetVar)(TCHAR, BOOL *))
|
|||
FileTimeToLocalFileTime(&w32fd.ftLastWriteTime, &ft);
|
||||
FileTimeToSystemTime(&ft, &st);
|
||||
|
||||
/* TODO: This probably should be locale-dependent */
|
||||
Out += _stprintf(Out,
|
||||
_T("%02d/%02d/%04d %02d:%02d %cM "),
|
||||
st.wMonth, st.wDay, st.wYear,
|
||||
(st.wHour + 11) % 12 + 1, st.wMinute,
|
||||
(st.wHour >= 12) ? _T('P') : _T('A'));
|
||||
Out += FormatDate(Out, &st, TRUE);
|
||||
*Out++ = _T(' ');
|
||||
Out += FormatTime(Out, &st);
|
||||
}
|
||||
if (Modifiers & M_SIZE)
|
||||
{
|
||||
|
|
|
@ -191,6 +191,8 @@ INT CommandDelay (LPTSTR);
|
|||
|
||||
|
||||
/* Prototypes for DIR.C */
|
||||
INT FormatDate (TCHAR *, LPSYSTEMTIME, BOOL);
|
||||
INT FormatTime (TCHAR *, LPSYSTEMTIME);
|
||||
INT CommandDir (LPTSTR);
|
||||
|
||||
|
||||
|
@ -304,8 +306,8 @@ extern INT nNumberGroups;
|
|||
|
||||
|
||||
VOID InitLocale (VOID);
|
||||
VOID PrintDate (VOID);
|
||||
VOID PrintTime (VOID);
|
||||
LPTSTR GetDateString (VOID);
|
||||
LPTSTR GetTimeString (VOID);
|
||||
|
||||
/* cache codepage */
|
||||
extern UINT InputCodePage;
|
||||
|
|
|
@ -205,7 +205,7 @@ INT cmd_date (LPTSTR param)
|
|||
}
|
||||
|
||||
if (nDateString == -1)
|
||||
PrintDate ();
|
||||
ConOutPrintf(_T("%s"), GetDateString());
|
||||
|
||||
if (!bPrompt)
|
||||
{
|
||||
|
|
|
@ -644,7 +644,6 @@ DirPrintFileDateTime(TCHAR *lpDate,
|
|||
{
|
||||
FILETIME ft;
|
||||
SYSTEMTIME dt;
|
||||
WORD wYear;
|
||||
|
||||
/* Select the right time field */
|
||||
switch (lpFlags->stTimeField.eTimeField)
|
||||
|
@ -668,44 +667,56 @@ DirPrintFileDateTime(TCHAR *lpDate,
|
|||
break;
|
||||
}
|
||||
|
||||
FormatDate(lpDate, &dt, lpFlags->b4Digit);
|
||||
FormatTime(lpTime, &dt);
|
||||
}
|
||||
|
||||
INT
|
||||
FormatDate(TCHAR *lpDate, LPSYSTEMTIME dt, BOOL b4Digit)
|
||||
{
|
||||
/* Format date */
|
||||
wYear = (lpFlags->b4Digit) ? dt.wYear : dt.wYear%100;
|
||||
WORD wYear = b4Digit ? dt->wYear : dt->wYear%100;
|
||||
switch (nDateFormat)
|
||||
{
|
||||
case 0: /* mmddyy */
|
||||
default:
|
||||
_stprintf(lpDate, _T("%02d%c%02d%c%0*d"),
|
||||
dt.wMonth, cDateSeparator,
|
||||
dt.wDay, cDateSeparator,
|
||||
lpFlags->b4Digit?4:2, wYear);
|
||||
return _stprintf(lpDate, _T("%02d%c%02d%c%0*d"),
|
||||
dt->wMonth, cDateSeparator,
|
||||
dt->wDay, cDateSeparator,
|
||||
b4Digit?4:2, wYear);
|
||||
break;
|
||||
|
||||
case 1: /* ddmmyy */
|
||||
_stprintf(lpDate, _T("%02d%c%02d%c%0*d"),
|
||||
dt.wDay, cDateSeparator, dt.wMonth,
|
||||
cDateSeparator,lpFlags->b4Digit?4:2, wYear);
|
||||
return _stprintf(lpDate, _T("%02d%c%02d%c%0*d"),
|
||||
dt->wDay, cDateSeparator, dt->wMonth,
|
||||
cDateSeparator, b4Digit?4:2, wYear);
|
||||
break;
|
||||
|
||||
case 2: /* yymmdd */
|
||||
_stprintf(lpDate, _T("%0*d%c%02d%c%02d"),
|
||||
lpFlags->b4Digit?4:2, wYear, cDateSeparator,
|
||||
dt.wMonth, cDateSeparator, dt.wDay);
|
||||
return _stprintf(lpDate, _T("%0*d%c%02d%c%02d"),
|
||||
b4Digit?4:2, wYear, cDateSeparator,
|
||||
dt->wMonth, cDateSeparator, dt->wDay);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
INT
|
||||
FormatTime(TCHAR *lpTime, LPSYSTEMTIME dt)
|
||||
{
|
||||
/* Format Time */
|
||||
switch (nTimeFormat)
|
||||
{
|
||||
case 0: /* 12 hour format */
|
||||
default:
|
||||
_stprintf(lpTime,_T("%02d%c%02u%c"),
|
||||
(dt.wHour == 0 ? 12 : (dt.wHour <= 12 ? dt.wHour : dt.wHour - 12)),
|
||||
return _stprintf(lpTime,_T("%02d%c%02u%c"),
|
||||
(dt->wHour == 0 ? 12 : (dt->wHour <= 12 ? dt->wHour : dt->wHour - 12)),
|
||||
cTimeSeparator,
|
||||
dt.wMinute, (dt.wHour <= 11 ? _T('a') : _T('p')));
|
||||
dt->wMinute, (dt->wHour <= 11 ? _T('a') : _T('p')));
|
||||
break;
|
||||
|
||||
case 1: /* 24 hour format */
|
||||
_stprintf(lpTime, _T("%02d%c%02u"),
|
||||
dt.wHour, cTimeSeparator, dt.wMinute);
|
||||
return _stprintf(lpTime, _T("%02d%c%02u"),
|
||||
dt->wHour, cTimeSeparator, dt->wMinute);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -54,27 +54,30 @@ VOID InitLocale (VOID)
|
|||
#endif
|
||||
}
|
||||
|
||||
|
||||
VOID PrintDate (VOID)
|
||||
/* Return date string including weekday. Used for $D in prompt and %DATE% */
|
||||
LPTSTR
|
||||
GetDateString(VOID)
|
||||
{
|
||||
TCHAR szDateDay[32];
|
||||
TCHAR szDate[32];
|
||||
static TCHAR szDate[32];
|
||||
SYSTEMTIME t;
|
||||
INT len;
|
||||
GetLocalTime(&t);
|
||||
|
||||
GetDateFormat(LOCALE_USER_DEFAULT, 0, NULL, _T("ddd"), szDateDay, sizeof (szDateDay));
|
||||
|
||||
GetDateFormat(LOCALE_USER_DEFAULT, DATE_SHORTDATE, NULL, NULL,szDate, sizeof (szDate));
|
||||
ConOutPrintf(_T("%s %s"),szDateDay, szDate);
|
||||
len = GetDateFormat(LOCALE_USER_DEFAULT, 0, &t, _T("ddd"), szDate, sizeof szDate);
|
||||
szDate[len - 1] = _T(' ');
|
||||
FormatDate(&szDate[len], &t, TRUE);
|
||||
return szDate;
|
||||
}
|
||||
|
||||
|
||||
VOID PrintTime (VOID)
|
||||
/* Return time in hh:mm:ss.xx format. Used for $T in prompt and %TIME% */
|
||||
LPTSTR
|
||||
GetTimeString(VOID)
|
||||
{
|
||||
TCHAR szMsg[RC_STRING_MAX_SIZE];
|
||||
SYSTEMTIME t;
|
||||
GetLocalTime(&t);
|
||||
|
||||
LoadString(CMD_ModuleHandle, STRING_LOCALE_HELP1, szMsg, RC_STRING_MAX_SIZE);
|
||||
ConOutPrintf(_T("%s: %02d%c%02d%c%02d%c%02d\n"), szMsg, t.wHour, cTimeSeparator,
|
||||
t.wMinute , cTimeSeparator,
|
||||
t.wSecond , cDecimalSeparator, t.wMilliseconds );
|
||||
static TCHAR szTime[12];
|
||||
SYSTEMTIME t;
|
||||
GetLocalTime(&t);
|
||||
_stprintf(szTime, _T("%02d%c%02d%c%02d%c%02d"),
|
||||
t.wHour, cTimeSeparator, t.wMinute, cTimeSeparator,
|
||||
t.wSecond, cDecimalSeparator, t.wMilliseconds / 10);
|
||||
return szTime;
|
||||
}
|
||||
|
|
|
@ -87,7 +87,7 @@ VOID PrintPrompt(VOID)
|
|||
break;
|
||||
|
||||
case _T('D'):
|
||||
PrintDate ();
|
||||
ConOutPrintf(_T("%s"), GetDateString());
|
||||
break;
|
||||
|
||||
case _T('E'):
|
||||
|
@ -137,12 +137,7 @@ VOID PrintPrompt(VOID)
|
|||
break;
|
||||
|
||||
case _T('T'):
|
||||
{
|
||||
SYSTEMTIME t;
|
||||
GetSystemTime(&t);
|
||||
ConOutPrintf(_T("%02d%c%02d%c%02d%c%02d\n"),t.wHour, cTimeSeparator,t.wMinute , cTimeSeparator,
|
||||
t.wSecond , cDecimalSeparator, t.wMilliseconds );
|
||||
}
|
||||
ConOutPrintf(_T("%s"), GetTimeString());
|
||||
break;
|
||||
|
||||
case _T('V'):
|
||||
|
|
|
@ -134,7 +134,6 @@ INT cmd_time (LPTSTR param)
|
|||
LPTSTR *arg;
|
||||
INT argc;
|
||||
INT i;
|
||||
BOOL bPrompt = TRUE;
|
||||
INT nTimeString = -1;
|
||||
|
||||
if (!_tcsncmp (param, _T("/?"), 2))
|
||||
|
@ -152,19 +151,25 @@ INT cmd_time (LPTSTR param)
|
|||
for (i = 0; i < argc; i++)
|
||||
{
|
||||
if (_tcsicmp (arg[i], _T("/t")) == 0)
|
||||
bPrompt = FALSE;
|
||||
{
|
||||
/* Display current time in short format */
|
||||
SYSTEMTIME st;
|
||||
TCHAR szTime[20];
|
||||
GetLocalTime(&st);
|
||||
FormatTime(szTime, &st);
|
||||
ConOutPuts(szTime);
|
||||
freep(arg);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((*arg[i] != _T('/')) && (nTimeString == -1))
|
||||
nTimeString = i;
|
||||
}
|
||||
|
||||
if (nTimeString == -1)
|
||||
PrintTime ();
|
||||
|
||||
if (!bPrompt)
|
||||
{
|
||||
freep (arg);
|
||||
return 0;
|
||||
ConOutResPrintf(STRING_LOCALE_HELP1);
|
||||
ConOutPrintf(_T(": %s\n"), GetTimeString());
|
||||
}
|
||||
|
||||
while (1)
|
||||
|
|
|
@ -153,7 +153,7 @@ INT CommandTimer (LPTSTR param)
|
|||
cS=TRUE;
|
||||
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
freep(p);
|
||||
return 0;
|
||||
}
|
||||
|
@ -163,7 +163,7 @@ INT CommandTimer (LPTSTR param)
|
|||
if(cS)
|
||||
{
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
PrintElapsedTime(GetTickCount()-cT, iFormat);
|
||||
freep(p);
|
||||
return 0;
|
||||
|
@ -172,7 +172,7 @@ INT CommandTimer (LPTSTR param)
|
|||
cT=GetTickCount();
|
||||
cS=TRUE;
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
freep(p);
|
||||
return 0;
|
||||
}
|
||||
|
@ -183,7 +183,7 @@ INT CommandTimer (LPTSTR param)
|
|||
{
|
||||
cS=FALSE;
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
PrintElapsedTime(GetTickCount()-cT, iFormat);
|
||||
freep(p);
|
||||
return 0;
|
||||
|
@ -192,7 +192,7 @@ INT CommandTimer (LPTSTR param)
|
|||
cT=GetTickCount();
|
||||
cS=TRUE;
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
freep(p);
|
||||
return 0;
|
||||
}
|
||||
|
@ -204,13 +204,13 @@ INT CommandTimer (LPTSTR param)
|
|||
{
|
||||
cS=FALSE;
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
PrintElapsedTime(GetTickCount()-cT, iFormat);
|
||||
freep(p);
|
||||
return 0;
|
||||
}
|
||||
ConOutResPrintf (STRING_TIMER_TIME,clk_n,cS?_T("ON"):_T("OFF"));
|
||||
PrintTime();
|
||||
ConOutPuts(GetTimeString());
|
||||
freep(p);
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue