Open CASCADE Technology Reference Manual 8.0.0
Loading...
Searching...
No Matches
Public Member Functions
IFSelect_SelectSignature Class Reference

A SelectSignature sorts the Entities on a Signature Matching. The signature to match is given at creation time. Also, the required match is given at creation time : exact (IsEqual) or contains (the Type's Name must contain the criterium Text) More...

#include <IFSelect_SelectSignature.hxx>

Inheritance diagram for IFSelect_SelectSignature:
Inheritance graph
[legend]

Public Member Functions

 IFSelect_SelectSignature (const occ::handle< IFSelect_Signature > &matcher, const char *const signtext, const bool exact=true)
 Creates a SelectSignature with its Signature and its Text to Match. <exact> if True requires exact match, if False requires <signtext> to be contained in the Signature of the entity (default is "exact")
 
 IFSelect_SelectSignature (const occ::handle< IFSelect_Signature > &matcher, const TCollection_AsciiString &signtext, const bool exact=true)
 As above with an AsciiString.
 
 IFSelect_SelectSignature (const occ::handle< IFSelect_SignCounter > &matcher, const char *const signtext, const bool exact=true)
 Creates a SelectSignature with a Counter, more precisely a SelectSignature. Which is used here to just give a Signature Value (by SignOnly Mode) Matching is the default provided by the class Signature.
 
occ::handle< IFSelect_SignatureSignature () const
 Returns the used Signature, then it is possible to access it, modify it as required. Can be null, hence see Counter.
 
occ::handle< IFSelect_SignCounterCounter () const
 Returns the used SignCounter. Can be used as alternative for Signature.
 
bool SortInGraph (const int rank, const occ::handle< Standard_Transient > &ent, const Interface_Graph &G) const override
 Returns True for an Entity (model->Value(num)) of which the signature matches the text given as creation time May also work with a Counter from the Graph.
 
bool Sort (const int rank, const occ::handle< Standard_Transient > &ent, const occ::handle< Interface_InterfaceModel > &model) const override
 Not called, defined only to remove a deferred method here.
 
const TCollection_AsciiStringSignatureText () const
 Returns Text used to Sort Entity on its Signature or SignCounter.
 
bool IsExact () const
 Returns True if match must be exact.
 
TCollection_AsciiString ExtractLabel () const override
 Returns a text defining the criterium. (it refers to the text and exact flag to be matched, and is qualified by the Name provided by the Signature)
 
- Public Member Functions inherited from IFSelect_SelectExtract
bool IsDirect () const
 Returns True if Sort criterium is Direct, False if Reverse.
 
void SetDirect (const bool direct)
 Sets Sort criterium sense to a new value (True : Direct , False : Reverse)
 
Interface_EntityIterator RootResult (const Interface_Graph &G) const override
 Returns the list of selected entities. Works by calling the method Sort on each input Entity : the Entity is kept as output if Sort returns the same value as Direct status.
 
TCollection_AsciiString Label () const override
 Returns a text saying "Picked" or "Removed", plus the specific criterium returned by ExtractLabel (see below)
 
- Public Member Functions inherited from IFSelect_SelectDeduct
void SetInput (const occ::handle< IFSelect_Selection > &sel)
 Defines or Changes the Input Selection.
 
occ::handle< IFSelect_SelectionInput () const
 Returns the Input Selection.
 
bool HasInput () const
 Returns True if the Input Selection is defined, False else.
 
bool HasAlternate () const
 Tells if an Alternate List has been set, i.e. : the Alternate Definition is present and set.
 
occ::handle< IFSelect_SelectPointed > & Alternate ()
 Returns the Alternate Definition It is returned modifiable, hence an already defined SelectPointed can be used But if it was not yet defined, it is created the first time.
 
Interface_EntityIterator InputResult (const Interface_Graph &G) const
 Returns the Result determined by Input Selection, as Unique if Input Selection is not defined, returns an empty list.
 
void FillIterator (IFSelect_SelectionIterator &iter) const override
 Puts in an Iterator the Selections from which "me" depends This list contains one Selection : the InputSelection.
 
- Public Member Functions inherited from IFSelect_Selection
Interface_EntityIterator UniqueResult (const Interface_Graph &G) const
 Returns the list of selected entities, each of them being unique. Default definition works from RootResult. According HasUniqueResult, UniqueResult returns directly RootResult, or build a Unique Result from it with a Graph.
 
virtual Interface_EntityIterator CompleteResult (const Interface_Graph &G) const
 Returns the list of entities involved by a Selection, i.e. UniqueResult plus the shared entities (directly or not)
 
- Public Member Functions inherited from Standard_Transient
 Standard_Transient ()
 Empty constructor.
 
 Standard_Transient (const Standard_Transient &)
 Copy constructor – does nothing.
 
Standard_Transientoperator= (const Standard_Transient &)
 Assignment operator, needed to avoid copying reference counter.
 
virtual ~Standard_Transient ()=default
 Destructor must be virtual.
 
virtual const opencascade::handle< Standard_Type > & DynamicType () const
 Returns a type descriptor about this object.
 
bool IsInstance (const opencascade::handle< Standard_Type > &theType) const
 Returns a true value if this is an instance of Type.
 
bool IsInstance (const char *const theTypeName) const
 Returns a true value if this is an instance of TypeName.
 
bool IsKind (const opencascade::handle< Standard_Type > &theType) const
 Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
bool IsKind (const char *const theTypeName) const
 Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
Standard_TransientThis () const
 Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero.
 
int GetRefCount () const noexcept
 Get the reference counter of this object.
 
void IncrementRefCounter () noexcept
 Increments the reference counter of this object. Uses relaxed memory ordering since incrementing only requires atomicity, not synchronization with other memory operations.
 
int DecrementRefCounter () noexcept
 Decrements the reference counter of this object; returns the decremented value. Uses release ordering for the decrement to ensure all writes to the object are visible before the count reaches zero. An acquire fence is added only when the count reaches zero, ensuring proper synchronization before deletion. This is more efficient than using acq_rel for every decrement.
 
virtual void Delete () const
 Memory deallocator for transient classes.
 

Additional Inherited Members

- Public Types inherited from Standard_Transient
typedef void base_type
 Returns a type descriptor about this object.
 
- Static Public Member Functions inherited from Standard_Transient
static constexpr const charget_type_name ()
 Returns a type descriptor about this object.
 
static const opencascade::handle< Standard_Type > & get_type_descriptor ()
 Returns type descriptor of Standard_Transient class.
 
- Protected Member Functions inherited from IFSelect_SelectExtract
 IFSelect_SelectExtract ()
 Initializes a SelectExtract : enforces the sort to be Direct.
 
- Protected Member Functions inherited from IFSelect_Selection
virtual bool HasUniqueResult () const
 Returns True if RootResult guarantees uniqueness for each Entity. Called by UniqueResult. Default answer is False. Can be redefined.
 

Detailed Description

A SelectSignature sorts the Entities on a Signature Matching. The signature to match is given at creation time. Also, the required match is given at creation time : exact (IsEqual) or contains (the Type's Name must contain the criterium Text)

Remark that no more interpretation is done, it is an alphanumeric signature : for instance, DynamicType is matched as such, super-types are not considered

Also, numeric (integer) comparisons are supported : an item can be <val ou <=val or >val or >=val , val being an Integer

A SelectSignature may also be created from a SignCounter, which then just gives its LastValue as SignatureValue

Constructor & Destructor Documentation

◆ IFSelect_SelectSignature() [1/3]

IFSelect_SelectSignature::IFSelect_SelectSignature ( const occ::handle< IFSelect_Signature > & matcher,
const char *const signtext,
const bool exact = true )

Creates a SelectSignature with its Signature and its Text to Match. <exact> if True requires exact match, if False requires <signtext> to be contained in the Signature of the entity (default is "exact")

◆ IFSelect_SelectSignature() [2/3]

IFSelect_SelectSignature::IFSelect_SelectSignature ( const occ::handle< IFSelect_Signature > & matcher,
const TCollection_AsciiString & signtext,
const bool exact = true )

As above with an AsciiString.

◆ IFSelect_SelectSignature() [3/3]

IFSelect_SelectSignature::IFSelect_SelectSignature ( const occ::handle< IFSelect_SignCounter > & matcher,
const char *const signtext,
const bool exact = true )

Creates a SelectSignature with a Counter, more precisely a SelectSignature. Which is used here to just give a Signature Value (by SignOnly Mode) Matching is the default provided by the class Signature.

Member Function Documentation

◆ Counter()

occ::handle< IFSelect_SignCounter > IFSelect_SelectSignature::Counter ( ) const

Returns the used SignCounter. Can be used as alternative for Signature.

◆ ExtractLabel()

TCollection_AsciiString IFSelect_SelectSignature::ExtractLabel ( ) const
overridevirtual

Returns a text defining the criterium. (it refers to the text and exact flag to be matched, and is qualified by the Name provided by the Signature)

Implements IFSelect_SelectExtract.

◆ IsExact()

bool IFSelect_SelectSignature::IsExact ( ) const

Returns True if match must be exact.

◆ Signature()

occ::handle< IFSelect_Signature > IFSelect_SelectSignature::Signature ( ) const

Returns the used Signature, then it is possible to access it, modify it as required. Can be null, hence see Counter.

◆ SignatureText()

const TCollection_AsciiString & IFSelect_SelectSignature::SignatureText ( ) const

Returns Text used to Sort Entity on its Signature or SignCounter.

◆ Sort()

bool IFSelect_SelectSignature::Sort ( const int rank,
const occ::handle< Standard_Transient > & ent,
const occ::handle< Interface_InterfaceModel > & model ) const
overridevirtual

Not called, defined only to remove a deferred method here.

Implements IFSelect_SelectExtract.

◆ SortInGraph()

bool IFSelect_SelectSignature::SortInGraph ( const int rank,
const occ::handle< Standard_Transient > & ent,
const Interface_Graph & G ) const
overridevirtual

Returns True for an Entity (model->Value(num)) of which the signature matches the text given as creation time May also work with a Counter from the Graph.

Reimplemented from IFSelect_SelectExtract.


The documentation for this class was generated from the following file: