This sample agent, Comm1, run at the same time as an identical one named Comm2, illustrates how you can use code locks to synchronize agent execution.
Run concurrently, these agents create a named lock called "Update," then:
'Comm1:
Option Public
' Remove the following line if you do not have a ' resource library defined. Use "ThreadsLib"
Sub Initialize Dim lockName As String Dim lockID As Integer, refcnt As Integer Dim gotLock As Variant, releaseLock As Variant, _ deleteLock As Variant
On Error Goto syn_error
' Provide some unique name here to distinguish the agents. ID = "Comm1 tuvwx:5706 " Msgbox ID & "Started"
lockName = "Update" On Error Goto syn_error
' Create the lock lockID = Createlock(uName) If (lockID <> -1) Then Msgbox ID & "Created lock: " & lockID End If
' Put agent to sleep for a second. ' This gives the second agent time to start. Sleep 1
For x = 1 To 5
' Attempt to get the lock and report the outcome ' as well as the reference count gotLock = CodeLock(lockID) If (gotLock) Then Msgbox ID & " Got lock: " & lockID & " - at: " & _ Now() refcnt = Codelockcheck(lockID) Msgbox ID & " Reference count is " & refcnt
' Do some meaningful work here, or just sleep Sleep 1 Else Msgbox ID & "Failed to get lock" End If
' Release the lock so the other agent can get it. releaseLock = Codeunlock(lockID) If (releaseLock) Then Msgbox ID & " Releasing lock: " & lockID & _ " - at: " & Now()
' Sleep here allows the other agents to obtain ' the lock before this agent has a chance to. Sleep 1 Else Msgbox ID & "Failed to release lock" End If
Next
' When we are finished, destroy this agent's reference ' to the lock deleteLock = Destroylock(lockID) If (deleteLock ) Then Msgbox ID & "Destroyed lock " & lockID Else Msgbox ID & "Failed to destroy lock" End If
Msgbox ID & "Done " Exit Sub
syn_error: errormsg = " * * Error: " & Err & " - " & Error() & _ " in " & ID & " at " & Erl() Msgbox errormsg Resume Next
End Sub
A sample output of Comm1 (with an ID of tuvwx:5706) and Comm2 (with an ID of uvwxy:5742) running concurrently as agents through the Domino Web server would look something like the following:
Note Your results will not be identical; due to the nature of asynchronous system locks, you can never predict when specific events will occur.
Addin: Agent message box: Comm1 tuvwx:5706 Started Addin: Agent message box: Comm1 tuvwx:5706 Created lock: 0 Addin: Agent message box: Comm2 uvwxy:5742 Started Addin: Agent message box: Comm2 uvwxy:5742 Created lock: 0 Addin: Agent message box: Comm1 tuvwx:5706 Got lock: 0 - at: 2/10/99 1:57:06 PM Addin: Agent message box: Comm1 tuvwx:5706 Reference count is 1 Addin: Agent message box: Comm2 uvwxy:5742 Got lock: 0 - at: 2/10/99 1:57:07 PM Addin: Agent message box: Comm2 uvwxy:5742 Reference count is 1 Addin: Agent message box: Comm1 tuvwx:5706 Releasing update_lock: 0 - at: 2/10/99 1:57:07 PM Addin: Agent message box: Comm2 uvwxy:5742 Releasing update_lock: 0 - at: 2/10/99 1:57:08 PM Addin: Agent message box: Comm1 tuvwx:5706 Got lock: 0 - at: 2/10/99 1:57:08 PM Addin: Agent message box: Comm1 tuvwx:5706 Reference count is 1 Addin: Agent message box: Comm2 uvwxy:5742 Got lock: 0 - at: 2/10/99 1:57:09 PM Addin: Agent message box: Comm2 uvwxy:5742 Reference count is 1 Addin: Agent message box: Comm1 tuvwx:5706 Releasing lock: 0 - at: 2/10/99 1:57:09 PM Addin: Agent message box: Comm2 uvwxy:5742 Releasing lock: 0 - at: 2/10/99 1:57:10 PM Addin: Agent message box: Comm1 tuvwx:5706 Got lock: 0 - at: 2/10/99 1:57:10 PM Addin: Agent message box: Comm1 tuvwx:5706 Reference count is 1 Addin: Agent message box: Comm2 uvwxy:5742 Got lock: 0 - at: 2/10/99 1:57:12 PM Addin: Agent message box: Comm2 uvwxy:5742 Reference count is 1 Addin: Agent message box: Comm1 tuvwx:5706 Releasing lock: 0 - at: 2/10/99 1:57:12 PM Addin: Agent message box: Comm2 uvwxy:5742 Releasing lock: 0 - at: 2/10/99 1:57:13 PM Addin: Agent message box: Comm1 tuvwx:5706 Got lock: 0 - at: 2/10/99 1:57:13 PM Addin: Agent message box: Comm1 tuvwx:5706 Reference count is 1 Addin: Agent message box: Comm2 uvwxy:5742 Got lock: 0 - at: 2/10/99 1:57:14 PM Addin: Agent message box: Comm2 uvwxy:5742 Reference count is 1 Addin: Agent message box: Comm1 tuvwx:5706 Releasing lock: 0 - at: 2/10/99 1:57:14 PM Addin: Agent message box: Comm2 uvwxy:5742 Releasing lock: 0 - at: 2/10/99 1:57:15 PM Addin: Agent message box: Comm1 tuvwx:5706 Got lock: 0 - at: 2/10/99 1:57:15 PM Addin: Agent message box: Comm1 tuvwx:5706 Reference count is 1 Addin: Agent message box: Comm2 uvwxy:5742 Got lock: 0 - at: 2/10/99 1:57:16 PM Addin: Agent message box: Comm2 uvwxy:5742 Reference count is 1 Addin: Agent message box: Comm1 tuvwx:5706 Releasing lock: 0 - at: 2/10/99 1:57:16 PM Addin: Agent message box: Comm2 uvwxy:5742 Releasing lock: 0 - at: 2/10/99 1:57:18 PM Addin: Agent message box: Comm1 tuvwx:5706 Destroyed lock 0 Addin: Agent message box: Comm1 tuvwx:5706 Done Addin: Agent message box: Comm2 uvwxy:5742 Destroyed lock 0 Addin: Agent message box: Comm2 uvwxy:5742 Done
These primitives are used only for communication between instances of cooperating LotusScript agents within a single process. They are designed specifically for asynchronous Web agents.
Supported platforms include Win32, OS/2, UNIX (Solaris, HPUX, AIX), and Alpha-NT.
See Also