1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-06-30 12:14:08 +03:00
occt/src/OSD/OSD_Semaphore.cdl
bugmaster b311480ed5 0023024: Update headers of OCCT files
Added appropriate copyright and license information in source files
2012-03-21 19:43:04 +04:00

129 lines
4.6 KiB
Plaintext
Executable File

-- 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;