Level Extreme platform
Subscription
Corporate profile
Products & Services
Support
Legal
Français
A New Twist On Is App Running
Message
From
31/05/2007 18:58:56
 
 
To
31/05/2007 01:27:21
General information
Forum:
Visual FoxPro
Category:
Windows API functions
Miscellaneous
Thread ID:
00409058
Message ID:
01229708
Views:
19
Jos, I had to modify this slightly as I am working with a window name as my event name instead of program(0)...

We had a couple of problems in the developer environment, but this seemed to work perfectly on the distributed app on test machines and at our client site live...


*-- the code: returns .t. if app is already running
LPARAMETERS tname

LOCAL jreturn
jreturn=.f.

*!*	*-- CODE COMMENTS FROM ED RAUGH ON THE UT, modified slightly - returns .t. or .f.
*!*	Forum:     Thread ID:   409058  
*!*	Category:     Message ID:   409114  
*!*	Title:  Re: A New Twist On Is App Running  
*!*	  

*!*	This has the advantage that it derives it's Event name from the executable, and if you do forget to issue a 
*!*	CloseHandle(), it still releases the Event object without bleeding, and the Event object completely 
*!*	disappears automagically when no remaining Event refs exist. 
*!*	CLOSE ALL will release the Event. You can use the Event for synchronizing several processes or thread using 
*!*	WaitForSingleObject() to wait on someone to 'raise' the event if you need some sort of event monitoring. 
*!*	Works under all OS versions I tested - not checked under Win95, but does work on Win98 and ME, as well as NT and 2K.

*!*	You can use any name you want if linking to the app's initial program doesn't work for you - I chose that because it's easy to get right, and presumably you want to block other instances of the app you're starting.
*!*	EMail: EdR@edrauh.com
*!*	"See, the sun is going down..."
*!*	"No, the horizon is moving up!"
*!*	- Firesign Theater





DECLARE INTEGER CreateEvent IN WIN32API ;
   INTEGER lpEventAttributes, ;
   SHORT bManualReset, ;
   SHORT bInitialState, ;
   STRING @ lpName
DECLARE INTEGER GetLastError IN Win32API
DECLARE CloseHandle IN Win32API INTEGER hObject
nEh = CreateEvent(0,0,1, tname + '.EVENT')
IF GetLastError() = 183 OR nEh = 0
   *  There's an instance running already (183) or the Event can't be defined
   *  So don't do it;  do release the handle, since it's harmless and should
   *  be done rather than relying on Windows to clean up after itself
   =CloseHandle(nEh)
   jreturn=.t.
ENDIF

RETURN jreturn
>Hi Stacy and All,
>
>I found this same problem under Vista but I cannot make Ed's code work for me. If I pass program(0) as the parameter to CreateEvent() then I can still open multiple copies of my program. Each gives a non-zero handle and GetLastError() returns 0. If I pass _VFP.ServerName as the parameter to CreateEvent() then the very first instance says that a copy is already running i.e. the one that is now doing the test! Any idea how to get around this?
>
>
>>Ed, thanks for the code example here, still helping folks with your info...
>>
>>We found out recently that the older versions based on a windows handle no longer operate properly under Vista if the application is minimized during use. The handle does not appear to be released when the app is closed.
>>
>>Your sample listed here appears to work perfectly!
>>
>>
>>>>I have an application that runs in the background. There is no user intervention via the application. One issue I have is people running the application more than one cause they cannot see it is running. I need to be able to detect the running app without using the Title bar as part of the solution. So I can just ignore someone trying to run it again.
>>>>
>>>>
>>>>Any Ideas? George :)
>>>>
>>>
>>>I'm not George, but I like using the native Event object for the OS via a couple of API calls:
>>>
>>>
DECLARE INTEGER CreateEvent IN WIN32API ;
>>>   INTEGER lpEventAttributes, ;
>>>   SHORT bManualReset, ;
>>>   SHORT bInitialState, ;
>>>   STRING @ lpName
>>>DECLARE INTEGER GetLastError IN Win32API
>>>DECLARE CloseHandle IN Win32API INTEGER hObject
>>>nEh = CreateEvent(0,0,1, PROGRAM(0) + '.EVENT')
>>>IF GetLastError() = 183 OR nEh = 0
>>>   *  There's an instance running already (183) or the Event can't be defined
>>>   *  So don't do it;  do release the handle, since it's harmless and should
>>>   *  be done rather than relying on Windows to clean up after itself
>>>   =CloseHandle(nEh)
>>>   QUIT
>>>ENDIF
>>>
>>>*  While shutting down, issue:
>>>=CloseHandle(nEh)
>>>
>>>This has the advantage that it derives it's Event name from the executable, and if you do forget to issue a CloseHandle(), it still releases the Event object without bleeding, and the Event object completely disappears automagically when no remaining Event refs exist. CLOSE ALL will release the Event. You can use the Event for synchronizing several processes or thread using WaitForSingleObject() to wait on someone to 'raise' the event if you need some sort of event monitoring. Works under all OS versions I tested - not checked under Win95, but does work on Win98 and ME, as well as NT and 2K.
>>>
>>>You can use any name you want if linking to the app's initial program doesn't work for you - I chose that because it's easy to get right, and presumably you want to block other instances of the app you're starting.
Thanks,

Stacy



Black Mountain Software, Inc.
Previous
Reply
Map
View

Click here to load this message in the networking platform