HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
DOP_GroupAndApply.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2024
3  * Side Effects Software Inc. All rights reserved.
4  *
5  * Redistribution and use of Houdini Development Kit samples in source and
6  * binary forms, with or without modification, are permitted provided that the
7  * following conditions are met:
8  * 1. Redistributions of source code must retain the above copyright notice,
9  * this list of conditions and the following disclaimer.
10  * 2. The name of Side Effects Software may not be used to endorse or
11  * promote products derived from this software without specific prior
12  * written permission.
13  *
14  * THIS SOFTWARE IS PROVIDED BY SIDE EFFECTS SOFTWARE `AS IS' AND ANY EXPRESS
15  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
17  * NO EVENT SHALL SIDE EFFECTS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,
18  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
19  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
20  * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
21  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
22  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
23  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  *----------------------------------------------------------------------------
26  */
27 
28 #ifndef __DOP_GroupAndApply_h__
29 #define __DOP_GroupAndApply_h__
30 
31 #include <DOP/DOP_Node.h>
32 
33 namespace HDK_Sample {
34 
36 {
37 public:
38  DOP_GroupAndApply(OP_Network *net, const char *name,
39  OP_Operator *op);
40  ~DOP_GroupAndApply() override;
41 
42  static OP_Node *myConstructor(OP_Network *net,
43  const char *name,
44  OP_Operator *op);
46 
47 protected:
49  int foroutputidx,
50  const SIM_ObjectArray &objects,
51  DOP_Engine &engine) override;
52  void getInputInfoSubclass(int inputidx,
53  DOP_InOutInfo &info) const override;
54  void getOutputInfoSubclass(int inputidx,
55  DOP_InOutInfo &info) const override;
56 
57 private:
58  void GROUP(UT_String &str, fpreal t);
59  int INPUTINDEX(fpreal t);
60 };
61 
62 }
63 
64 #endif
void processObjectsSubclass(fpreal time, int foroutputidx, const SIM_ObjectArray &objects, DOP_Engine &engine) override
This default implementation does not affect incoming objects.
GT_API const UT_StringHolder time
Holds pointers to a number of SIM_Object objects.
DOP_GroupAndApply(OP_Network *net, const char *name, OP_Operator *op)
GLuint const GLchar * name
Definition: glcorearb.h:786
GLdouble t
Definition: glad.h:2397
fpreal64 fpreal
Definition: SYS_Types.h:277
static PRM_Template myTemplateList[]
void getOutputInfoSubclass(int inputidx, DOP_InOutInfo &info) const override
This default implementation specifies the output sends out objects.
static OP_Node * myConstructor(OP_Network *net, const char *name, OP_Operator *op)
This is the base class for all DOP nodes.
Definition: DOP_Node.h:77
void getInputInfoSubclass(int inputidx, DOP_InOutInfo &info) const override
This default implementation specifies the input accepts objects.