[CMD]: Small refactoring:

- Moving ConGetDefaultAttributes() in console.h;
- Moving some SDK inclusions into precomp.h;
- Removing extern HANDLE hIn; and localize the SHORT maxx/y variables;
- Comment fix;
- Whitespace fixes for screen.c.

svn path=/trunk/; revision=76009
This commit is contained in:
Hermès Bélusca-Maïto 2017-09-30 21:37:34 +00:00
parent d7bbf5ad8a
commit 11f7d225c8
8 changed files with 71 additions and 71 deletions

View file

@ -311,7 +311,8 @@ Execute(LPTSTR Full, LPTSTR First, LPTSTR Rest, PARSED_COMMAND *Cmd)
{
TCHAR szFullName[MAX_PATH];
TCHAR *first, *rest, *dot;
TCHAR szWindowTitle[MAX_PATH], szNewTitle[MAX_PATH*2];
TCHAR szWindowTitle[MAX_PATH];
TCHAR szNewTitle[MAX_PATH*2];
DWORD dwExitCode = 0;
TCHAR *FirstEnd;
TCHAR szFullCmdLine[CMDLINE_LENGTH];
@ -1762,33 +1763,6 @@ GetCmdLineCommand(TCHAR *commandline, TCHAR *ptr, BOOL AlwaysStrip)
}
#ifdef INCLUDE_CMD_COLOR
BOOL ConGetDefaultAttributes(PWORD pwDefAttr)
{
BOOL Success;
HANDLE hConsole;
CONSOLE_SCREEN_BUFFER_INFO csbi;
/* Do not modify *pwDefAttr if we fail, in which case use default attributes */
hConsole = CreateFile(_T("CONOUT$"), GENERIC_READ|GENERIC_WRITE,
FILE_SHARE_READ|FILE_SHARE_WRITE, NULL,
OPEN_EXISTING, 0, NULL);
if (hConsole == INVALID_HANDLE_VALUE)
return FALSE; // No default console
Success = GetConsoleScreenBufferInfo(hConsole, &csbi);
if (Success)
*pwDefAttr = csbi.wAttributes;
CloseHandle(hConsole);
return Success;
}
#endif
/*
* Set up global initializations and process parameters
*/
@ -1997,7 +1971,6 @@ static VOID Cleanup(VOID)
if (IsExistingFile(_T("cmdexit.bat")))
{
ConErrResPuts(STRING_CMD_ERROR5);
ParseCommandLine(_T("cmdexit.bat"));
}
else if (IsExistingFile(_T("\\cmdexit.bat")))

View file

@ -25,12 +25,6 @@
#include <config.h>
#include <winnls.h>
#include <winreg.h>
#include <winuser.h>
#include <wincon.h>
#include <tchar.h>
#include "cmdver.h"
#include "cmddbg.h"
@ -43,7 +37,6 @@
#define D_ON _T("on")
#define D_OFF _T("off")
/* command line buffer length */
#define CMDLINE_LENGTH 8192
@ -51,7 +44,6 @@
#define BUFF_SIZE 16384
/* Global variables */
extern HANDLE hIn;
extern LPTSTR lpOriginalEnvironment;
extern WORD wColor;
extern WORD wDefColor;
@ -62,8 +54,6 @@ extern BOOL bDisableBatchEcho;
extern BOOL bEnableExtensions;
extern BOOL bDelayedExpansion;
extern INT nErrorLevel;
extern SHORT maxx;
extern SHORT maxy;
extern BOOL bUnicodeOutput;

View file

@ -507,6 +507,33 @@ VOID GetScreenSize(PSHORT maxx, PSHORT maxy)
#ifdef INCLUDE_CMD_COLOR
BOOL ConGetDefaultAttributes(PWORD pwDefAttr)
{
BOOL Success;
HANDLE hConsole;
CONSOLE_SCREEN_BUFFER_INFO csbi;
/* Do not modify *pwDefAttr if we fail, in which case use default attributes */
hConsole = CreateFile(_T("CONOUT$"), GENERIC_READ|GENERIC_WRITE,
FILE_SHARE_READ|FILE_SHARE_WRITE, NULL,
OPEN_EXISTING, 0, NULL);
if (hConsole == INVALID_HANDLE_VALUE)
return FALSE; // No default console
Success = GetConsoleScreenBufferInfo(hConsole, &csbi);
if (Success)
*pwDefAttr = csbi.wAttributes;
CloseHandle(hConsole);
return Success;
}
#endif
BOOL ConSetTitle(IN LPCTSTR lpConsoleTitle)
{
/* Now really set the console title */

View file

@ -72,6 +72,11 @@ VOID GetScreenSize (PSHORT, PSHORT);
VOID SetCursorType (BOOL, BOOL);
#ifdef INCLUDE_CMD_COLOR
BOOL ConGetDefaultAttributes(PWORD pwDefAttr);
#endif
BOOL ConSetTitle(IN LPCTSTR lpConsoleTitle);
#ifdef INCLUDE_CMD_BEEP

View file

@ -7,15 +7,20 @@
#define _CRT_SECURE_NO_DEPRECATE
#endif /*_MSC_VER */
#include <stdio.h>
#include <stdarg.h>
#include <stdlib.h>
#include <malloc.h>
#include <tchar.h>
#define WIN32_NO_STATUS
#include <stdarg.h>
#include <windef.h>
#include <winbase.h>
#include <winnls.h>
#include <winreg.h>
#include <winuser.h>
#include <wincon.h>
#include <shellapi.h>
#include <stdio.h>
#define NTOS_MODE_USER
#include <ndk/rtlfuncs.h>

View file

@ -15,10 +15,10 @@
#ifdef INCLUDE_CMD_SCREEN
INT CommandScreen(LPTSTR param)
{
SHORT x, y;
SHORT maxx, maxy;
BOOL bSkipText = FALSE;
if (_tcsncmp(param, _T("/?"), 2) == 0)
@ -29,11 +29,14 @@ INT CommandScreen (LPTSTR param)
nErrorLevel = 0;
//get row
/* Retrieve the screen dimensions */
GetScreenSize(&maxx, &maxy);
/* Get row */
while (_istspace(*param))
param++;
if (!(*param))
if (!*param)
{
error_req_param_missing();
return 1;
@ -43,11 +46,10 @@ INT CommandScreen (LPTSTR param)
if (y < 0 || y > (maxy-1))
{
ConOutResPuts(STRING_SCREEN_ROW);
return 1;
}
//get col
/* Get column */
if (!(param = _tcschr(param, _T(' '))))
{
error_req_param_missing();
@ -57,7 +59,7 @@ INT CommandScreen (LPTSTR param)
while (_istspace(*param))
param++;
if (!(*param))
if (!*param)
{
error_req_param_missing();
return 1;
@ -70,7 +72,7 @@ INT CommandScreen (LPTSTR param)
return 1;
}
//get text
/* Get text */
if (!(param = _tcschr(param, _T(' '))))
{
bSkipText = TRUE;
@ -80,21 +82,18 @@ INT CommandScreen (LPTSTR param)
while (_istspace(*param))
param++;
if (!(*param))
{
if (!*param)
bSkipText = TRUE;
}
}
bIgnoreEcho = TRUE;
if (bSkipText)
x = 0;
SetCursorXY(x, y);
if (!(bSkipText))
if (!bSkipText)
ConOutPuts(param);
return 0;

View file

@ -303,6 +303,7 @@ INT cmd_start (LPTSTR Rest)
nErrorLevel = (INT)dwExitCode;
}
CloseHandle (prci.hProcess);
/* Get New code page if it has change */
InputCodePage= GetConsoleCP();
OutputCodePage = GetConsoleOutputCP();