Enlightenment CVS committal Author : tsauerbeck Project : e17 Module : libs/edje
Dir : e17/libs/edje/src/lib Modified Files: edje_embryo.c edje_private.h Log Message: added support for a few more properties for the custom state stuff =================================================================== RCS file: /cvsroot/enlightenment/e17/libs/edje/src/lib/edje_embryo.c,v retrieving revision 1.39 retrieving revision 1.40 diff -u -3 -r1.39 -r1.40 --- edje_embryo.c 30 Oct 2004 12:29:07 -0000 1.39 +++ edje_embryo.c 2 Nov 2004 17:31:55 -0000 1.40 @@ -125,7 +125,15 @@ * set_state_val(part_id, State_Param:param, ...) * get_state_val(part_id, State_Param:param, ...) * - * Supported parameters: align[Float:x, Float:y] + * Supported parameters: + * align[Float:x, Float:y] + * min[w, h] + * max[w, h] + * step[x,y] + * aspect[Float:min, Float:max] + * color[r,g,b,a] + * color2[r,g,b,a] + * color3[r,g,b,a] * * ** part_id and program_id need to be able to be "found" from strings * @@ -148,11 +156,7 @@ * Need to implement support for the following properties * in get/set_state_val(): * - * min[w,h] - * max[w,h] - * step[x,y] - * aspect[min,max] - * apsetc_preference + * aspect_preference * rel1[relx,rely,part_id,part_id] * rel1[offx,offy] * rel2[relx,rely,part_id,part_id] @@ -163,9 +167,6 @@ * fill[pos_relx,pos_rely,pos_offx,pos_offy] * fill[sz_relx,sz_rely,sz_offx,sz_offy] * color_class - * color[r,g,b,a] - * color2[r,g,b,a] - * color3[r,g,b,a] * text[text_class] * text[font] * text[size] @@ -186,6 +187,14 @@ ___l = embryo_data_string_length_get(ep, ___cptr); \ if (((str) = alloca(___l + 1))) \ embryo_data_string_get(ep, ___cptr, (str));}} +#define GETFLOAT(val, par) { \ + float *___cptr; \ + if ((___cptr = (float *)embryo_data_address_get(ep, (par)))) { \ + val = *___cptr;}} +#define GETINT(val, par) { \ + int *___cptr; \ + if ((___cptr = (int *)embryo_data_address_get(ep, (par)))) { \ + val = *___cptr;}} #define SETSTR(str, par) { \ Embryo_Cell *___cptr; \ if ((___cptr = embryo_data_address_get(ep, (par)))) { \ @@ -1506,13 +1515,63 @@ case EDJE_STATE_PARAM_ALIGNMENT: CHKPARAM(4); - cptr = embryo_data_address_get(ep, params[3]); - if (cptr) - rp->custom.description->align.x = EMBRYO_CELL_TO_FLOAT(*cptr); - - cptr = embryo_data_address_get(ep, params[4]); - if (cptr) - rp->custom.description->align.y = EMBRYO_CELL_TO_FLOAT(*cptr); + GETFLOAT(rp->custom.description->align.x, params[3]); + GETFLOAT(rp->custom.description->align.y, params[4]); + + break; + case EDJE_STATE_PARAM_MIN: + CHKPARAM(4); + + GETINT(rp->custom.description->min.w, params[3]); + GETINT(rp->custom.description->min.h, params[4]); + + break; + case EDJE_STATE_PARAM_MAX: + CHKPARAM(4); + + GETINT(rp->custom.description->max.w, params[3]); + GETINT(rp->custom.description->max.h, params[4]); + + break; + case EDJE_STATE_PARAM_STEP: + CHKPARAM(4); + + GETINT(rp->custom.description->step.x, params[3]); + GETINT(rp->custom.description->step.y, params[4]); + + break; + case EDJE_STATE_PARAM_ASPECT: + CHKPARAM(4); + + GETFLOAT(rp->custom.description->aspect.min, params[3]); + GETFLOAT(rp->custom.description->aspect.max, params[4]); + + break; + case EDJE_STATE_PARAM_COLOR: + CHKPARAM(6); + + GETINT(rp->custom.description->color.r, params[3]); + GETINT(rp->custom.description->color.g, params[4]); + GETINT(rp->custom.description->color.b, params[5]); + GETINT(rp->custom.description->color.a, params[6]); + + break; + case EDJE_STATE_PARAM_COLOR2: + CHKPARAM(6); + + GETINT(rp->custom.description->color2.r, params[3]); + GETINT(rp->custom.description->color2.g, params[4]); + GETINT(rp->custom.description->color2.b, params[5]); + GETINT(rp->custom.description->color2.a, params[6]); + + break; + case EDJE_STATE_PARAM_COLOR3: + CHKPARAM(6); + + GETINT(rp->custom.description->color3.r, params[3]); + GETINT(rp->custom.description->color3.g, params[4]); + GETINT(rp->custom.description->color3.b, params[5]); + GETINT(rp->custom.description->color3.a, params[6]); break; default: @@ -1550,19 +1609,63 @@ case EDJE_STATE_PARAM_ALIGNMENT: CHKPARAM(4); - cptr = embryo_data_address_get(ep, params[3]); - if (cptr) - { - f = rp->custom.description->align.x; - *cptr = EMBRYO_FLOAT_TO_CELL(f); - } - - cptr = embryo_data_address_get(ep, params[4]); - if (cptr) - { - f = rp->custom.description->align.y; - *cptr = EMBRYO_FLOAT_TO_CELL(f); - } + SETFLOAT(rp->custom.description->align.x, params[3]); + SETFLOAT(rp->custom.description->align.y, params[4]); + + break; + case EDJE_STATE_PARAM_MIN: + CHKPARAM(4); + + SETINT(rp->custom.description->min.w, params[3]); + SETINT(rp->custom.description->min.h, params[4]); + + break; + case EDJE_STATE_PARAM_MAX: + CHKPARAM(4); + + SETINT(rp->custom.description->max.w, params[3]); + SETINT(rp->custom.description->max.h, params[4]); + + break; + case EDJE_STATE_PARAM_STEP: + CHKPARAM(4); + + SETINT(rp->custom.description->step.x, params[3]); + SETINT(rp->custom.description->step.y, params[4]); + + break; + case EDJE_STATE_PARAM_ASPECT: + CHKPARAM(4); + + SETFLOAT(rp->custom.description->aspect.min, params[3]); + SETFLOAT(rp->custom.description->aspect.max, params[4]); + + break; + case EDJE_STATE_PARAM_COLOR: + CHKPARAM(6); + + SETINT(rp->custom.description->color.r, params[3]); + SETINT(rp->custom.description->color.g, params[4]); + SETINT(rp->custom.description->color.b, params[5]); + SETINT(rp->custom.description->color.a, params[6]); + + break; + case EDJE_STATE_PARAM_COLOR2: + CHKPARAM(6); + + SETINT(rp->custom.description->color2.r, params[3]); + SETINT(rp->custom.description->color2.g, params[4]); + SETINT(rp->custom.description->color2.b, params[5]); + SETINT(rp->custom.description->color2.a, params[6]); + + break; + case EDJE_STATE_PARAM_COLOR3: + CHKPARAM(6); + + SETINT(rp->custom.description->color3.r, params[3]); + SETINT(rp->custom.description->color3.g, params[4]); + SETINT(rp->custom.description->color3.b, params[5]); + SETINT(rp->custom.description->color3.a, params[6]); break; default: =================================================================== RCS file: /cvsroot/enlightenment/e17/libs/edje/src/lib/edje_private.h,v retrieving revision 1.77 retrieving revision 1.78 diff -u -3 -r1.77 -r1.78 --- edje_private.h 30 Oct 2004 12:19:33 -0000 1.77 +++ edje_private.h 2 Nov 2004 17:31:56 -0000 1.78 @@ -126,7 +126,14 @@ #define EDJE_STATE_PARAM_NONE 0 #define EDJE_STATE_PARAM_ALIGNMENT 1 -#define EDJE_STATE_PARAM_LAST 2 +#define EDJE_STATE_PARAM_MIN 2 +#define EDJE_STATE_PARAM_MAX 3 +#define EDJE_STATE_PARAM_STEP 4 +#define EDJE_STATE_PARAM_ASPECT 5 +#define EDJE_STATE_PARAM_COLOR 6 +#define EDJE_STATE_PARAM_COLOR2 7 +#define EDJE_STATE_PARAM_COLOR3 8 +#define EDJE_STATE_PARAM_LAST 9 /*----------*/ ------------------------------------------------------- This SF.Net email is sponsored by: Sybase ASE Linux Express Edition - download now for FREE LinuxWorld Reader's Choice Award Winner for best database on Linux. http://ads.osdn.com/?ad_id=5588&alloc_id=12065&op=click _______________________________________________ enlightenment-cvs mailing list [EMAIL PROTECTED] https://lists.sourceforge.net/lists/listinfo/enlightenment-cvs