OpenCAX/entry/src/main/cpp/include/opencascade/IGESData_DirChecker.hxx
2026-02-19 19:05:41 +08:00

177 lines
7.2 KiB
C++

// Created on: 1992-11-10
// Created by: Christian CAILLET
// Copyright (c) 1992-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.
#ifndef _IGESData_DirChecker_HeaderFile
#define _IGESData_DirChecker_HeaderFile
#include "Standard.hxx"
#include "Standard_DefineAlloc.hxx"
#include "Standard_Handle.hxx"
#include "Standard_Integer.hxx"
#include "IGESData_DefType.hxx"
class Interface_Check;
class IGESData_IGESEntity;
//! This class centralizes general Checks upon an IGES Entity's
//! Directory Part. That is : such field Ignored or Required,
//! or Required with a given Value (for an Integer field)
//! More precise checks can be performed as necessary, by each
//! Entity (method OwnCheck).
//!
//! Each class of Entity defines its DirChecker (method DirChecker)
//! and the DirChecker is able to perform its Checks on an Entity
//!
//! A Required Value or presence of a field causes a Fail Message
//! if criterium is not satisfied
//! An Ignored field causes a Correction Message if the field is
//! not null/zero
class IGESData_DirChecker
{
public:
DEFINE_STANDARD_ALLOC
//! Returns a DirChecker, with no criterium at all to be checked
Standard_EXPORT IGESData_DirChecker();
//! Returns a DirChecker, with no criterium except Required Type
Standard_EXPORT IGESData_DirChecker(const Standard_Integer atype);
//! Returns a DirChecker, with no criterium except Required values
//! for Type and Form numbers
Standard_EXPORT IGESData_DirChecker(const Standard_Integer atype, const Standard_Integer aform);
//! Returns a DirChecker, with no criterium except Required values
//! for Type number (atype), and Required Range for Form number
//! (which must be between aform1 and aform2 included)
Standard_EXPORT IGESData_DirChecker(const Standard_Integer atype,
const Standard_Integer aform1,
const Standard_Integer aform2);
//! Returns True if at least one criterium has already been set
//! Allows user to store a DirChecker (static variable) then ask
//! if it has been set before setting it
Standard_EXPORT Standard_Boolean IsSet() const;
//! Sets a DirChecker with most current criteria, that is :
//! Structure Ignored ( worths call Structure(crit = DefVoid) )
Standard_EXPORT void SetDefault();
//! Sets Structure criterium.
//! If crit is DefVoid, Ignored : should not be defined
//! If crit is DefReference, Required : must be defined
//! Other values are not taken in account
Standard_EXPORT void Structure(const IGESData_DefType crit);
//! Sets LineFont criterium
//! If crit is DefVoid, Ignored : should not be defined
//! If crit is DefAny, Required : must be defined (value or ref)
//! If crit is DefValue, Required as a Value (error if Reference)
//! Other values are not taken in account
Standard_EXPORT void LineFont(const IGESData_DefType crit);
//! Sets LineWeight criterium
//! If crit is DefVoid, Ignored : should not be defined
//! If crit is DefValue, Required
//! Other values are not taken in account
Standard_EXPORT void LineWeight(const IGESData_DefType crit);
//! Sets Color criterium
//! If crit is DefVoid, Ignored : should not be defined
//! If crit is DefAny, Required : must be defined (value or ref)
//! Other values are not taken in account
Standard_EXPORT void Color(const IGESData_DefType crit);
//! Sets Graphics data (LineFont, LineWeight, Color, Level, View)
//! to be ignored according value of Hierarchy status :
//! If hierarchy is not given, they are Ignored any way
//! (that is, they should not be defined)
//! If hierarchy is given, Graphics are Ignored if the Hierarchy
//! status has the value given in argument "hierarchy"
Standard_EXPORT void GraphicsIgnored(const Standard_Integer hierarchy = -1);
//! Sets Blank Status to be ignored
//! (should not be defined, or its value should be 0)
Standard_EXPORT void BlankStatusIgnored();
//! Sets Blank Status to be required at a given value
Standard_EXPORT void BlankStatusRequired(const Standard_Integer val);
//! Sets Subordinate Status to be ignored
//! (should not be defined, or its value should be 0)
Standard_EXPORT void SubordinateStatusIgnored();
//! Sets Subordinate Status to be required at a given value
Standard_EXPORT void SubordinateStatusRequired(const Standard_Integer val);
//! Sets Blank Status to be ignored
//! (should not be defined, or its value should be 0)
Standard_EXPORT void UseFlagIgnored();
//! Sets Blank Status to be required at a given value
//! Give -1 to demand UseFlag not zero (but no precise value req.)
Standard_EXPORT void UseFlagRequired(const Standard_Integer val);
//! Sets Hierarchy Status to be ignored
//! (should not be defined, or its value should be 0)
Standard_EXPORT void HierarchyStatusIgnored();
//! Sets Hierarchy Status to be required at a given value
Standard_EXPORT void HierarchyStatusRequired(const Standard_Integer val);
//! Performs the Checks on an IGESEntity, according to the
//! recorded criteria
//! In addition, does minimal Checks, such as admitted range for
//! Status, or presence of Error status in some data (Color, ...)
Standard_EXPORT void Check(Handle(Interface_Check)& ach,
const Handle(IGESData_IGESEntity)& ent) const;
//! Performs a Check only on Values of Type Number and Form Number
//! This allows to do a check on an Entity not yet completely
//! filled but of which Type and Form Number have been already set
Standard_EXPORT void CheckTypeAndForm(Handle(Interface_Check)& ach,
const Handle(IGESData_IGESEntity)& ent) const;
//! Corrects the Directory Entry of an IGES Entity as far as it is
//! possible according recorded criteria without any ambiguity :
//! - if a numeric Status is required a given value, this value is
//! enforced
//! - if an item is required to be Void, or if it recorded as
//! Erroneous, it is cleared (set to Void)
//! - Type Number is enforced
//! - finally Form Number is enforced only if one and only Value
//! is admitted (no range, see Constructors of DirChecker)
Standard_EXPORT Standard_Boolean Correct(const Handle(IGESData_IGESEntity)& ent) const;
protected:
private:
Standard_Boolean isitset;
Standard_Integer thetype;
Standard_Integer theform1;
Standard_Integer theform2;
IGESData_DefType thestructure;
IGESData_DefType thelinefont;
IGESData_DefType thelineweig;
IGESData_DefType thecolor;
Standard_Integer thegraphier;
Standard_Integer theblankst;
Standard_Integer thesubordst;
Standard_Integer theuseflag;
Standard_Integer thehierst;
};
#endif // _IGESData_DirChecker_HeaderFile