Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

468 lines
13 KiB

/*++
Copyright (c) 1996 Microsoft Corporation
Module Name:
treg.c
Abstract:
Test for cluster registry API
Author:
John Vert (jvert) 15-Mar-1996
Revision History:
--*/
#include "windows.h"
#include "cluster.h"
#include "stdio.h"
#include "stdlib.h"
#include "conio.h"
#define INDENT_LEVEL 4
WCHAR Value1Data[] = L"This is data for value 1";
WCHAR Value2Data[] = L"This is data for value 2";
WCHAR Value3Data[] = L"This is data for value 3";
VOID
DumpKeyWorker(
IN HKEY Key,
IN DWORD Indent
);
VOID
DumpValues(
IN HKEY Key,
IN DWORD Indent
);
int
_cdecl
main (argc, argv)
int argc;
char *argv[];
{
HCLUSTER Cluster;
HRESOURCE Resource;
HGROUP Group;
HNODE Node;
HKEY ClusterRoot;
HKEY TestKey;
HCLUSENUM ResEnum;
DWORD ClusterCountBefore, ClusterCountAfter;
DWORD i;
DWORD Status;
WCHAR NameBuf[50];
DWORD NameLen;
DWORD Type;
DWORD Disposition;
//
// Dump out registry structure for current cluster.
//
Cluster = OpenCluster(NULL);
if (Cluster == NULL) {
fprintf(stderr, "OpenCluster(NULL) failed %d\n",GetLastError());
return(0);
}
ClusterRoot = GetClusterKey(Cluster, KEY_READ);
if (ClusterRoot == NULL) {
fprintf(stderr, "GetClusterKey failed %d\n", GetLastError());
return(0);
}
printf("CLUSTERROOT\n");
DumpKeyWorker(ClusterRoot, 4);
//
// Dump by object
//
printf("\n\nENUMERATING OBJECTS\n");
ResEnum = ClusterOpenEnum(Cluster, CLUSTER_ENUM_ALL);
if (ResEnum == NULL) {
fprintf(stderr, "ClusterOpenEnum failed %d\n",GetLastError());
return(0);
}
ClusterCountBefore = ClusterGetEnumCount(ResEnum);
for(i=0; ; i++) {
NameLen = sizeof(NameBuf)/sizeof(WCHAR);
Status = ClusterEnum(ResEnum,
i,
&Type,
NameBuf,
&NameLen);
if (Status == ERROR_NO_MORE_ITEMS) {
break;
} else if (Status != ERROR_SUCCESS) {
fprintf(stderr, "ClusterEnum %d returned error %d\n",i,Status);
return(0);
}
switch (Type) {
case CLUSTER_ENUM_NODE:
printf("NODE %ws\n",NameBuf);
break;
case CLUSTER_ENUM_RESTYPE:
printf("RESOURCETYPE %ws\n",NameBuf);
break;
case CLUSTER_ENUM_RESOURCE:
printf("RESOURCE %ws\n",NameBuf);
Resource = OpenClusterResource(Cluster, NameBuf);
if (Resource == NULL) {
fprintf(stderr, "OpenClusterResource returned error %d\n",GetLastError());
break;
}
ClusterRoot = GetClusterResourceKey(Resource,
KEY_READ);
if (ClusterRoot == NULL) {
fprintf(stderr, "GetClusterResourceKey returned error %d\n",GetLastError());
break;
}
CloseClusterResource(Resource);
DumpKeyWorker(ClusterRoot, 4);
break;
case CLUSTER_ENUM_GROUP:
printf("GROUP %ws\n",NameBuf);
Group = OpenClusterGroup(Cluster, NameBuf);
if (Group == NULL) {
fprintf(stderr, "OpenClusterGroup returned error %d\n",GetLastError());
break;
}
ClusterRoot = GetClusterGroupKey(Group,
KEY_READ);
if (ClusterRoot == NULL) {
fprintf(stderr, "GetClusterResourceKey returned error %d\n",GetLastError());
break;
}
CloseClusterGroup(Group);
DumpKeyWorker(ClusterRoot, 4);
break;
default:
fprintf(stderr, "ClusterEnum returned unknown type %d\n",Type);
break;
}
}
if (Status == ERROR_NO_MORE_ITEMS) {
printf("\nCluster count: %d\n", i);
ClusterCountAfter = ClusterGetEnumCount(ResEnum);
if (ClusterCountBefore != ClusterCountAfter)
fprintf(stderr, "\nReported cluster count was %d before enumeration, and %d afterward\n", ClusterCountBefore, ClusterCountAfter);
else if (i != ClusterCountBefore)
fprintf(stderr, "\nReported cluster count: %d\n", ClusterCountBefore);
}
ClusterCloseEnum(ResEnum);
//
// Test the create/delete apis
//
printf("\nTesting Creation APIs\n");
ClusterRoot = GetClusterKey(Cluster, KEY_READ | KEY_WRITE);
if (ClusterRoot == NULL) {
fprintf(stderr, "GetClusterKey failed %d\n", GetLastError());
return(0);
}
Status = ClusterRegCreateKey(ClusterRoot,
L"TestKey",
0,
KEY_READ | KEY_WRITE,
NULL,
&TestKey,
&Disposition);
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "ClusterRegCreateKey failed %d\n", Status);
return(0);
}
if (Disposition == REG_CREATED_NEW_KEY) {
printf("TestKey successfully created\n");
} else if (Disposition == REG_OPENED_EXISTING_KEY) {
printf("TestKey successfully opened\n");
} else {
fprintf(stderr,"CreateKey of TestKey returned unknown Disposition %d\n", Disposition);
}
Status = ClusterRegSetValue(TestKey,
L"Value1",
REG_SZ,
(CONST BYTE*)Value1Data,
(lstrlenW(Value1Data)+1)*sizeof(WCHAR));
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "SetValue for Value1 failed %d\n", Status);
}
Status = ClusterRegSetValue(TestKey,
L"Value2",
REG_SZ,
(CONST BYTE*)Value2Data,
(lstrlenW(Value2Data)+1)*sizeof(WCHAR));
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "SetValue for Value2 failed %d\n", Status);
}
Status = ClusterRegSetValue(TestKey,
L"Value3",
REG_SZ,
(CONST BYTE*)Value3Data,
(lstrlenW(Value3Data)+1)*sizeof(WCHAR));
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "SetValue for Value3 failed %d\n", Status);
}
printf("Press a key to delete values\n");
_getch();
printf("Deleting values...\n");
Status = ClusterRegDeleteValue(TestKey, L"Value1");
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DeleteValue for Value1 failed %d\n", Status);
}
Status = ClusterRegDeleteValue(TestKey, L"Value2");
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DeleteValue for Value2 failed %d\n", Status);
}
Status = ClusterRegDeleteValue(TestKey, L"Value3");
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DeleteValue for Value3 failed %d\n", Status);
}
printf("Press a key to delete TestKey\n");
_getch();
printf("Deleting TestKey");
ClusterRegCloseKey(TestKey);
Status = ClusterRegDeleteKey(ClusterRoot, L"TestKey");
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DeleteKey failed %d\n", Status);
}
ClusterRegCloseKey(ClusterRoot);
CloseCluster(Cluster);
}
VOID
DumpKeyWorker(
IN HKEY Key,
IN DWORD Indent
)
/*++
Routine Description:
Recursively dumps out the specified cluster registry key
Arguments:
Key - Supplies the root of the subtree to dump
Indent - Supplies the current indent level
Return Value:
None.
--*/
{
DWORD i;
DWORD j;
HKEY Subkey;
DWORD CurrentLength=80;
DWORD Length;
LPWSTR Buffer;
FILETIME FileTime;
LONG Status;
//
// Enumerate our values
//
DumpValues(Key, Indent);
//
// Enumerate the subkeys and dump each one.
//
Buffer = malloc(CurrentLength*sizeof(WCHAR));
if (Buffer == NULL) {
fprintf(stderr, "DumpKeyWorker: out of memory\n");
return;
}
for (i=0; ; i++) {
retry:
Length = CurrentLength;
Status = ClusterRegEnumKey(Key,
i,
Buffer,
&Length,
&FileTime);
if (Status == ERROR_MORE_DATA) {
CurrentLength = Length+1;
free(Buffer);
Buffer = malloc(CurrentLength*sizeof(WCHAR));
if (Buffer == NULL) {
fprintf(stderr, "DumpKeyWorker: out of memory\n");
}
goto retry;
} else if (Status == ERROR_NO_MORE_ITEMS) {
break;
} else if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DumpKeyWorker, ClusterRegEnumKey returned %d\n",Status);
return;
}
//
// print out name
//
for (j=0;j<Indent;j++) {
printf(" ");
}
printf("%ws\n",Buffer);
//
// Open the key and call ourself recursively
//
Status = ClusterRegOpenKey(Key,
Buffer,
KEY_READ,
&Subkey);
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DumpKeyWorker, ClusterRegOpenKey returned %d\n",Status);
return;
}
DumpKeyWorker(Subkey, Indent+INDENT_LEVEL);
Status = ClusterRegCloseKey(Subkey);
if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DumpKeyWorker, ClusterRegCloseKey returned %d\n",Status);
}
}
free(Buffer);
}
VOID
DumpValues(
IN HKEY Key,
IN DWORD Indent
)
/*++
Routine Description:
Dumps the values of the specified key.
Arguments:
Key - Supplies the key to dump.
Indent - Supplies the indentation level to use.
Return Value:
None.
--*/
{
DWORD i;
DWORD j;
HKEY Subkey;
DWORD CurrentNameLength=80;
DWORD NameLength;
LPWSTR Name;
DWORD CurrentDataLength=80;
DWORD DataLength;
PUCHAR Data ;
LONG Status;
DWORD Type;
//
// Enumerate the values and dump each one.
//
Name = malloc(CurrentNameLength*sizeof(WCHAR));
if (Name==NULL) {
fprintf(stderr, "DumpValues: out of memory\n");
return;
}
Data = malloc(CurrentDataLength);
if (Name==NULL) {
fprintf(stderr, "DumpValues: out of memory\n");
return;
}
for (i=0; ;i++) {
retry:
NameLength = CurrentNameLength;
DataLength = CurrentDataLength;
Status = ClusterRegEnumValue(Key,
i,
Name,
&NameLength,
&Type,
Data,
&DataLength);
if (Status == ERROR_MORE_DATA) {
if (NameLength+1 > CurrentNameLength) {
CurrentNameLength = NameLength+1;
free(Name);
Name = malloc(CurrentNameLength);
if (Name == NULL) {
fprintf(stderr, "DumpValues: out of memory\n");
return;
}
}
if (DataLength > CurrentDataLength) {
CurrentDataLength = DataLength;
free(Data);
Data = malloc(CurrentDataLength);
if (Data == NULL) {
fprintf(stderr, "DumpValues: out of memory\n");
return;
}
}
goto retry;
} else if (Status == ERROR_NO_MORE_ITEMS) {
return;
} else if (Status != ERROR_SUCCESS) {
fprintf(stderr, "DumpValues: out of memory\n");
return;
}
//
// print out value
//
for (j=0;j<Indent;j++) {
printf(" ");
}
printf("%ws = ",Name);
switch (Type) {
case REG_SZ:
printf("REG_SZ %ws\n",Data);
break;
case REG_DWORD:
printf("REG_DWORD 0x%08lx\n",Data);
break;
case REG_BINARY:
printf("REG_BINARY 0x%08lx\n",Data);
break;
default:
printf("UNKNOWN TYPE %d\n",Type);
break;
}
}
free(Name);
free(Data);
}