WindowsXP-SP1/base/screg/winreg/cntrtext/lodctr/lodctr.c
2020-09-30 16:53:49 +02:00

288 lines
8.8 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
lodctr.c
Abstract:
Program to read the contents of the file specified in the command line
and update the registry accordingly
Author:
Bob Watson (a-robw) 10 Feb 93
Revision History:
a-robw 25-Feb-93 revised calls to make it compile as a UNICODE or
an ANSI app.
a-robw 10-Nov-95 revised to use DLL functions for all the dirty work
// command line arguments supported:
/C:<filename> upgrade counter text strings using <filename>
/H:<filename> upgrade help text strings using <filename>
/L:<LangID> /C and /H params are for language <LangID>
/S:<filename> save current perf registry strings & info to <filname>
/R:<filename> restore perf registry strings & info using <filname>
/T:<service> set <service> to be Trusted using current DLL
--*/
#define UNICODE 1
#define _UNICODE 1
//
// Windows Include files
//
#include <nt.h>
#include <ntrtl.h>
#include <nturtl.h>
#include <windows.h>
#include <stdlib.h>
#include <tchar.h>
#include <loadperf.h>
#include "..\common\common.h"
static CHAR szFileNameBuffer[MAX_PATH*2];
static
LPCSTR
GetTrustedServiceName (
LPCSTR szArg1
)
{
LPSTR szReturn = NULL;
if ((szArg1[0] == '-') || (szArg1[0] == '/')) {
//it's a switch command
if ((szArg1[1] == 't') || (szArg1[1] == 'T')) {
// the command is to Save the configuration to a file
if (szArg1[2] == ':') {
// then the rest of the string is the name of the trusted service
szReturn = (LPSTR)&szArg1[3];
}
}
}
return (LPCSTR)szReturn;
}
static
BOOL
GetUpgradeFileNames (
LPCSTR *szArgs,
LPSTR *szCounterFile,
LPSTR *szHelpFile,
LPSTR *szLangId
)
{
DWORD dwArgIdx = 1;
DWORD dwMask = 0;
do {
// check first arg, function assumes there are 2 args or more
if ((szArgs[dwArgIdx][0] == '-') || (szArgs[dwArgIdx][0] == '/')) {
//it's a switch command
if ((szArgs[dwArgIdx][1] == 'c') || (szArgs[dwArgIdx ][1] == 'C')) {
// the command is to load a service
if (szArgs[dwArgIdx ][2] == ':') {
// then the rest of the string is the service name
*szCounterFile = (LPSTR)&szArgs[dwArgIdx ][3];
dwMask |= 1;
}
} else if ((szArgs[dwArgIdx][1] == 'h') || (szArgs[dwArgIdx ][1] == 'H')) {
// the command is to load a service
if (szArgs[dwArgIdx][2] == ':') {
// then the rest of the string is the service name
*szHelpFile = (LPSTR)&szArgs[dwArgIdx ][3];
dwMask |= 2;
}
} else if ((szArgs[dwArgIdx][1] == 'l') || (szArgs[dwArgIdx ][1] == 'L')) {
// the command is to load a service
if (szArgs[dwArgIdx][2] == ':') {
// then the rest of the string is the service name
*szLangId = (LPSTR)&szArgs[dwArgIdx ][3];
dwMask |= 4;
}
}
}
dwArgIdx++;
} while (dwArgIdx <= 3);
if (dwMask == 7) {
// all names found
return TRUE;
} else {
return FALSE;
}
}
static
LPCSTR
GetSaveFileName (
LPCSTR szArg1
)
{
LPSTR szReturn = NULL;
DWORD dwSize;
if ((szArg1[0] == '-') || (szArg1[0] == '/')) {
//it's a switch command
if ((szArg1[1] == 's') || (szArg1[1] == 'S')) {
// the command is to Save the configuration to a file
if (szArg1[2] == ':') {
// then the rest of the string is the input file name
dwSize = SearchPathA (NULL, (LPSTR)&szArg1[3], NULL,
sizeof(szFileNameBuffer)/sizeof(szFileNameBuffer[0]),
szFileNameBuffer, NULL);
if (dwSize == 0) {
//unable to find file in path so use it as is
szReturn = (LPSTR)&szArg1[3];
} else {
// else return the expanded file name
szReturn = szFileNameBuffer;
}
}
}
}
return (LPCSTR)szReturn;
}
static
LPCSTR
GetRestoreFileName (
LPCSTR szArg1
)
{
LPSTR szReturn = NULL;
DWORD dwSize;
if ((szArg1[0] == '-') || (szArg1[0] == '/')) {
//it's a switch command
if ((szArg1[1] == 'r') || (szArg1[1] == 'R')) {
// the command is to Save the configuration to a file
if (szArg1[2] == ':') {
// then the rest of the string is the input file name
dwSize = SearchPathA (NULL, (LPSTR)&szArg1[3], NULL,
sizeof(szFileNameBuffer)/sizeof(szFileNameBuffer[0]),
szFileNameBuffer, NULL);
if (dwSize == 0) {
//unable to find file in path so use it as is
szReturn = (LPSTR)&szArg1[3];
} else {
// else return the expanded file name
szReturn = szFileNameBuffer;
}
}
}
}
return (LPCSTR)szReturn;
}
int
__cdecl main(
int argc,
char *argv[]
)
/*++
main
Arguments
ReturnValue
0 (ERROR_SUCCESS) if command was processed
Non-Zero if command error was detected.
--*/
{
LPTSTR lpCommandLine;
LPSTR szCmdArgFileName;
LPWSTR wszFileName;
DWORD dwFileNameLen;
int nReturn;
lpCommandLine = GetCommandLine(); // get command line
// check for a service name in the command line
if (argc >= 2) {
if (argc >= 4) {
BOOL bDoUpdate;
LPSTR szCounterFile = NULL;
LPSTR szHelpFile = NULL;
LPSTR szLanguageID = NULL;
bDoUpdate = GetUpgradeFileNames (
argv,
&szCounterFile,
&szHelpFile,
&szLanguageID);
if (bDoUpdate) {
return (int) UpdatePerfNameFilesA (
szCounterFile,
szHelpFile,
szLanguageID,
0);
}
} else {
// then there's a param to check
szCmdArgFileName = (LPSTR)GetSaveFileName (argv[1]);
if (szCmdArgFileName != NULL) {
dwFileNameLen = lstrlenA(szCmdArgFileName) + 1;
wszFileName = HeapAlloc (GetProcessHeap(), 0, (dwFileNameLen) * sizeof (WCHAR));
if (wszFileName != NULL) {
mbstowcs (wszFileName, szCmdArgFileName, dwFileNameLen);
nReturn = (int)BackupPerfRegistryToFileW (
(LPCWSTR)wszFileName,
(LPCWSTR)L"");
HeapFree (GetProcessHeap(), 0, wszFileName);
return nReturn;
}
}
// try Restore file name
szCmdArgFileName = (LPSTR)GetRestoreFileName (argv[1]);
if (szCmdArgFileName != NULL) {
dwFileNameLen = lstrlenA(szCmdArgFileName) + 1;
wszFileName = HeapAlloc (GetProcessHeap(), 0, (dwFileNameLen) * sizeof (WCHAR));
if (wszFileName != NULL) {
mbstowcs (wszFileName, szCmdArgFileName, dwFileNameLen);
nReturn = (int)RestorePerfRegistryFromFileW(
(LPCWSTR) wszFileName,
NULL);
HeapFree (GetProcessHeap(), 0, wszFileName);
return nReturn;
}
}
// try Trusted service name
szCmdArgFileName = (LPSTR)GetTrustedServiceName (argv[1]);
if (szCmdArgFileName != NULL) {
dwFileNameLen = lstrlenA(szCmdArgFileName) + 1;
wszFileName = HeapAlloc (GetProcessHeap(), 0, (dwFileNameLen) * sizeof (WCHAR));
if (wszFileName != NULL) {
mbstowcs (wszFileName, szCmdArgFileName, dwFileNameLen);
nReturn = (int)SetServiceAsTrusted (NULL,
(LPCWSTR)wszFileName); // filename is really the service name
HeapFree (GetProcessHeap(), 0, wszFileName);
return nReturn;
}
}
}
}
// if here then load the registry from an ini file
return (int) LoadPerfCounterTextStrings (
lpCommandLine,
FALSE); // show text strings to console
}