Gradients: mostly done
This commit is contained in:
@@ -48,38 +48,30 @@ GradientType gradient_type_from_string(const char *str)
|
||||
return GRADIENT_VERTICAL;
|
||||
}
|
||||
|
||||
gboolean read_origin_from_string(const char *str, Origin *element)
|
||||
gboolean read_element_from_string(const char *str, Element *element)
|
||||
{
|
||||
if (g_str_equal(str, "element")) {
|
||||
*element = ORIGIN_ELEMENT;
|
||||
if (g_str_equal(str, "self")) {
|
||||
*element = ELEMENT_SELF;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "parent")) {
|
||||
*element = ORIGIN_PARENT;
|
||||
*element = ELEMENT_PARENT;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "panel")) {
|
||||
*element = ORIGIN_PANEL;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "screen")) {
|
||||
*element = ORIGIN_SCREEN;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "desktop")) {
|
||||
*element = ORIGIN_DESKTOP;
|
||||
*element = ELEMENT_PANEL;
|
||||
return TRUE;
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
Origin origin_from_string(const char *str)
|
||||
Element element_from_string(const char *str)
|
||||
{
|
||||
Origin result;
|
||||
if (read_origin_from_string(str, &result))
|
||||
Element result;
|
||||
if (read_element_from_string(str, &result))
|
||||
return result;
|
||||
fprintf(stderr, RED "Invalid origin type: %s" RESET "\n", str);
|
||||
return ORIGIN_ELEMENT;
|
||||
return ELEMENT_SELF;
|
||||
}
|
||||
|
||||
gboolean read_size_from_string(const char *str, SizeVariable *variable)
|
||||
@@ -92,6 +84,10 @@ gboolean read_size_from_string(const char *str, SizeVariable *variable)
|
||||
*variable = SIZE_HEIGHT;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "radius")) {
|
||||
*variable = SIZE_RADIUS;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "left")) {
|
||||
*variable = SIZE_LEFT;
|
||||
return TRUE;
|
||||
@@ -108,24 +104,24 @@ gboolean read_size_from_string(const char *str, SizeVariable *variable)
|
||||
*variable = SIZE_BOTTOM;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "center")) {
|
||||
*variable = SIZE_CENTER;
|
||||
if (g_str_equal(str, "centerx")) {
|
||||
*variable = SIZE_CENTERX;
|
||||
return TRUE;
|
||||
}
|
||||
if (g_str_equal(str, "radius")) {
|
||||
*variable = SIZE_RADIUS;
|
||||
if (g_str_equal(str, "centery")) {
|
||||
*variable = SIZE_CENTERY;
|
||||
return TRUE;
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
gboolean read_size_variable_from_string(const char *str,
|
||||
Origin *variable_element,
|
||||
Element *variable_element,
|
||||
SizeVariable *variable,
|
||||
double *multiplier)
|
||||
{
|
||||
if (read_size_from_string(str, variable)) {
|
||||
*variable_element = ORIGIN_ELEMENT;
|
||||
*variable_element = ELEMENT_SELF;
|
||||
*multiplier = 1;
|
||||
return TRUE;
|
||||
}
|
||||
@@ -133,8 +129,8 @@ gboolean read_size_variable_from_string(const char *str,
|
||||
char *value1 = 0, *value2 = 0, *value3 = 0, *value4 = 0;
|
||||
extract_values_4(str, &value1, &value2, &value3, &value4);
|
||||
|
||||
if (value1 && value2 && !value3) {
|
||||
if (read_origin_from_string(value1, variable_element) && read_size_from_string(value2, variable)) {
|
||||
if (value1 && !value2) {
|
||||
if (read_size_from_string(value1, variable)) {
|
||||
*multiplier = 1;
|
||||
if (value1)
|
||||
free(value1);
|
||||
@@ -148,8 +144,38 @@ gboolean read_size_variable_from_string(const char *str,
|
||||
}
|
||||
}
|
||||
|
||||
if (value1 && value2 && !value3) {
|
||||
if (read_element_from_string(value1, variable_element) && read_size_from_string(value2, variable)) {
|
||||
*multiplier = 1;
|
||||
if (value1)
|
||||
free(value1);
|
||||
if (value2)
|
||||
free(value2);
|
||||
if (value3)
|
||||
free(value3);
|
||||
if (value4)
|
||||
free(value4);
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
if (value1 && value2 && value3 && !value4) {
|
||||
if (read_size_from_string(value1, variable) && g_str_equal(value2, "*") &&
|
||||
read_double_with_percent(value3, multiplier)) {
|
||||
if (value1)
|
||||
free(value1);
|
||||
if (value2)
|
||||
free(value2);
|
||||
if (value3)
|
||||
free(value3);
|
||||
if (value4)
|
||||
free(value4);
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
if (value1 && value2 && value3 && value4) {
|
||||
if (read_origin_from_string(value1, variable_element) && read_size_from_string(value2, variable) &&
|
||||
if (read_element_from_string(value1, variable_element) && read_size_from_string(value2, variable) &&
|
||||
g_str_equal(value3, "*") && read_double_with_percent(value4, multiplier)) {
|
||||
if (value1)
|
||||
free(value1);
|
||||
@@ -178,18 +204,21 @@ gboolean read_size_variable_from_string(const char *str,
|
||||
Offset *offset_from_string(const char *str)
|
||||
{
|
||||
Offset *offset = (Offset *)calloc(1, sizeof(Offset));
|
||||
// number ?
|
||||
if (read_double(str, &offset->constant_value)) {
|
||||
offset->constant = TRUE;
|
||||
return offset;
|
||||
}
|
||||
// SIZE ?
|
||||
offset->constant = FALSE;
|
||||
|
||||
if (read_size_variable_from_string(str, &offset->variable_element, &offset->variable, &offset->multiplier)) {
|
||||
if (read_size_variable_from_string(str, &offset->element, &offset->variable, &offset->multiplier)) {
|
||||
if (debug_gradients)
|
||||
fprintf(stderr,
|
||||
"Read offset '%s' as: %d %d %f\n",
|
||||
str,
|
||||
offset->element,
|
||||
offset->variable,
|
||||
offset->multiplier);
|
||||
return offset;
|
||||
}
|
||||
|
||||
free(offset);
|
||||
return NULL;
|
||||
}
|
||||
@@ -199,63 +228,61 @@ void init_gradient(GradientClass *g, GradientType type)
|
||||
memset(g, 0, sizeof(*g));
|
||||
g->type = type;
|
||||
if (g->type == GRADIENT_VERTICAL) {
|
||||
g->from.origin = ORIGIN_ELEMENT;
|
||||
Offset *offset_top = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_top->constant = TRUE;
|
||||
offset_top->constant_value = 0;
|
||||
g->from.offsets_y = g_list_append(g->from.offsets_y, offset_top);
|
||||
Offset *offset_bottom = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_bottom->constant = FALSE;
|
||||
offset_bottom->variable_element = ORIGIN_ELEMENT;
|
||||
offset_bottom->element = ELEMENT_SELF;
|
||||
offset_bottom->variable = SIZE_HEIGHT;
|
||||
offset_bottom->multiplier = 1.0;
|
||||
g->from.offsets_y = g_list_append(g->from.offsets_y, offset_bottom);
|
||||
g->to.offsets_y = g_list_append(g->to.offsets_y, offset_bottom);
|
||||
} else if (g->type == GRADIENT_HORIZONTAL) {
|
||||
g->from.origin = ORIGIN_ELEMENT;
|
||||
Offset *offset_left = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_left->constant = TRUE;
|
||||
offset_left->constant_value = 0;
|
||||
g->from.offsets_x = g_list_append(g->from.offsets_x, offset_left);
|
||||
Offset *offset_right = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_right->constant = FALSE;
|
||||
offset_right->variable_element = ORIGIN_ELEMENT;
|
||||
offset_right->element = ELEMENT_SELF;
|
||||
offset_right->variable = SIZE_WIDTH;
|
||||
offset_right->multiplier = 1.0;
|
||||
g->from.offsets_x = g_list_append(g->from.offsets_x, offset_right);
|
||||
g->to.offsets_x = g_list_append(g->to.offsets_x, offset_right);
|
||||
} else if (g->type == GRADIENT_CENTERED) {
|
||||
g->from.origin = ORIGIN_ELEMENT;
|
||||
// from
|
||||
Offset *offset_center_x = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_x->constant = FALSE;
|
||||
offset_center_x->variable_element = ORIGIN_ELEMENT;
|
||||
offset_center_x->variable = SIZE_CENTER;
|
||||
offset_center_x->element = ELEMENT_SELF;
|
||||
offset_center_x->variable = SIZE_CENTERX;
|
||||
offset_center_x->multiplier = 1.0;
|
||||
g->from.offsets_x = g_list_append(g->from.offsets_x, offset_center_x);
|
||||
Offset *offset_center_y = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_y->constant = FALSE;
|
||||
offset_center_y->variable_element = ORIGIN_ELEMENT;
|
||||
offset_center_y->variable = SIZE_CENTER;
|
||||
offset_center_y->element = ELEMENT_SELF;
|
||||
offset_center_y->variable = SIZE_CENTERY;
|
||||
offset_center_y->multiplier = 1.0;
|
||||
g->from.offsets_y = g_list_append(g->from.offsets_y, offset_center_y);
|
||||
Offset *offset_center_r = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_x->constant = TRUE;
|
||||
offset_center_x->constant_value = 0;
|
||||
offset_center_r->constant = TRUE;
|
||||
offset_center_r->constant_value = 0;
|
||||
g->from.offsets_r = g_list_append(g->from.offsets_r, offset_center_r);
|
||||
g->to.origin = ORIGIN_ELEMENT;
|
||||
// to
|
||||
offset_center_x = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_x->constant = FALSE;
|
||||
offset_center_x->variable_element = ORIGIN_ELEMENT;
|
||||
offset_center_x->variable = SIZE_CENTER;
|
||||
offset_center_x->element = ELEMENT_SELF;
|
||||
offset_center_x->variable = SIZE_CENTERX;
|
||||
offset_center_x->multiplier = 1.0;
|
||||
g->to.offsets_x = g_list_append(g->to.offsets_x, offset_center_x);
|
||||
offset_center_y = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_y->constant = FALSE;
|
||||
offset_center_y->variable_element = ORIGIN_ELEMENT;
|
||||
offset_center_y->variable = SIZE_CENTER;
|
||||
offset_center_y->element = ELEMENT_SELF;
|
||||
offset_center_y->variable = SIZE_CENTERY;
|
||||
offset_center_y->multiplier = 1.0;
|
||||
g->to.offsets_y = g_list_append(g->to.offsets_y, offset_center_y);
|
||||
offset_center_r = (Offset *)calloc(1, sizeof(Offset));
|
||||
offset_center_r->constant = FALSE;
|
||||
offset_center_r->variable_element = ORIGIN_ELEMENT;
|
||||
offset_center_r->element = ELEMENT_SELF;
|
||||
offset_center_r->variable = SIZE_RADIUS;
|
||||
offset_center_r->multiplier = 1.0;
|
||||
g->to.offsets_r = g_list_append(g->to.offsets_r, offset_center_r);
|
||||
@@ -275,4 +302,5 @@ void cleanup_gradient(GradientClass *g)
|
||||
g_list_free_full(g->to.offsets_x, free);
|
||||
g_list_free_full(g->to.offsets_y, free);
|
||||
g_list_free_full(g->to.offsets_r, free);
|
||||
bzero(g, sizeof(*g));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user