X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fvtk%2Fsrc%2FbbvtkGetVectorElement.h;h=f8b29c29c5e98b898289f70d238525f5f1e70061;hb=e7388f3073fa5eb9e35dafa8fbdf9e72ef6afd57;hp=3bf6996d479a0f2e535107be8b6dd1fa64965496;hpb=c74b2de1f3b56e7b89613c04ad459aa4e0567ce2;p=bbtk.git diff --git a/packages/vtk/src/bbvtkGetVectorElement.h b/packages/vtk/src/bbvtkGetVectorElement.h index 3bf6996..f8b29c2 100644 --- a/packages/vtk/src/bbvtkGetVectorElement.h +++ b/packages/vtk/src/bbvtkGetVectorElement.h @@ -2,8 +2,8 @@ Program: bbtk Module: $RCSfile: bbvtkGetVectorElement.h,v $ Language: C++ - Date: $Date: 2010/04/01 15:46:54 $ - Version: $Revision: 1.1 $ + Date: $Date: 2011/07/22 17:42:57 $ + Version: $Revision: 1.3 $ =========================================================================*/ /* --------------------------------------------------------------------- @@ -44,10 +44,11 @@ namespace bbvtk { BBTK_TEMPLATE_BLACK_BOX_INTERFACE(GetVectorElement,bbtk::AtomicBlackBox,T); BBTK_DECLARE_INPUT(In,std::vector); - BBTK_DECLARE_INPUT(I,int); + BBTK_DECLARE_INPUT(I,int); + BBTK_DECLARE_INPUT(ErrorValue,T); BBTK_DECLARE_OUTPUT(Out,T); BBTK_PROCESS(DoIt); - void DoIt(); + void DoIt(); }; //================================================================= @@ -61,7 +62,8 @@ namespace bbvtk BBTK_DESCRIPTION("Gets the i-th element from the input vector ("+bbtk::TypeName >()); typedef std::vector Tvector; BBTK_TEMPLATE_INPUT(GetVectorElement, In,"Input",Tvector); - BBTK_TEMPLATE_INPUT(GetVectorElement, I, "Input",int); + BBTK_TEMPLATE_INPUT(GetVectorElement, I, "Input",int); + BBTK_TEMPLATE_INPUT(GetVectorElement, ErrorValue, "ErrorValue",T); BBTK_TEMPLATE_OUTPUT(GetVectorElement,Out,"Output",T); BBTK_END_DESCRIBE_TEMPLATE_BLACK_BOX(GetVectorElement); //================================================================= @@ -70,8 +72,13 @@ namespace bbvtk template void GetVectorElement::DoIt() { - // unsigned int i = bbGetInputI(); - bbSetOutputOut(bbGetInputIn()[bbGetInputI()]); + if (( bbGetInputI() < bbGetInputIn().size() ) && ( bbGetInputI() >= 0 ) ) + { + bbSetOutputOut( bbGetInputIn()[bbGetInputI()] ); + } else + { + bbSetOutputOut( bbGetInputErrorValue() ); + } } //=================================================================