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
|
||||
|
||||
/* internal exports only */
|
||||
struct wmOperator;
|
||||
struct wmEvent;
|
||||
struct wmWindow;
|
||||
|
||||
/* area.c */
|
||||
void area_copy_data(ScrArea *sa1, ScrArea *sa2, int swap_space);
|
||||
|
||||
/* screen_edit.c */
|
||||
int screen_cursor_test(bContext *C, wmOperator *op, wmEvent *event);
|
||||
int area_cursor_test(bContext *C, wmOperator *op, wmEvent *event);
|
||||
bScreen *screen_add(struct wmWindow *win, char *name);
|
||||
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 ED_SCR_OT_split_area(wmOperatorType *ot);
|
||||
void ED_SCR_OT_join_areas(wmOperatorType *ot);
|
||||
void ED_SCR_OT_actionzone(wmOperatorType *ot);
|
||||
void ED_SCR_OT_area_rip(wmOperatorType *ot);
|
||||
|
||||
void ED_SCR_OT_border_select(wmOperatorType *ot);
|
||||
void removenotused_scrverts(bScreen *sc);
|
||||
void removedouble_scrverts(bScreen *sc);
|
||||
void removedouble_scredges(bScreen *sc);
|
||||
void removenotused_scredges(bScreen *sc);
|
||||
|
||||
#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!!
|
||||
* OP_get_int_array (op, "vector", vec, &len);
|
||||
*/
|
||||
void OP_set_int(wmOperator *op, char *name, int value);
|
||||
void OP_set_float(wmOperator *op, char *name, float value);
|
||||
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_float_array(wmOperator *op, char *name, float *array, short len);
|
||||
void OP_set_int (wmOperator *op, char *name, int value);
|
||||
void OP_set_float (wmOperator *op, char *name, float value);
|
||||
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_float_array(wmOperator *op, char *name, float *array, short len);
|
||||
|
||||
int OP_get_int(wmOperator *op, char *name, int *value);
|
||||
int OP_get_float(wmOperator *op, char *name, float *value);
|
||||
char *OP_get_string(wmOperator *op, char *name);
|
||||
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_int (wmOperator *op, char *name, int *value);
|
||||
int OP_get_float (wmOperator *op, char *name, float *value);
|
||||
char *OP_get_string (wmOperator *op, char *name);
|
||||
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);
|
||||
|
||||
void OP_verify_int(wmOperator *op, char *name, int 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);
|
||||
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_int (wmOperator *op, char *name, int 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);
|
||||
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);
|
||||
|
||||
/*
|
||||
* 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);
|
||||
}
|
||||
|
||||
/* ******************************************************* */
|
||||
|
||||
/* wrapped to get property from a operator. */
|
||||
IDProperty *op_get_property(wmOperator *op, char *name)
|
||||
/* default keymap for windows and screens, only call once per WM */
|
||||
void wm_window_keymap(wmWindowManager *wm)
|
||||
{
|
||||
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.
|
||||
*/
|
||||
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);
|
||||
}
|
||||
/* 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);
|
||||
}
|
||||
|
||||
|
@ -45,6 +45,7 @@ extern void wm_report_free(wmReport *report);
|
||||
/* wm_operator.c, for init/exit */
|
||||
void wm_operatortype_free(void);
|
||||
void wm_operatortype_init(void);
|
||||
void wm_window_keymap(wmWindowManager *wm);
|
||||
|
||||
/* wm_gesture.c */
|
||||
void wm_gesture_draw(struct wmWindow *win);
|
||||
|
Loading…
Reference in New Issue
Block a user