forked from bartvdbraak/blender
Code shuffle to make a bit more structure.
- operator definitions, callbacks, registry to WM and handlers for it are now always in a file xxxx_ops.c or xxxx_operators.c, in the bottom you will find the registry and handler code. - fixed some confusing naming conventions "rip_area vs area_join" etc. Now stick to convention to first name subject, then operation (like UI :). So it's area_rip, screen_add, and so on. - Nicely put exported calls (outside module) together in bottom: this using names such as ED_screen_duplicate(). - Moved Operator-Property API to new C file.
This commit is contained in:
parent
fd8c94fdb1
commit
a1b2c0c0fb
File diff suppressed because it is too large
Load Diff
@ -29,23 +29,22 @@
|
|||||||
#define ED_SCREEN_INTERN_H
|
#define ED_SCREEN_INTERN_H
|
||||||
|
|
||||||
/* internal exports only */
|
/* internal exports only */
|
||||||
struct wmOperator;
|
struct wmWindow;
|
||||||
struct wmEvent;
|
|
||||||
|
|
||||||
/* area.c */
|
/* area.c */
|
||||||
void area_copy_data(ScrArea *sa1, ScrArea *sa2, int swap_space);
|
void area_copy_data(ScrArea *sa1, ScrArea *sa2, int swap_space);
|
||||||
|
|
||||||
/* screen_edit.c */
|
/* screen_edit.c */
|
||||||
int screen_cursor_test(bContext *C, wmOperator *op, wmEvent *event);
|
bScreen *screen_add(struct wmWindow *win, char *name);
|
||||||
int area_cursor_test(bContext *C, wmOperator *op, wmEvent *event);
|
ScrEdge *screen_findedge(bScreen *sc, ScrVert *v1, ScrVert *v2);
|
||||||
|
ScrArea *area_split(wmWindow *win, bScreen *sc, ScrArea *sa, char dir, float fac);
|
||||||
|
int screen_area_join(bScreen* scr, ScrArea *sa1, ScrArea *sa2);
|
||||||
|
int area_getorientation(bScreen *screen, ScrArea *sa, ScrArea *sb);
|
||||||
|
|
||||||
void ED_SCR_OT_move_areas(wmOperatorType *ot);
|
void removenotused_scrverts(bScreen *sc);
|
||||||
void ED_SCR_OT_split_area(wmOperatorType *ot);
|
void removedouble_scrverts(bScreen *sc);
|
||||||
void ED_SCR_OT_join_areas(wmOperatorType *ot);
|
void removedouble_scredges(bScreen *sc);
|
||||||
void ED_SCR_OT_actionzone(wmOperatorType *ot);
|
void removenotused_scredges(bScreen *sc);
|
||||||
void ED_SCR_OT_area_rip(wmOperatorType *ot);
|
|
||||||
|
|
||||||
void ED_SCR_OT_border_select(wmOperatorType *ot);
|
|
||||||
|
|
||||||
#endif /* ED_SCREEN_INTERN_H */
|
#endif /* ED_SCREEN_INTERN_H */
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -139,23 +139,23 @@ int WM_border_select_modal (struct bContext *C, wmOperator *op, struct wmEvent
|
|||||||
* len= 4; <---- set the size!!
|
* len= 4; <---- set the size!!
|
||||||
* OP_get_int_array (op, "vector", vec, &len);
|
* OP_get_int_array (op, "vector", vec, &len);
|
||||||
*/
|
*/
|
||||||
void OP_set_int(wmOperator *op, char *name, int value);
|
void OP_set_int (wmOperator *op, char *name, int value);
|
||||||
void OP_set_float(wmOperator *op, char *name, float value);
|
void OP_set_float (wmOperator *op, char *name, float value);
|
||||||
void OP_set_string(wmOperator *op, char *name, char *str);
|
void OP_set_string (wmOperator *op, char *name, char *str);
|
||||||
void OP_set_int_array(wmOperator *op, char *name, int *array, short len);
|
void OP_set_int_array(wmOperator *op, char *name, int *array, short len);
|
||||||
void OP_set_float_array(wmOperator *op, char *name, float *array, short len);
|
void OP_set_float_array(wmOperator *op, char *name, float *array, short len);
|
||||||
|
|
||||||
int OP_get_int(wmOperator *op, char *name, int *value);
|
int OP_get_int (wmOperator *op, char *name, int *value);
|
||||||
int OP_get_float(wmOperator *op, char *name, float *value);
|
int OP_get_float (wmOperator *op, char *name, float *value);
|
||||||
char *OP_get_string(wmOperator *op, char *name);
|
char *OP_get_string (wmOperator *op, char *name);
|
||||||
int OP_get_int_array(wmOperator *op, char *name, int *array, short *len);
|
int OP_get_int_array(wmOperator *op, char *name, int *array, short *len);
|
||||||
int OP_get_float_array(wmOperator *op, char *name, float *array, short *len);
|
int OP_get_float_array(wmOperator *op, char *name, float *array, short *len);
|
||||||
|
|
||||||
void OP_verify_int(wmOperator *op, char *name, int value, int *result);
|
void OP_verify_int (wmOperator *op, char *name, int value, int *result);
|
||||||
void OP_verify_float(wmOperator *op, char *name, float value, int *result);
|
void OP_verify_float (wmOperator *op, char *name, float value, int *result);
|
||||||
char *OP_verify_string(wmOperator *op, char *name, char *str);
|
char *OP_verify_string(wmOperator *op, char *name, char *str);
|
||||||
void OP_verify_int_array(wmOperator *op, char *name, int *array, short len, int *resultarray, short *resultlen);
|
void OP_verify_int_array(wmOperator *op, char *name, int *array, short len, int *resultarray, short *resultlen);
|
||||||
void OP_verify_float_array(wmOperator *op, char *name, float *array, short len, float *resultarray, short *resultlen);
|
void OP_verify_float_array(wmOperator *op, char *name, float *array, short len, float *resultarray, short *resultlen);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Need call this function in the "exit callback"
|
* Need call this function in the "exit callback"
|
||||||
|
@ -74,17 +74,6 @@ void wm_operator_register(wmWindowManager *wm, wmOperator *op)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* **************** standard keymap for WM ********************** */
|
|
||||||
|
|
||||||
/* default keymap for windows and screens, only call once per WM */
|
|
||||||
static void wm_window_keymap(wmWindowManager *wm)
|
|
||||||
{
|
|
||||||
/* note, this doesn't replace existing keymap items */
|
|
||||||
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_window_duplicate", AKEY, KM_PRESS, 0, 0);
|
|
||||||
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_save_homefile", UKEY, KM_PRESS, KM_CTRL, 0);
|
|
||||||
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_window_fullscreen_toggle", FKEY, KM_PRESS, 0, 0);
|
|
||||||
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_exit_blender", QKEY, KM_PRESS, KM_CTRL, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ****************************************** */
|
/* ****************************************** */
|
||||||
|
|
||||||
|
298
source/blender/windowmanager/intern/wm_operator_props.c
Normal file
298
source/blender/windowmanager/intern/wm_operator_props.c
Normal file
@ -0,0 +1,298 @@
|
|||||||
|
/**
|
||||||
|
* $Id:
|
||||||
|
*
|
||||||
|
* ***** 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
*
|
||||||
|
* The Original Code is Copyright (C) 2008 Blender Foundation.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* Contributor(s): Blender Foundation
|
||||||
|
*
|
||||||
|
* ***** END GPL LICENSE BLOCK *****
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "DNA_ID.h"
|
||||||
|
|
||||||
|
#include "MEM_guardedalloc.h"
|
||||||
|
|
||||||
|
#include "BKE_idprop.h"
|
||||||
|
|
||||||
|
#include "WM_api.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* wrapped to get property from a operator. */
|
||||||
|
static IDProperty *op_get_property(wmOperator *op, char *name)
|
||||||
|
{
|
||||||
|
IDProperty *prop;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
prop= IDP_GetPropertyFromGroup(op->properties, name);
|
||||||
|
return prop;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We need create a "group" to store the operator properties.
|
||||||
|
* We don't have a WM_operator_new or some thing like that,
|
||||||
|
* so this function is called by all the OP_set_* function
|
||||||
|
* in case that op->properties is equal to NULL.
|
||||||
|
*/
|
||||||
|
static void op_init_property(wmOperator *op)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
val.i = 0; /* silence MSVC warning about uninitialized var when debugging */
|
||||||
|
op->properties= IDP_New(IDP_GROUP, val, "property");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ***** Property API, exported ***** */
|
||||||
|
void OP_free_property(wmOperator *op)
|
||||||
|
{
|
||||||
|
if(op->properties) {
|
||||||
|
IDP_FreeProperty(op->properties);
|
||||||
|
/*
|
||||||
|
* This need change, when the idprop code only
|
||||||
|
* need call IDP_FreeProperty. (check BKE_idprop.h)
|
||||||
|
*/
|
||||||
|
MEM_freeN(op->properties);
|
||||||
|
op->properties= NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_set_int(wmOperator *op, char *name, int value)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
IDProperty *prop;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
op_init_property(op);
|
||||||
|
|
||||||
|
val.i= value;
|
||||||
|
prop= IDP_New(IDP_INT, val, name);
|
||||||
|
IDP_ReplaceInGroup(op->properties, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_set_float(wmOperator *op, char *name, float value)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
IDProperty *prop;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
op_init_property(op);
|
||||||
|
|
||||||
|
val.f= value;
|
||||||
|
prop= IDP_New(IDP_FLOAT, val, name);
|
||||||
|
IDP_ReplaceInGroup(op->properties, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_set_int_array(wmOperator *op, char *name, int *array, short len)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
IDProperty *prop;
|
||||||
|
short i;
|
||||||
|
int *pointer;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
op_init_property(op);
|
||||||
|
|
||||||
|
val.array.len= len;
|
||||||
|
val.array.type= IDP_INT;
|
||||||
|
prop= IDP_New(IDP_ARRAY, val, name);
|
||||||
|
|
||||||
|
pointer= (int *)prop->data.pointer;
|
||||||
|
for(i= 0; i < len; i++)
|
||||||
|
pointer[i]= array[i];
|
||||||
|
IDP_ReplaceInGroup(op->properties, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_set_float_array(wmOperator *op, char *name, float *array, short len)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
IDProperty *prop;
|
||||||
|
short i;
|
||||||
|
float *pointer;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
op_init_property(op);
|
||||||
|
|
||||||
|
val.array.len= len;
|
||||||
|
val.array.type= IDP_FLOAT;
|
||||||
|
prop= IDP_New(IDP_ARRAY, val, name);
|
||||||
|
|
||||||
|
pointer= (float *) prop->data.pointer;
|
||||||
|
for(i= 0; i < len; i++)
|
||||||
|
pointer[i]= array[i];
|
||||||
|
IDP_ReplaceInGroup(op->properties, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_set_string(wmOperator *op, char *name, char *str)
|
||||||
|
{
|
||||||
|
IDPropertyTemplate val;
|
||||||
|
IDProperty *prop;
|
||||||
|
|
||||||
|
if(!op->properties)
|
||||||
|
op_init_property(op);
|
||||||
|
|
||||||
|
val.str= str;
|
||||||
|
prop= IDP_New(IDP_STRING, val, name);
|
||||||
|
IDP_ReplaceInGroup(op->properties, prop);
|
||||||
|
}
|
||||||
|
|
||||||
|
int OP_get_int(wmOperator *op, char *name, int *value)
|
||||||
|
{
|
||||||
|
IDProperty *prop= op_get_property(op, name);
|
||||||
|
int status= 0;
|
||||||
|
|
||||||
|
if ((prop) && (prop->type == IDP_INT)) {
|
||||||
|
(*value)= prop->data.val;
|
||||||
|
status= 1;
|
||||||
|
}
|
||||||
|
return (status);
|
||||||
|
}
|
||||||
|
|
||||||
|
int OP_get_float(wmOperator *op, char *name, float *value)
|
||||||
|
{
|
||||||
|
IDProperty *prop= op_get_property(op, name);
|
||||||
|
int status= 0;
|
||||||
|
|
||||||
|
if ((prop) && (prop->type == IDP_FLOAT)) {
|
||||||
|
(*value)= *(float*)&prop->data.val;
|
||||||
|
status= 1;
|
||||||
|
}
|
||||||
|
return (status);
|
||||||
|
}
|
||||||
|
|
||||||
|
int OP_get_int_array(wmOperator *op, char *name, int *array, short *len)
|
||||||
|
{
|
||||||
|
IDProperty *prop= op_get_property(op, name);
|
||||||
|
short i;
|
||||||
|
int status= 0;
|
||||||
|
int *pointer;
|
||||||
|
|
||||||
|
if ((prop) && (prop->type == IDP_ARRAY)) {
|
||||||
|
pointer= (int *) prop->data.pointer;
|
||||||
|
|
||||||
|
for(i= 0; (i < prop->len) && (i < *len); i++)
|
||||||
|
array[i]= pointer[i];
|
||||||
|
|
||||||
|
(*len)= i;
|
||||||
|
status= 1;
|
||||||
|
}
|
||||||
|
return (status);
|
||||||
|
}
|
||||||
|
|
||||||
|
int OP_get_float_array(wmOperator *op, char *name, float *array, short *len)
|
||||||
|
{
|
||||||
|
IDProperty *prop= op_get_property(op, name);
|
||||||
|
short i;
|
||||||
|
float *pointer;
|
||||||
|
int status= 0;
|
||||||
|
|
||||||
|
if ((prop) && (prop->type == IDP_ARRAY)) {
|
||||||
|
pointer= (float *) prop->data.pointer;
|
||||||
|
|
||||||
|
for(i= 0; (i < prop->len) && (i < *len); i++)
|
||||||
|
array[i]= pointer[i];
|
||||||
|
|
||||||
|
(*len)= i;
|
||||||
|
status= 1;
|
||||||
|
}
|
||||||
|
return (status);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *OP_get_string(wmOperator *op, char *name)
|
||||||
|
{
|
||||||
|
IDProperty *prop= op_get_property(op, name);
|
||||||
|
if ((prop) && (prop->type == IDP_STRING))
|
||||||
|
return ((char *) prop->data.pointer);
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_verify_int(wmOperator *op, char *name, int value, int *result)
|
||||||
|
{
|
||||||
|
int rvalue;
|
||||||
|
|
||||||
|
if(OP_get_int(op, name, &rvalue))
|
||||||
|
value= rvalue;
|
||||||
|
else
|
||||||
|
OP_set_int(op, name, value);
|
||||||
|
|
||||||
|
if(result)
|
||||||
|
*result= value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_verify_float(wmOperator *op, char *name, float value, int *result)
|
||||||
|
{
|
||||||
|
float rvalue;
|
||||||
|
|
||||||
|
if(OP_get_float(op, name, &rvalue))
|
||||||
|
value= rvalue;
|
||||||
|
else
|
||||||
|
OP_set_float(op, name, value);
|
||||||
|
|
||||||
|
if(result)
|
||||||
|
*result= value;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *OP_verify_string(wmOperator *op, char *name, char *str)
|
||||||
|
{
|
||||||
|
char *result= OP_get_string(op, name);
|
||||||
|
|
||||||
|
if(!result) {
|
||||||
|
OP_set_string(op, name, str);
|
||||||
|
result= OP_get_string(op, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_verify_int_array(wmOperator *op, char *name, int *array, short len, int *resultarray, short *resultlen)
|
||||||
|
{
|
||||||
|
int rarray[1];
|
||||||
|
short rlen= 1;
|
||||||
|
|
||||||
|
if(resultarray && resultlen) {
|
||||||
|
if(!OP_get_int_array(op, name, resultarray, &rlen)) {
|
||||||
|
OP_set_int_array(op, name, array, len);
|
||||||
|
OP_get_int_array(op, name, resultarray, resultlen);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(!OP_get_int_array(op, name, rarray, &rlen))
|
||||||
|
OP_set_int_array(op, name, array, len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void OP_verify_float_array(wmOperator *op, char *name, float *array, short len, float *resultarray, short *resultlen)
|
||||||
|
{
|
||||||
|
float rarray[1];
|
||||||
|
short rlen= 1;
|
||||||
|
|
||||||
|
if(resultarray && resultlen) {
|
||||||
|
if(!OP_get_float_array(op, name, resultarray, &rlen)) {
|
||||||
|
OP_set_float_array(op, name, array, len);
|
||||||
|
OP_get_float_array(op, name, resultarray, resultlen);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(!OP_get_float_array(op, name, rarray, &rlen))
|
||||||
|
OP_set_float_array(op, name, array, len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -236,265 +236,13 @@ void wm_operatortype_init(void)
|
|||||||
WM_operatortype_append(WM_OT_exit_blender);
|
WM_operatortype_append(WM_OT_exit_blender);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ******************************************************* */
|
/* default keymap for windows and screens, only call once per WM */
|
||||||
|
void wm_window_keymap(wmWindowManager *wm)
|
||||||
/* wrapped to get property from a operator. */
|
|
||||||
IDProperty *op_get_property(wmOperator *op, char *name)
|
|
||||||
{
|
{
|
||||||
IDProperty *prop;
|
/* note, this doesn't replace existing keymap items */
|
||||||
|
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_window_duplicate", AKEY, KM_PRESS, 0, 0);
|
||||||
if(!op->properties)
|
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_save_homefile", UKEY, KM_PRESS, KM_CTRL, 0);
|
||||||
return NULL;
|
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_window_fullscreen_toggle", FKEY, KM_PRESS, 0, 0);
|
||||||
|
WM_keymap_verify_item(&wm->windowkeymap, "WM_OT_exit_blender", QKEY, KM_PRESS, KM_CTRL, 0);
|
||||||
prop= IDP_GetPropertyFromGroup(op->properties, name);
|
|
||||||
return prop;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* We need create a "group" to store the operator properties.
|
|
||||||
* We don't have a WM_operator_new or some thing like that,
|
|
||||||
* so this function is called by all the OP_set_* function
|
|
||||||
* in case that op->properties is equal to NULL.
|
|
||||||
*/
|
|
||||||
void op_init_property(wmOperator *op)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
val.i = 0; /* silence MSVC warning about uninitialized var when debugging */
|
|
||||||
op->properties= IDP_New(IDP_GROUP, val, "property");
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ***** Property API, exported ***** */
|
|
||||||
void OP_free_property(wmOperator *op)
|
|
||||||
{
|
|
||||||
if(op->properties) {
|
|
||||||
IDP_FreeProperty(op->properties);
|
|
||||||
/*
|
|
||||||
* This need change, when the idprop code only
|
|
||||||
* need call IDP_FreeProperty. (check BKE_idprop.h)
|
|
||||||
*/
|
|
||||||
MEM_freeN(op->properties);
|
|
||||||
op->properties= NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_set_int(wmOperator *op, char *name, int value)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
IDProperty *prop;
|
|
||||||
|
|
||||||
if(!op->properties)
|
|
||||||
op_init_property(op);
|
|
||||||
|
|
||||||
val.i= value;
|
|
||||||
prop= IDP_New(IDP_INT, val, name);
|
|
||||||
IDP_ReplaceInGroup(op->properties, prop);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_set_float(wmOperator *op, char *name, float value)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
IDProperty *prop;
|
|
||||||
|
|
||||||
if(!op->properties)
|
|
||||||
op_init_property(op);
|
|
||||||
|
|
||||||
val.f= value;
|
|
||||||
prop= IDP_New(IDP_FLOAT, val, name);
|
|
||||||
IDP_ReplaceInGroup(op->properties, prop);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_set_int_array(wmOperator *op, char *name, int *array, short len)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
IDProperty *prop;
|
|
||||||
short i;
|
|
||||||
int *pointer;
|
|
||||||
|
|
||||||
if(!op->properties)
|
|
||||||
op_init_property(op);
|
|
||||||
|
|
||||||
val.array.len= len;
|
|
||||||
val.array.type= IDP_INT;
|
|
||||||
prop= IDP_New(IDP_ARRAY, val, name);
|
|
||||||
|
|
||||||
pointer= (int *)prop->data.pointer;
|
|
||||||
for(i= 0; i < len; i++)
|
|
||||||
pointer[i]= array[i];
|
|
||||||
IDP_ReplaceInGroup(op->properties, prop);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_set_float_array(wmOperator *op, char *name, float *array, short len)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
IDProperty *prop;
|
|
||||||
short i;
|
|
||||||
float *pointer;
|
|
||||||
|
|
||||||
if(!op->properties)
|
|
||||||
op_init_property(op);
|
|
||||||
|
|
||||||
val.array.len= len;
|
|
||||||
val.array.type= IDP_FLOAT;
|
|
||||||
prop= IDP_New(IDP_ARRAY, val, name);
|
|
||||||
|
|
||||||
pointer= (float *) prop->data.pointer;
|
|
||||||
for(i= 0; i < len; i++)
|
|
||||||
pointer[i]= array[i];
|
|
||||||
IDP_ReplaceInGroup(op->properties, prop);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_set_string(wmOperator *op, char *name, char *str)
|
|
||||||
{
|
|
||||||
IDPropertyTemplate val;
|
|
||||||
IDProperty *prop;
|
|
||||||
|
|
||||||
if(!op->properties)
|
|
||||||
op_init_property(op);
|
|
||||||
|
|
||||||
val.str= str;
|
|
||||||
prop= IDP_New(IDP_STRING, val, name);
|
|
||||||
IDP_ReplaceInGroup(op->properties, prop);
|
|
||||||
}
|
|
||||||
|
|
||||||
int OP_get_int(wmOperator *op, char *name, int *value)
|
|
||||||
{
|
|
||||||
IDProperty *prop= op_get_property(op, name);
|
|
||||||
int status= 0;
|
|
||||||
|
|
||||||
if ((prop) && (prop->type == IDP_INT)) {
|
|
||||||
(*value)= prop->data.val;
|
|
||||||
status= 1;
|
|
||||||
}
|
|
||||||
return (status);
|
|
||||||
}
|
|
||||||
|
|
||||||
int OP_get_float(wmOperator *op, char *name, float *value)
|
|
||||||
{
|
|
||||||
IDProperty *prop= op_get_property(op, name);
|
|
||||||
int status= 0;
|
|
||||||
|
|
||||||
if ((prop) && (prop->type == IDP_FLOAT)) {
|
|
||||||
(*value)= *(float*)&prop->data.val;
|
|
||||||
status= 1;
|
|
||||||
}
|
|
||||||
return (status);
|
|
||||||
}
|
|
||||||
|
|
||||||
int OP_get_int_array(wmOperator *op, char *name, int *array, short *len)
|
|
||||||
{
|
|
||||||
IDProperty *prop= op_get_property(op, name);
|
|
||||||
short i;
|
|
||||||
int status= 0;
|
|
||||||
int *pointer;
|
|
||||||
|
|
||||||
if ((prop) && (prop->type == IDP_ARRAY)) {
|
|
||||||
pointer= (int *) prop->data.pointer;
|
|
||||||
|
|
||||||
for(i= 0; (i < prop->len) && (i < *len); i++)
|
|
||||||
array[i]= pointer[i];
|
|
||||||
|
|
||||||
(*len)= i;
|
|
||||||
status= 1;
|
|
||||||
}
|
|
||||||
return (status);
|
|
||||||
}
|
|
||||||
|
|
||||||
int OP_get_float_array(wmOperator *op, char *name, float *array, short *len)
|
|
||||||
{
|
|
||||||
IDProperty *prop= op_get_property(op, name);
|
|
||||||
short i;
|
|
||||||
float *pointer;
|
|
||||||
int status= 0;
|
|
||||||
|
|
||||||
if ((prop) && (prop->type == IDP_ARRAY)) {
|
|
||||||
pointer= (float *) prop->data.pointer;
|
|
||||||
|
|
||||||
for(i= 0; (i < prop->len) && (i < *len); i++)
|
|
||||||
array[i]= pointer[i];
|
|
||||||
|
|
||||||
(*len)= i;
|
|
||||||
status= 1;
|
|
||||||
}
|
|
||||||
return (status);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *OP_get_string(wmOperator *op, char *name)
|
|
||||||
{
|
|
||||||
IDProperty *prop= op_get_property(op, name);
|
|
||||||
if ((prop) && (prop->type == IDP_STRING))
|
|
||||||
return ((char *) prop->data.pointer);
|
|
||||||
return (NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_verify_int(wmOperator *op, char *name, int value, int *result)
|
|
||||||
{
|
|
||||||
int rvalue;
|
|
||||||
|
|
||||||
if(OP_get_int(op, name, &rvalue))
|
|
||||||
value= rvalue;
|
|
||||||
else
|
|
||||||
OP_set_int(op, name, value);
|
|
||||||
|
|
||||||
if(result)
|
|
||||||
*result= value;
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_verify_float(wmOperator *op, char *name, float value, int *result)
|
|
||||||
{
|
|
||||||
float rvalue;
|
|
||||||
|
|
||||||
if(OP_get_float(op, name, &rvalue))
|
|
||||||
value= rvalue;
|
|
||||||
else
|
|
||||||
OP_set_float(op, name, value);
|
|
||||||
|
|
||||||
if(result)
|
|
||||||
*result= value;
|
|
||||||
}
|
|
||||||
|
|
||||||
char *OP_verify_string(wmOperator *op, char *name, char *str)
|
|
||||||
{
|
|
||||||
char *result= OP_get_string(op, name);
|
|
||||||
|
|
||||||
if(!result) {
|
|
||||||
OP_set_string(op, name, str);
|
|
||||||
result= OP_get_string(op, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_verify_int_array(wmOperator *op, char *name, int *array, short len, int *resultarray, short *resultlen)
|
|
||||||
{
|
|
||||||
int rarray[1];
|
|
||||||
short rlen= 1;
|
|
||||||
|
|
||||||
if(resultarray && resultlen) {
|
|
||||||
if(!OP_get_int_array(op, name, resultarray, &rlen)) {
|
|
||||||
OP_set_int_array(op, name, array, len);
|
|
||||||
OP_get_int_array(op, name, resultarray, resultlen);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if(!OP_get_int_array(op, name, rarray, &rlen))
|
|
||||||
OP_set_int_array(op, name, array, len);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void OP_verify_float_array(wmOperator *op, char *name, float *array, short len, float *resultarray, short *resultlen)
|
|
||||||
{
|
|
||||||
float rarray[1];
|
|
||||||
short rlen= 1;
|
|
||||||
|
|
||||||
if(resultarray && resultlen) {
|
|
||||||
if(!OP_get_float_array(op, name, resultarray, &rlen)) {
|
|
||||||
OP_set_float_array(op, name, array, len);
|
|
||||||
OP_get_float_array(op, name, resultarray, resultlen);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if(!OP_get_float_array(op, name, rarray, &rlen))
|
|
||||||
OP_set_float_array(op, name, array, len);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,6 +45,7 @@ extern void wm_report_free(wmReport *report);
|
|||||||
/* wm_operator.c, for init/exit */
|
/* wm_operator.c, for init/exit */
|
||||||
void wm_operatortype_free(void);
|
void wm_operatortype_free(void);
|
||||||
void wm_operatortype_init(void);
|
void wm_operatortype_init(void);
|
||||||
|
void wm_window_keymap(wmWindowManager *wm);
|
||||||
|
|
||||||
/* wm_gesture.c */
|
/* wm_gesture.c */
|
||||||
void wm_gesture_draw(struct wmWindow *win);
|
void wm_gesture_draw(struct wmWindow *win);
|
||||||
|
Loading…
Reference in New Issue
Block a user