-- Created on: 1993-02-04 -- Created by: Christian CAILLET -- Copyright (c) 1993-1999 Matra Datavision -- Copyright (c) 1999-2014 OPEN CASCADE SAS -- -- This file is part of Open CASCADE Technology software library. -- -- This library is free software; you can redistribute it and/or modify it under -- the terms of the GNU Lesser General Public License version 2.1 as published -- by the Free Software Foundation, with special exception defined in the file -- OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -- distribution for complete text of the license and disclaimer of any warranty. -- -- Alternatively, this file may be used under the terms of Open CASCADE -- commercial license or contractual agreement. deferred class ReaderModule from Interface inherits TShared ---Purpose : Defines unitary operations required to read an Entity from a -- File (see FileReaderData, FileReaderTool), under control of -- a FileReaderTool. The initial creation is performed by a -- GeneralModule (set in GeneralLib). Then, which remains is -- Loading data from the FileReaderData to the Entity -- -- To work, a GeneralModule has formerly recognized the Type read -- from FileReaderData as a positive Case Number, then the -- ReaderModule reads it according to this Case Number uses Transient, FileReaderData, Check raises DomainError is CaseNum (me; data : FileReaderData; num : Integer) returns Integer is deferred; ---Purpose : Translates the type of record in to a positive -- Case Number. If Recognition fails, must return 0 Read (me; casenum : Integer; data : FileReaderData; num : Integer; ach : in out Check; ent : mutable Transient) ---Purpose : Performs the effective loading from , record , -- to the Entity formerly created -- In case of Error or Warning, fills with messages -- Remark that the Case Number comes from translating a record raises DomainError is deferred; -- Can raise any exception, while it is preferable to prevent -- them and fill the Check NewRead (me; casenum : Integer; data : FileReaderData; num : Integer; ach : in out Check; ent : out mutable Transient) returns Boolean ---Purpose : Specific operator (create+read) defaulted to do nothing. -- It can be redefined when it is not possible to work in two -- steps (NewVoid then Read). This occurs when no default -- constructor is defined : hence the result must be -- created with an effective definition from the reader. -- Remark : if NewRead is defined, Copy has nothing to do. -- -- Returns True if it has produced something, false else. -- If nothing was produced, should be filled : it will be -- treated as "Unrecognized case" by reader tool. raises DomainError is virtual; -- Can raise any exception, while it is preferable to prevent -- them and fill the Check end ReaderModule;