-- Created on: 1992-04-21 -- Created by: Stephan GARNAUD (ARM) -- Copyright (c) 1992-1999 Matra Datavision -- Copyright (c) 1999-2012 OPEN CASCADE SAS -- -- The content of this file is subject to the Open CASCADE Technology Public -- License Version 6.5 (the "License"). You may not use the content of this file -- except in compliance with the License. Please obtain a copy of the License -- at http://www.opencascade.org and read it completely before using this file. -- -- The Initial Developer of the Original Code is Open CASCADE S.A.S., having its -- main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France. -- -- The Original Code and all software distributed under the License is -- distributed on an "AS IS" basis, without warranty of any kind, and the -- Initial Developer hereby disclaims all such warranties, including without -- limitation, any warranties of merchantability, fitness for a particular -- purpose or non-infringement. Please see the License for the specific terms -- and conditions governing the rights and limitations under the License. class Semaphore from OSD ---Purpose: IPC Tools -Semaphores -- The semaphores are used to facilitate shared resources. -- This implementation provides a way to ensure mutual -- exclusion using 'Lock' and 'Free' primitives. -- The Lock is used to prevent access if it's not yet allowed. -- The Free validates the semaphores and if possible, frees process -- waiting for a common resource. uses Protection, Error, AsciiString from TCollection raises ConstructionError, OSDError, ProgramError is Create returns Semaphore; ---Purpose: Allocate room for semaphore name. -- This is to be used with 'Open'. -- so the process is a client. ---Level: Advanced Create (Name : AsciiString) returns Semaphore ---Purpose: Instantiates Semaphore object with a name. -- The name is the only way provided to work with a common -- semaphore for different processes. -- Each process working with the same semaphore must use -- a common known access : the semaphore's NAME. -- Raises ConstructionError when the name contains characters -- not in range of ' '...'~'. -- This is for a server process. ---Level: Advanced raises ConstructionError; Build (me : in out) is static; ---Purpose: Sets semaphore (physically) into memory ---Level: Advanced Open (me : in out ; Name : AsciiString) ---Purpose: Opens (physically) a semaphore -- Raises ConstructionError when the name contains characters -- not in range of ' '...'~'. ---Level: Advanced raises ConstructionError is static; GetCounter (me : in out) returns Integer is static; ---Purpose: Returns current value of the semaphore's counter. -- Raises ProgramError when the semaphore is not open. ---Level: Advanced SetCounter (me : in out; Value : Integer) is static; ---Purpose: Sets the semaphore's counter to a specific value. -- Raises ProgramError when the semaphore is not open. ---Level: Advanced Delete (me: out) ---Purpose: Removes the semaphore. -- This is used only by server process ! -- Raise ProgramError if the semaphore is already deleted. ---Level: Advanced raises ProgramError is static; Lock (me: out) ---Purpose: Makes current process waiting for access -- Raises ProgramError when the semaphore does't exist. ---Level: Advanced raises ProgramError is static; Free (me: out) ---Purpose: Frees one access to a semaphore. -- Raises ProgramError when the semaphore does't exist. ---Level: Advanced raises ProgramError is static; Restore (me : in out) ---Purpose: Resets semaphore counter to zero. -- Raises ProgramError when the semaphore does't exist. ---Level: Advanced raises ProgramError is static; Failed (me) returns Boolean is static; ---Purpose: Returns TRUE if an error occurs ---Level: Advanced Reset (me : in out) is static; ---Purpose: Resets error counter to zero ---Level: Advanced Perror (me : in out) ---Purpose: Raises OSD_Error ---Level: Advanced raises OSDError is static; Error (me) returns Integer is static; ---Purpose: Returns error number if 'Failed' is TRUE. ---Level: Advanced fields myName : AsciiString; -- The semaphore name myKey : Integer; mySemId : Integer; -- Internal identification of semaphore myError : Error; end Semaphore from OSD;