PRB: DDEInitiate() Gives Remote Data Not Accessible Dialog Box (105005)



The information in this article applies to:

  • Microsoft Visual FoxPro for Windows 3.0
  • Microsoft FoxPro for Windows 2.5
  • Microsoft FoxPro for Windows 2.5a

This article was previously published under Q105005

SYMPTOMS

In FoxPro for Windows the DDEInitiate() function may result in getting an undesirable "? Remote data not accessible. Start application '<appname>.EXE'?" dialog box.

Code following the DDEInitiate() function may check for the return of -1, which indicates that the channel was not established; however, the code is not yet executed.

CAUSE

The default setting for the Safety clause of the DDESetOption() function is true (.T.). This setting specifies whether a dialog box is displayed when the DDEInitiate() function is used to establish a channel to a server application and the application is not currently open.

RESOLUTION

Issue the DDESetOption() function prior to the DDEInitiate() function to change the setting for Safety to false (.F.).

For example, the following code establishes a DDE channel between Microsoft FoxPro for Windows and Microsoft Excel, even if Microsoft Excel is not presently minimized in the Windows background, without receiving the dialog box message mentioned above:
   =DDESetOption("SAFETY",.F.)
   DO WHILE .T.
      =DDESetOption("TimeOut",10000)
      iChannel=DDEInitiate("Excel","System")
      =DDESetOption("TimeOut",2000)
      IF iChannel !=-1   && If Excel is started, exit loop
         EXIT
      ELSE             && Start Excel & try to get channel
         RUN /N3 d:\msoffice\excel\excel.exe   && Change this line
                                      && according to your path to Excel.
      ENDIF
   ENDDO
				

REFERENCES

"Language Reference," version 2.5, pages L3-366, L3-374

Modification Type:MajorLast Reviewed:11/17/2003
Keywords:kbprb KB105005