HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
XUSD_PerfMonAutoCookEvent.h
Go to the documentation of this file.
1 /*
2  * Copyright 2019 Side Effects Software Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17 
18 #ifndef __XUSD_PerfMonAutoCookEvent_h__
19 #define __XUSD_PerfMonAutoCookEvent_h__
20 
21 #include "HUSD_API.h"
22 #include <OP/OP_Node.h>
23 #include <UT/UT_PerfMonAutoEvent.h>
24 #include <pxr/pxr.h>
25 
27 
29 {
30 public:
31  XUSD_PerfMonAutoCookEvent(int nodeid, const char *msg)
32  {
33  UT_Performance *perfmon = UTgetPerformance();
34 
35  if (perfmon->isRecordingCookStats())
36  {
37  OP_Node *node = OP_Node::lookupNode(nodeid);
38 
39  if (node && node->isCooking(false))
40  setTimedEventId_(perfmon->startTimedCookEvent(nodeid, msg));
41  }
42  }
44  { }
45 };
46 
48 
49 #endif
50 
UT_API UT_Performance * UTgetPerformance(bool create=true)
XUSD_PerfMonAutoCookEvent(int nodeid, const char *msg)
bool isRecordingCookStats() const
Return true if Houdini is recording cook stats.
int startTimedCookEvent(int node_id, const char *cook_event_name=NULL)
void setTimedEventId_(int event_id)
PXR_NAMESPACE_CLOSE_SCOPE PXR_NAMESPACE_OPEN_SCOPE
Definition: path.h:1375
#define PXR_NAMESPACE_CLOSE_SCOPE
Definition: pxr.h:91
static OP_Node * lookupNode(int unique_id, bool include_proxy=false)
Definition: OP_Node.h:698
bool isCooking(bool include_ancestors) const