MOAB: Mesh Oriented datABase  (version 5.4.1)
test_both.cpp File Reference
#include "iGeom.h"
#include "iMesh.h"
#include "iRel.h"
#include "TestUtil.hpp"
#include <cstdlib>
+ Include dependency graph for test_both.cpp:

Go to the source code of this file.

Functions

void test_both ()
void test_change_to_both ()
void test_change_to_set ()
int main ()

Variables

iGeom_Instance geom
iMesh_Instance mesh
iRel_Instance rel
iBase_EntityHandle geom_ent
iBase_EntityHandle mesh_ents [4]
iBase_EntitySetHandle mesh_set

Function Documentation

int main ( )

Definition at line 82 of file test_both.cpp.

References geom, geom_ent, iBase_INTERLEAVED, iMesh_addEntArrToSet, iMesh_createEntSet, iMesh_createVtxArr, iMesh_dtor, iMesh_newMesh, iRel_create, iRel_destroy, mesh, mesh_ents, mesh_set, rel, RUN_TEST, test_both(), test_change_to_both(), and test_change_to_set().

{
    int err;
    int num_fail = 0;

    iGeom_newGeom( 0, &geom, &err, 0 );
    iMesh_newMesh( 0, &mesh, &err, 0 );
    iRel_create( 0, &rel, &err, 0 );

    iGeom_createBrick( geom, 2, 2, 2, &geom_ent, &err );

    double coords[] = {
        0, 0, 0, 0, 1, 0, 1, 1, 0, 1, 0, 0,
    };

    iBase_EntityHandle* mesh_ents_ptr = mesh_ents;
    int mesh_ents_alloc               = 4, mesh_ents_size;
    iMesh_createVtxArr( mesh, 4, iBase_INTERLEAVED, coords, 12, &mesh_ents_ptr, &mesh_ents_alloc, &mesh_ents_size,
                        &err );

    iMesh_createEntSet( mesh, false, &mesh_set, &err );
    iMesh_addEntArrToSet( mesh, mesh_ents, mesh_ents_size, mesh_set, &err );

    num_fail += RUN_TEST( test_both );
    num_fail += RUN_TEST( test_change_to_both );
    num_fail += RUN_TEST( test_change_to_set );

    iRel_destroy( rel, &err );
    iMesh_dtor( mesh, &err );
    iGeom_dtor( geom, &err );

    return num_fail;
}
void test_both ( )

Definition at line 18 of file test_both.cpp.

References CHECK_EQUAL, CHECK_ERR, geom, geom_ent, iRel_ACTIVE, iRel_BOTH, iRel_createPair, iRel_ENTITY, iRel_getEntArrEntArrRelation, iRel_IGEOM_IFACE, iRel_IMESH_IFACE, iRel_setEntSetRelation, mesh, mesh_ents, mesh_set, and rel.

Referenced by main().

{
    int err;
    iRel_PairHandle pair;

    iRel_createPair( rel, geom, iRel_ENTITY, iRel_IGEOM_IFACE, iRel_ACTIVE, mesh, iRel_BOTH, iRel_IMESH_IFACE,
                     iRel_ACTIVE, &pair, &err );CHECK_ERR( err );

    iRel_setEntSetRelation( rel, pair, geom_ent, mesh_set, &err );CHECK_ERR( err );

    iBase_EntityHandle* related_ents = NULL;
    int related_ents_alloc           = 0, related_ents_size;
    iRel_getEntArrEntArrRelation( rel, pair, mesh_ents, 4, 1, &related_ents, &related_ents_alloc, &related_ents_size,
                                  &err );CHECK_ERR( err );

    for( int i = 0; i < related_ents_size; i++ )
        CHECK_EQUAL( related_ents[i], geom_ent );

    free( related_ents );
}

Definition at line 39 of file test_both.cpp.

References CHECK_EQUAL, CHECK_ERR, geom, geom_ent, iRel_ACTIVE, iRel_BOTH, iRel_changePairType, iRel_createPair, iRel_ENTITY, iRel_getEntArrEntArrRelation, iRel_IGEOM_IFACE, iRel_IMESH_IFACE, iRel_SET, iRel_setEntSetRelation, mesh, mesh_ents, mesh_set, and rel.

Referenced by main().

{
    int err;
    iRel_PairHandle pair;

    iRel_createPair( rel, geom, iRel_ENTITY, iRel_IGEOM_IFACE, iRel_ACTIVE, mesh, iRel_SET, iRel_IMESH_IFACE,
                     iRel_ACTIVE, &pair, &err );CHECK_ERR( err );

    iRel_setEntSetRelation( rel, pair, geom_ent, mesh_set, &err );CHECK_ERR( err );

    iRel_changePairType( rel, pair, iRel_ENTITY, iRel_BOTH, &err );CHECK_ERR( err );

    iBase_EntityHandle* related_ents = NULL;
    int related_ents_alloc           = 0, related_ents_size;
    iRel_getEntArrEntArrRelation( rel, pair, mesh_ents, 4, 1, &related_ents, &related_ents_alloc, &related_ents_size,
                                  &err );CHECK_ERR( err );

    for( int i = 0; i < related_ents_size; i++ )
        CHECK_EQUAL( related_ents[i], geom_ent );

    free( related_ents );
}

Variable Documentation

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines