Terminating a Conversation
Either the client or the server can issue a
WM_DDE_TERMINATE message to terminate a conversation at any time. Similarly, both the client
and server applications should be prepared to receive this message at any time.
An application must terminate all of its conversations before shutting down.
In the following example, the application terminating the conversation posts a
WM_DDE_TERMINATE message.
PostMessage(hwndServerDDE, WM_DDE_TERMINATE,
PackDDElParam(WM_DDE_TERMINATE, (UINT) hwndClientDDE, 0), 0);
This informs the other application that the sending application will send no
further messages and the recipient can close its window. The recipient is
expected in all cases to respond promptly by sending a
WM_DDE_TERMINATE message. The recipient must not send a negative, busy, or positive
WM_DDE_ACK message.
After an application has sent the WM_DDE_TERMINATE message to the partner in a
DDE conversation, it must not respond to messages from that partner, since the
partner might have destroyed the window to which the response would be sent.
If an application receives a DDE message other than WM_DDE_TERMINATE after it
has posted WM_DDE_TERMINATE, it should free all objects associated with the
received messages except the data handles for
WM_DDE_DATA or
WM_DDE_POKE messages that do
not have the
fRelease member set.
When an application is about to terminate, it should end all active DDE
conversations before completing processing of the
WM_DESTROY message. However, if an application does not end its active DDE
conversations, the system will terminate any DDE conversations associated with a window when
the window is destroyed. The following example shows how a server application
terminates all DDE conversations.
- oid TerminateConversations(hwndServerDDE)
HWND hwndServerDDE;
{
HWND hwndClientDDE;
/* Terminate each active conversation. */
while (hwndClientDDE = GetNextLink(hwndClientDDE)) {
SendTerminate(hwndServerDDE, hwndClientDDE);
}
return;
}
BOOL AtLeastOneLinkActive(VOID)
{
return TRUE;
}
HWND GetNextLink(hwndDummy)
HWND hwndDummy;
{
return (HWND) 1;
}
VOID SendTerminate(HWND hwndServerDDE, HWND hwndClientDDE)
{
return;
}
- 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