Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/bpython/intern/BPY_macros.h')
-rw-r--r--source/blender/bpython/intern/BPY_macros.h268
1 files changed, 268 insertions, 0 deletions
diff --git a/source/blender/bpython/intern/BPY_macros.h b/source/blender/bpython/intern/BPY_macros.h
new file mode 100644
index 00000000000..9f9bea4864a
--- /dev/null
+++ b/source/blender/bpython/intern/BPY_macros.h
@@ -0,0 +1,268 @@
+
+/* bpython library macros
+ *
+ * $Id$
+ *
+ * ***** BEGIN GPL/BL DUAL 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. The Blender
+ * Foundation also sells licenses for use in proprietary software under
+ * the Blender License. See http://www.blender.org/BL/ for information
+ * about this.
+ *
+ * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ *
+ * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
+ * All rights reserved.
+ *
+ * The Original Code is: all of this file.
+ *
+ * Contributor(s): none yet.
+ *
+ * ***** END GPL/BL DUAL LICENSE BLOCK *****
+ *
+ */
+
+
+/* Hint: use gcc -E file.c to see what these macros are expanded in */
+
+#include "api.h" // temporary defines for API version
+
+#include "BPY_listbase_macro.h"
+#include "BKE_utildefines.h"
+
+/* CONSTANTS */
+
+#define IDNAME 24
+#define PATH_MAXCHAR 128
+
+/* ALIASES */
+
+#define BPY_TRY(x) {if((!(x))) return NULL;}
+#define BPY_TRY_TYPEERROR(x, str) \
+ { if(!(x)) { \
+ PyErr_SetString(PyExc_TypeError, str); \
+ return NULL; }\
+ }
+
+#define BPY_ADDCONST(dict, name) PyDict_SetItemString(dict, #name, PyInt_FromLong(name))
+#define CurrentFrame (getGlobal()->scene->r.cfra)
+#define RETURN_INC(ob) {Py_INCREF(ob); return ob; }
+
+/* Blender object internal 'reference' (user) counting */
+/* 'x' must be of type (ID *) */
+
+#ifdef DEBUG
+
+ #define BOB_USERCOUNT(x) \
+ (x)->us
+ #define BOB_DECUSER(x) \
+ printf("BOB_DECUSER: %s\n", (x)->name); \
+ (x)->us ? (x)->us--:printf("FATAL: 0--\n")
+ #define BOB_INCUSER(x) \
+ printf("BOB_INCUSER: %s\n", (x)->name); \
+ id_us_plus(x)
+ /* safe ref-inc/dec */
+ #define BOB_XDECUSER(x) \
+ if (x) { \
+ printf("BOB_XDECUSER: %s\n", (x)->name); \
+ ((x)->us ? (x)->us--:printf("FATAL: 0--\n")); \
+ }
+ #define BOB_XINCUSER(x) \
+ if (x) { \
+ printf("BOB_XINCUSER: %s\n", (x)->name); \
+ if (x) id_us_plus(x); \
+ }
+#else
+
+ #define BOB_USERCOUNT(x) \
+ (x)->us
+ #define BOB_DECUSER(x) \
+ (x)->us ? (x)->us--:printf("FATAL: 0--\n")
+ #define BOB_INCUSER(x) \
+ id_us_plus(x)
+ /* safe ref-inc/dec */
+ #define BOB_XDECUSER(x) \
+ if (x) ((x)->us ? (x)->us--:printf("FATAL: 0--\n"))
+ #define BOB_XINCUSER(x) \
+ if (x) id_us_plus(x)
+
+#endif
+
+/* WARNINGS, Verbose */
+
+#define BPY_CHECKFLAG(x) (getGlobal()->f & x)
+#define BPY_DEBUGFLAG BPY_CHECKFLAG(G_DEBUG)
+#define BPY_debug(a) if BPY_DEBUGFLAG {printf a; }
+#define BPY_warn(a) {printf a; }
+
+/* BLENDER DATABLOCK ACCESS */
+
+/* these are relicts... */
+#define GS(a) (*((short *)(a)))
+#define STREQ(str, a) ( strcmp((str), (a))==0 )
+
+/** This macro should be used to get the (short) id type of a ID datablock
+ * structure (Object, Mesh, etc.)
+ * Usage is dangerous, so use it only if you know what you're doing :-)
+ * Otherwise, use DataBlock_type() or associated functions (datablock.c)
+ */
+
+#define GET_ID_TYPE(x) (GS((x)->name))
+
+/* gets the datablock's ID pointer. be careful with its usage,
+ * - no typechecking done! */
+#define DATABLOCK_ID(x) ( (ID *) ((DataBlock *) x)->data)
+
+/** This defines the Get method plus documentation for use in a
+ * Method definition list.
+ * Example:
+ *
+ * DATABLOCK_GET(modulename, objectname, listbase.first)
+ *
+ * This function, called in Python by:
+ *
+ * modulename.Get(name)
+ *
+ * returns a Python DataBlock object for the Blender object with name
+ * 'name'. If 'name' omitted, a list of all the objects in the
+ * given list (a linked list of ID pointers) is returned
+ */
+
+
+#define DATABLOCK_GET(uname, docname, list) \
+static char uname##_get_doc[]= \
+"([name]) - Get " #docname "s from Blender\n" \
+"\n" \
+"[name] The name of the " #docname " to return\n" \
+"\n" \
+"Returns a list of all " #docname "s if name is not specified"; \
+ \
+static PyObject* uname##_get (PyObject *self, PyObject *args) { \
+ return py_find_from_list(list, args); \
+}
+
+/** This macro defines the creation of new Objects */
+
+#define DATABLOCK_NEW( modprefix, type, callfunc) \
+static char modprefix##_New_doc[] = \
+"() - returns new " #type " object"; \
+ \
+PyObject *modprefix##_New (PyObject *self, PyObject *args) \
+{ \
+ type *obj; \
+ char *name = #type; \
+ BPY_TRY(PyArg_ParseTuple(args, "|s", &name)); \
+ obj = callfunc; \
+ return DataBlock_fromData(obj); \
+} \
+
+#define DATABLOCK_ASSIGN_IPO(type, prefix) \
+static char type##_assignIpo_doc[]= \
+"(ipo) - assigns Ipo to object of type " #type ; \
+ \
+static PyObject *type##_assignIpo(PyObject *self, PyObject *args) \
+{ \
+ DataBlock *ipoblock; \
+ Ipo *ipo; \
+ type *object = PYBLOCK_AS(type, self); \
+ \
+ BPY_TRY(PyArg_ParseTuple(args, "O!", &DataBlock_Type, &ipoblock));\
+ if (!DataBlock_isType(ipoblock, ID_IP)) { \
+ PyErr_SetString(PyExc_TypeError, "expects Ipo object"); \
+ return 0; \
+ } \
+ ipo = PYBLOCK_AS_IPO(ipoblock); \
+ \
+ if (ipo->blocktype != GET_ID_TYPE((ID *) object)) { \
+ PyErr_SetString(PyExc_TypeError, \
+ "Ipo type does not match object type"); \
+ return 0; \
+ } \
+ prefix##_assignIpo(object, ipo); \
+ \
+ Py_INCREF(Py_None); \
+ return Py_None; \
+} \
+ \
+static char type##_clrIpo_doc[]= \
+"(ipo) - clears Ipo" ; \
+ \
+static PyObject *type##_clrIpo(PyObject *self, PyObject *args) \
+{ \
+ type *object = PYBLOCK_AS(type, self); \
+ BPY_TRY(PyArg_ParseTuple(args, "")); \
+ prefix##_assignIpo(object, 0); \
+ Py_INCREF(Py_None); \
+ return Py_None; \
+}
+
+/** Macro used to define the MethodDef macro which is used again for defining
+ * module or object methods in the Method table, see e.g. BPY_scene.c
+ *
+ * Usage:
+
+ * _MethodDef(delete, Scene) expands to:
+ *
+ * {"delete", Scene_delete, METH_VARARGS, Scene_delete_doc}
+ */
+#define _MethodDef(func, prefix) \
+ {#func, prefix##_##func, METH_VARARGS, prefix##_##func##_doc}
+
+/** Mark the datablock wrapper as invalid. See BPY_text.c for details */
+#define MARK_INVALID(datablock) \
+ ((DataBlock *) datablock)->data = NULL
+
+/** Check whether datablock wrapper is valid */
+#define CHECK_VALIDDATA(x, msg) \
+ if (!x) { \
+ PyErr_SetString(PyExc_RuntimeError, msg); \
+ return 0; \
+ } \
+
+
+/* OBJECT ACCESS */
+
+/** retrieves name from BPYobject */
+#define getName(x) ((x)->id.name+2)
+#define getUsers(x) ((x)->id.us)
+#define getIDName(x) ((x)->name+2)
+#define getIDUsers(x) ((x)->us)
+
+#define object_getMaterials(object) (object)->mat
+
+/** rename object with name */
+
+/* ListBase of active object in scene */
+#define FirstBase (getGlobal()->scene->base.first)
+#define ActiveBase (getGlobal()->scene->basact)
+#define ObjectfromBase(base) (base->object)
+#define SelectedAndLayer(base) (((base)->flag & SELECT) && ((base)->lay & getGlobal()->vd->lay))
+/* Active object (bright pink) */
+
+#define ActiveObject (ActiveBase ? ObjectfromBase(ActiveBase) : NULL)
+
+/* returns 1 if textureface tf is selected/active, else 0 */
+#define isSelectedFace(tf) (((tf).flag & TF_SELECT) ? 1 : 0 )
+#define isActiveFace(tf) (((tf).flag & TF_ACTIVE) ? 1 : 0 )
+
+/* some conversion macros */
+
+#define PYBLOCK_AS(x, y) (x *) ((DataBlock *) y)->data
+#define PYBLOCK_AS_TEXT(x) PYBLOCK_AS(Text, x)
+#define PYBLOCK_AS_MATERIAL(x) PYBLOCK_AS(Material, x)
+#define PYBLOCK_AS_OBJECT(x) PYBLOCK_AS(Object, x)
+#define PYBLOCK_AS_MESH(x) PYBLOCK_AS(Mesh, x)
+#define PYBLOCK_AS_LAMP(x) PYBLOCK_AS(Lamp, x)
+#define PYBLOCK_AS_IPO(x) PYBLOCK_AS(Ipo, x)
+#define PYBLOCK_AS_DATA(x) PYBLOCK_AS(void, x)