Using NDdeShareAdd to Create a DDE Share
The
NDdeShareAdd function is used by a DDE server application to create a DDE share.
Before creating a DDE share, it is a good idea to verify that the proposed
share name and topic name are valid by using the
NDdeIsValidShareName and
NDdeIsValidAppTopicList functions. These functions are also called by
NDdeShareAdd.
The following example demonstrates how to create a DDE share. It uses a NULL
discretionary access control list (DACL) to grant write access to all users.
Note that this is not the same as specifying NULL in the
pSD parameter of
NDdeShareAdd.
BOOL MyCreateDdeShare( LPTSTR lpszShareName, LPTSTR lpszTopicList )
{
NDDESHAREINFO ndsi;
PSECURITY_DESCRIPTOR pSD = NULL;
// Where lpszShareName is the share name.
if( NDdeIsValidShareName( lpszShareName ) == FALSE )
return FALSE;
// Where lpszTopicList is a list of null-terminated strings terminated
// by another null character.
if( NDdeIsValidAppTopicList( lpszTopicList ) == FALSE )
return FALSE;
// Fill in the NDDESHAREINFO structure.
ndsi.lRevision = 1;
ndsi.lpszShareName = lpszShareName;
ndsi.lShareType = SHARE_TYPE_STATIC;
ndsi.lpszAppTopicList = lpszTopicList;
ndsi.fSharedFlag = TRUE;
ndsi.fService = FALSE;
ndsi.fStartAppFlag = TRUE;
ndsi.nCmdShow = SW_SHOWNORMAL;
ndsi.cNumItems = 0;
ndsi.lpszItemList = "";
// Create a security descriptor to allow write access.
pSD = (PSECURITY_DESCRIPTOR) LocalAlloc(
LPTR,
SECURITY_DESCRIPTOR_MIN_LENGTH );
InitializeSecurityDescriptor( pSD, SECURITY_DESCRIPTOR_REVISION );
SetSecurityDescriptorDacl( pSD, TRUE, (PACL)NULL, FALSE );
// Delete possible old DDE share.
NDdeShareDel(
NULL,
lpszShareName,
0
);
// Create the DDE share.
NDdeShareAdd(
NULL,
2,
pSD,
(LPBYTE)&ndsi,
sizeof(NDDESHAREINFO)
);
LocalFree( pSD );
return TRUE;
}
The following example shows how you could call the MyCreateDdeShare function
to create the share MyDdeShare$:
char *TopicList = "\0\0MyApp|MyTopic\0\0";
MyCreateDdeShare( "MyDdeShare$", TopicList );
This share name ends with a dollar sign ($), indicating that it is a static
DDE share. Topic strings are provided only for the static-type DDE share.
- Software for developers
-
Delphi Components
.Net Components
Software for Android Developers
- More information resources
-
MegaDetailed.Net
Unix Manual Pages
Delphi Examples
- Databases for Amazon shops developers
-
Amazon Categories Database
Browse Nodes Database