This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/depsgraph/intern/depsgraph_debug.h
Campbell Barton 5d30c23c35 doxygen: corrections/updates
Also add depsgraph & physics
2015-05-20 14:12:22 +10:00

88 lines
2.6 KiB
C++

/*
* ***** BEGIN GPL LICENSE BLOCK *****
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* The Original Code is Copyright (C) 2013 Blender Foundation.
* All rights reserved.
*
* Original Author: Joshua Leung
* Contributor(s): None Yet
*
* ***** END GPL LICENSE BLOCK *****
*/
/** \file blender/depsgraph/intern/depsgraph_debug.h
* \ingroup depsgraph
*/
#ifndef __DEPSGRAPH_DEBUG_H__
#define __DEPSGRAPH_DEBUG_H__
#include "depsgraph_types.h"
extern "C" {
#include "BKE_global.h"
}
struct DepsgraphStats;
struct DepsgraphStatsID;
struct DepsgraphStatsComponent;
struct DepsgraphSettings;
struct EvaluationContext;
struct OperationDepsNode;
struct Depsgraph;
struct DepsgraphDebug {
static DepsgraphStats *stats;
static void stats_init();
static void stats_free();
static void verify_stats();
static void reset_stats();
static void eval_begin(const EvaluationContext *eval_ctx);
static void eval_end(const EvaluationContext *eval_ctx);
static void eval_step(const EvaluationContext *eval_ctx,
const char *message);
static void task_started(Depsgraph *graph, const OperationDepsNode *node);
static void task_completed(Depsgraph *graph,
const OperationDepsNode *node,
double time);
static DepsgraphStatsID *get_id_stats(ID *id, bool create);
static DepsgraphStatsComponent *get_component_stats(DepsgraphStatsID *id_stats,
const string &name,
bool create);
static DepsgraphStatsComponent *get_component_stats(ID *id,
const string &name,
bool create)
{
return get_component_stats(get_id_stats(id, create), name, create);
}
};
#define DEG_DEBUG_PRINTF(...) \
{ \
if (G.debug & G_DEBUG_DEPSGRAPH) { \
fprintf(stderr, __VA_ARGS__); \
} \
} \
#endif /* __DEPSGRAPH_DEBUG_H__ */