#ifndef _ShapeProcessor_HeaderFile
#define _ShapeProcessor_HeaderFile
 
#include <cadex/Base/UTF16String.hxx>
#include <cadex/ModelData/Body.hxx>
#include <cadex/ModelData/Model.hxx>
#include <cadex/ModelData/Part.hxx>
#include <cadex/ModelData/Shell.hxx>
#include <cadex/ModelData/Solid.hxx>
#include <cadex/WallThickness_Data.hxx>
 
#include <iostream>
 
 
using namespace std;
 
{
public:
 
    {
 
            size_t aBodyNumber = 0;
            const auto& aBodies = thePart.
Bodies();
 
            for (const auto& aBody : aBodies) {
                while (aShapeIt.
HasNext()) {
 
                    const auto& aShape = aShapeIt.
Next();
 
                    if (aShape.Type() == ModelData::ShapeType::Solid) {
                        cout << "Part #" << myPartIndex << " [\"" << aPartName << "\"] - solid #" << std::to_string (aBodyNumber) << " has:" << endl;
                        ProcessSolid (ModelData::Solid::Cast (aShape));
                    } else if (aShape.Type() == ModelData::ShapeType::Shell) {
                        cout << "Part #" << myPartIndex << " [\"" << aPartName << "\"] - shell #" << std::to_string (aBodyNumber) << " has:" << endl;
                        ProcessShell (ModelData::Shell::Cast (aShape));
                    }
                }
                ++aBodyNumber;
            }
        ++myPartIndex;
    }
 
 
 
private:
    size_t  myPartIndex = 0;
};
 
{
public:
 
    {
 
        size_t aBodyNumber = 0;
        const auto& aBodies = thePart.Bodies();
        for (const auto& aBody : aBodies) {
            while (aShapeIt.HasNext()) {
                const auto& aShape = aShapeIt.Next();
                if (aShape.Type() == ModelData::ShapeType::Solid) {
                    cout << "Part #" << myPartIndex << " [\"" << aPartName << "\"] - solid #" << std::to_string (aBodyNumber++) << " has:" << endl;
                    ProcessSolid (ModelData::Solid::Cast (aShape));
                }
            }
        }
 
        ++myPartIndex;
    }
 
 
private:
    size_t  myPartIndex = 0;
};
 
{
public:
 
    {
 
        size_t aBodyNumber = 0;
        const auto& aBodies = thePart.Bodies();
        for (const auto& aBody : aBodies) {
            while (aShapeIt.HasNext()) {
                const auto& aShape = aShapeIt.Next();
                if (aShape.Type() == ModelData::ShapeType::Solid) {
                    cout << "Part #" << myPartIndex << " [\"" << aPartName << "\"] - solid #" << std::to_string (aBodyNumber++) << " has:" << endl;
                    ProcessSolid (ModelData::Solid::Cast (aShape), aPartName, aBodyNumber);
                }
            }
        }
        ++myPartIndex;
    }
 
        const UTF16String& thePartName, 
size_t theShapeIndex) = 0;
 
 
protected:
    size_t                  myPartIndex = 0;
};
 
#endif
UTF16String Name() const
Returns a name.
Definition ModelElement.cxx:55
Element visitor with empty implementation.
Definition ModelElementVisitor.hxx:64
Defines a leaf node in the scene graph hiearchy.
Definition Part.hxx:34
Iterates over subshapes in a shape.
Definition ShapeIterator.hxx:32
Defines a connected set of faces.
Definition Shell.hxx:32
Defines a topological solid.
Definition Solid.hxx:32
Defines a Unicode (UTF-16) string wrapping a standard string.
Definition UTF16String.hxx:30
bool IsEmpty() const
Returns true if the string is empty.
Definition UTF16String.cxx:336
Contains classes, namespaces, enums, types, and global functions related to Manufacturing Toolkit.
Definition LicenseManager_LicenseError.hxx:30