Hoops Visualize HPS  version 2018-SP2
Hoops Visualize HPS 3D Rendering Engine
Looking for a senior C++ dev?
I'm looking for work. Hire me!
HPS::Exchange::TranslationNotifier Class Reference

The TranslationNotifier class is a smart-pointer that is tied to a file translation. More...

#include <sprk_exchange.h>

Inheritance diagram for HPS::Exchange::TranslationNotifier:
Collaboration diagram for HPS::Exchange::TranslationNotifier:

Public Member Functions

 TranslationNotifier ()
 The default constructor creates an TranslationNotifier object which is not tied to any file translation. More...
 
 TranslationNotifier (TranslationNotifier const &in_that)
 The copy constructor creates a new TranslationNotifier object that is associated with the same file translation as the source TranslationNotifier. More...
 
 TranslationNotifier (IONotifier const &in_that)
 The conversion constructor creates a new derived TranslationNotifier object from a base IONotifier object. More...
 
 TranslationNotifier (TranslationNotifier &&in_that)
 The move constructor creates an TranslationNotifier by transferring the underlying impl of the rvalue reference to this TranslationNotifier thereby avoiding a copy and allocation. More...
 
TranslationNotifieroperator= (TranslationNotifier &&in_that)
 The move assignment operator transfers the underlying impl of the rvalue reference to this TranslationNotifier thereby avoiding a copy. More...
 
virtual ~TranslationNotifier ()
 
HPS::Type ObjectType () const
 
TranslationNotifieroperator= (TranslationNotifier const &in_that)
 Associate this TranslationNotifier with the same file translation as the source TranslationNotifier. More...
 
void Assign (TranslationNotifier const &in_that)
 Associate this TranslationNotifier with the same file translation as the source TranslationNotifier. More...
 
Exchange::ParasolidEntityArray GetParasolidParts () const
 Get the Parasolid parts obtained from the translation. More...
 
HPS::Time GetImportTime () const
 Get the number of milliseconds it took Exchange to read the CAD file(s) and generate the corresponding PRC data. More...
 
HPS::Time GetTranslationTime () const
 Get the number of milliseconds it took Exchange to translate the PRC data into Parasolid data. More...
 
void Assign (IONotifier const &in_that)
 Associate this IONotifier with the same file IO operation as the source IONotifier. More...
 
IONotifierWait ()
 Cause this thread to sleep until the asynchronous file IO operation associated with this notifier is complete. More...
 
IOResult Status () const
 Query the status of the file IO operation for this notifier. More...
 
IOResult Status (float &out_percent_complete) const
 Query the status and completion percentage of the file IO for this notifier. More...
 
IONotifierCancel ()
 Requests to cancel the asynchronous file IO if it is still in progress. More...
 
virtual HPS::Type Type () const
 This function returns the true type of the underlying object. More...
 
virtual bool Empty () const
 Indicates whether this object has any values set on it. More...
 
virtual void Reset ()
 Resets this object to its initial, uninitialized state. More...
 
bool HasType (HPS::Type in_mask) const
 This function indicates whether this Object has the given Type mask. More...
 
intptr_t GetClassID () const
 Returns a unique identifier that is shared by all objects of the same class. More...
 
intptr_t GetInstanceID () const
 Returns an identifier that can be used to identify which instance of a class an object is. More...
 

Static Public Member Functions

template<typename T >
static intptr_t ClassID ()
 Unique identifier for this class. More...
 

Static Public Attributes

static const HPS::Type staticType = HPS::Type::ExchangeTranslationNotifier
 

Detailed Description

The TranslationNotifier class is a smart-pointer that is tied to a file translation.

It is used to interact with an ongoing translation or get the results from a completed translation.

Constructor & Destructor Documentation

◆ TranslationNotifier() [1/4]

HPS::Exchange::TranslationNotifier::TranslationNotifier ( )

The default constructor creates an TranslationNotifier object which is not tied to any file translation.

◆ TranslationNotifier() [2/4]

HPS::Exchange::TranslationNotifier::TranslationNotifier ( TranslationNotifier const &  in_that)

The copy constructor creates a new TranslationNotifier object that is associated with the same file translation as the source TranslationNotifier.

Parameters
in_thatThe source TranslationNotifier to copy.

◆ TranslationNotifier() [3/4]

HPS::Exchange::TranslationNotifier::TranslationNotifier ( IONotifier const &  in_that)

The conversion constructor creates a new derived TranslationNotifier object from a base IONotifier object.

The copy will only be successful if the source notifier is really an upcast of this notifier type. Otherwise the copy will fail and the resulting TranslationNotifier will be invalid.

Parameters
in_thatThe source IONotifier to copy.

◆ TranslationNotifier() [4/4]

HPS::Exchange::TranslationNotifier::TranslationNotifier ( TranslationNotifier &&  in_that)

The move constructor creates an TranslationNotifier by transferring the underlying impl of the rvalue reference to this TranslationNotifier thereby avoiding a copy and allocation.

Parameters
in_thatAn rvalue reference to an TranslationNotifier to take the impl from.

◆ ~TranslationNotifier()

virtual HPS::Exchange::TranslationNotifier::~TranslationNotifier ( )
virtual

Member Function Documentation

◆ Assign() [1/2]

void HPS::Exchange::TranslationNotifier::Assign ( TranslationNotifier const &  in_that)

Associate this TranslationNotifier with the same file translation as the source TranslationNotifier.

Parameters
in_thatThe source TranslationNotifier for the assignment.

◆ Assign() [2/2]

void HPS::IONotifier::Assign ( IONotifier const &  in_that)
inherited

Associate this IONotifier with the same file IO operation as the source IONotifier.

Parameters
in_thatThe source IONotifier for the assignment.

◆ Cancel()

IONotifier& HPS::IONotifier::Cancel ( )
inherited

Requests to cancel the asynchronous file IO if it is still in progress.

The Cancel() function will return synchronously, however there may be some delay between when the cancel request is made and when the asynchronous file IO stops. Call Wait() to ensure that the asynchronous file IO operation has stopped.

Returns
A reference to this IONotifier.

◆ ClassID()

template<typename T >
static intptr_t HPS::Object::ClassID ( )
inlinestaticinherited

Unique identifier for this class.

Note: this method uses construction of static objects. If used in a constructor, it should be used in the body not the initializer list.

◆ Empty()

virtual bool HPS::Object::Empty ( ) const
inlinevirtualinherited

Indicates whether this object has any values set on it.

Returns
true if no values are set on this object, false otherwise.

Reimplemented in HPS::STL::ImportResultsKit, HPS::STL::ImportOptionsKit, HPS::OBJ::ImportResultsKit, HPS::OBJ::ImportOptionsKit, HPS::Hardcopy::File::ExportOptionsKit, HPS::Stream::ExportOptionsKit, HPS::Stream::ImportResultsKit, HPS::Stream::ImportOptionsKit, HPS::PointCloud::ImportOptionsKit, HPS::PointCloud::ImportResultsKit, HPS::UpdateOptionsKit, HPS::HighlightSearchOptionsKit, HPS::HighlightOptionsKit, HPS::SelectionOptionsKit, HPS::SearchOptionsKit, HPS::CutGeometryGatheringOptionsKit, HPS::ShapeKit, HPS::ShaderKit, HPS::Shader::ImportOptionsKit, HPS::ImageKit, HPS::Image::ImportOptionsKit, HPS::Image::ExportOptionsKit, HPS::TextureOptionsKit, HPS::LinePatternKit, HPS::LinePatternParallelKit, HPS::LinePatternOptionsKit, HPS::GlyphKit, HPS::ApplicationWindowOptionsKit, HPS::OffScreenWindowOptionsKit, HPS::StandAloneWindowOptionsKit, HPS::GridKit, HPS::PolygonKit, HPS::MeshKit, HPS::ShellKit, HPS::ShellRelationResultsKit, HPS::ShellRelationOptionsKit, HPS::ShellOptimizationOptionsKit, HPS::TextKit, HPS::EllipticalArcKit, HPS::EllipseKit, HPS::TrimKit, HPS::NURBSSurfaceKit, HPS::NURBSCurveKit, HPS::SpotlightKit, HPS::InfiniteLineKit, HPS::CuttingSectionKit, HPS::CircularWedgeKit, HPS::CircularArcKit, HPS::CircleKit, HPS::SphereKit, HPS::CylinderKit, HPS::DistantLightKit, HPS::MarkerKit, HPS::LineKit, HPS::AttributeLockKit, HPS::FontInfoState, HPS::WindowInfoKit, HPS::DebuggingKit, HPS::SubwindowKit, HPS::ContourLineKit, HPS::VisualEffectsKit, HPS::TransformMaskKit, HPS::PostProcessEffectsKit, HPS::DrawingAttributeKit, HPS::HiddenLineAttributeKit, HPS::PerformanceKit, HPS::NURBSSurfaceAttributeKit, HPS::MaterialKit, HPS::MaterialMappingKit, HPS::MatrixKit, HPS::CurveAttributeKit, HPS::EdgeAttributeKit, HPS::LineAttributeKit, HPS::TextAttributeKit, HPS::CuttingSectionAttributeKit, HPS::CylinderAttributeKit, HPS::LightingAttributeKit, HPS::SphereAttributeKit, HPS::MarkerAttributeKit, HPS::CullingKit, HPS::ColorInterpolationKit, HPS::TransparencyKit, HPS::SelectabilityKit, HPS::CameraKit, HPS::VisibilityKit, HPS::BoundingKit, HPS::SegmentOptimizationOptionsKit, HPS::Publish::ExportOptionsKit, HPS::Publish::TextFieldKit, HPS::Publish::SignatureFieldKit, HPS::Publish::DropDownListKit, HPS::Exchange::TessellationOptionsKit, HPS::Publish::ListBoxKit, HPS::Exchange::ExportSTEPOptionsKit, HPS::Exchange::ExportParasolidOptionsKit, HPS::Publish::RadioButtonKit, HPS::Exchange::ExportIGESOptionsKit, HPS::Exchange::ExportXMLOptionsKit, HPS::Publish::CheckBoxKit, HPS::Exchange::ExportU3DOptionsKit, HPS::Exchange::ExportSTLOptionsKit, HPS::Publish::ButtonKit, HPS::Exchange::ExportPRCOptionsKit, HPS::Publish::LinkKit, HPS::Exchange::ExportJTOptionsKit, HPS::Publish::SlideTableKit, HPS::Exchange::ExportACISOptionsKit, HPS::Publish::TableKit, HPS::Exchange::Export3MFOptionsKit, HPS::Publish::ImageKit, HPS::Publish::TextKit, HPS::Exchange::ModelFileImportOptionsKit, HPS::Publish::ViewKit, HPS::Exchange::TranslationOptionsKit, HPS::Publish::ArtworkKit, HPS::Publish::AnnotationKit, HPS::ComponentPath, HPS::Exchange::ImportOptionsKit, HPS::Parasolid::ExportOptionsKit, HPS::Exchange::NURBSConversionOptionsKit, HPS::Parasolid::LineTessellationKit, HPS::Exchange::Configuration, HPS::Publish::PageKit, HPS::Parasolid::FacetTessellationKit, HPS::Publish::DocumentKit, HPS::Parasolid::ImportOptionsKit, HPS::DWG::ImportOptionsKit, HPS::OOC::ImportOptionsKit, HPS::Sketchup::ImportOptionsKit, and HPS::Sketchup::ImportResultsKit.

◆ GetClassID()

intptr_t HPS::Object::GetClassID ( ) const
inherited

Returns a unique identifier that is shared by all objects of the same class.

Returns
A unique value shared by all objects of the same class.

◆ GetImportTime()

HPS::Time HPS::Exchange::TranslationNotifier::GetImportTime ( ) const

Get the number of milliseconds it took Exchange to read the CAD file(s) and generate the corresponding PRC data.

Throws an IOException if the translation is not complete, was not successful or was canceled.

◆ GetInstanceID()

intptr_t HPS::Object::GetInstanceID ( ) const
inherited

Returns an identifier that can be used to identify which instance of a class an object is.

Different keys and controls will return the same value if they are backed by the same database resource.

Returns
A value unique to an instance of an object and all objects that are backed by the same database resource.

◆ GetParasolidParts()

Exchange::ParasolidEntityArray HPS::Exchange::TranslationNotifier::GetParasolidParts ( ) const

Get the Parasolid parts obtained from the translation.

Throws an IOException if the translation is not complete, was not successful or was canceled.

Returns
The Parasolid Parts for a successful file translation.

◆ GetTranslationTime()

HPS::Time HPS::Exchange::TranslationNotifier::GetTranslationTime ( ) const

Get the number of milliseconds it took Exchange to translate the PRC data into Parasolid data.

Throws an IOException if the translation is not complete, was not successful or was canceled.

◆ HasType()

bool HPS::Object::HasType ( HPS::Type  in_mask) const
inherited

This function indicates whether this Object has the given Type mask.

Parameters
in_maskThe Type mask to check against this Object.
Returns
true if this Object has the given Type mask, false otherwise.

◆ ObjectType()

HPS::Type HPS::Exchange::TranslationNotifier::ObjectType ( ) const
inlinevirtual

Reimplemented from HPS::IONotifier.

◆ operator=() [1/2]

TranslationNotifier& HPS::Exchange::TranslationNotifier::operator= ( TranslationNotifier &&  in_that)

The move assignment operator transfers the underlying impl of the rvalue reference to this TranslationNotifier thereby avoiding a copy.

Parameters
in_thatAn rvalue reference to an TranslationNotifier to take the impl from.
Returns
A reference to this TranslationNotifier.

◆ operator=() [2/2]

TranslationNotifier& HPS::Exchange::TranslationNotifier::operator= ( TranslationNotifier const &  in_that)

Associate this TranslationNotifier with the same file translation as the source TranslationNotifier.

Parameters
in_thatThe source TranslationNotifier for the assignment.
Returns
A reference to this TranslationNotifier.

◆ Reset()

◆ Status() [1/2]

IOResult HPS::IONotifier::Status ( ) const
inherited

Query the status of the file IO operation for this notifier.

Returns
The current state of the file import.

◆ Status() [2/2]

IOResult HPS::IONotifier::Status ( float &  out_percent_complete) const
inherited

Query the status and completion percentage of the file IO for this notifier.

Parameters
out_percent_completeFloat in the range [0,1] indicating the current percentage complete.
Returns
The current state of the file import.

◆ Type()

◆ Wait()

IONotifier& HPS::IONotifier::Wait ( )
inherited

Cause this thread to sleep until the asynchronous file IO operation associated with this notifier is complete.

Returns
A reference to this IONotifier.

Member Data Documentation

◆ staticType

const HPS::Type HPS::Exchange::TranslationNotifier::staticType = HPS::Type::ExchangeTranslationNotifier
static

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