Level Extreme platform
Subscription
Corporate profile
Products & Services
Support
Legal
Français
A New Twist On Is App Running
Message
General information
Forum:
Visual FoxPro
Category:
Windows API functions
Miscellaneous
Thread ID:
00409058
Message ID:
00409188
Views:
35
>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.

PMFJI,

Ed, this is really an exciting chunk of code! Until now, I've always played the Window Title game. I've tested it and I've gone to MSDN to read about it and about WaitForSingleObject so I wouldn't be wasting your time.

I'm not an API genius, but I'd love to understand this a bit more. I'm not sure I follow what's going on here.

Are you registering a bogus event with Windows? The 1 makes it signalled , right? So, if I wanted to WaitForSingleObject, I'd wait to see the signalled state turn off? I saw SetEvent and ResetEvent for that. I guess the piece I'm missing is: What is this "event" thing that we're creating? Is it just like a flag? and Would I need to write a loop around WaitForSingleObject or is that the cool thing about it is that it sits there and "polls" the event?

Thanks!

Marty
Marty Smith, CSQE
Previous
Next
Reply
Map
View

Click here to load this message in the networking platform