diff --git a/src/config/parse_config.h b/src/config/parse_config.h index b795a81..7909bcc 100644 --- a/src/config/parse_config.h +++ b/src/config/parse_config.h @@ -80,8 +80,8 @@ typedef struct { const char *monitor; int32_t offsetx; int32_t offsety; - int32_t width; - int32_t height; + float width; + float height; int32_t nofocus; int32_t nofadein; int32_t nofadeout; @@ -2058,9 +2058,9 @@ bool parse_option(Config *config, char *key, char *value) { } else if (strcmp(key, "no_force_center") == 0) { rule->no_force_center = atoi(val); } else if (strcmp(key, "width") == 0) { - rule->width = atoi(val); + rule->width = atof(val); } else if (strcmp(key, "height") == 0) { - rule->height = atoi(val); + rule->height = atof(val); } else if (strcmp(key, "isnoborder") == 0) { rule->isnoborder = atoi(val); } else if (strcmp(key, "isnoshadow") == 0) { diff --git a/src/mango.c b/src/mango.c index 591d4f6..46a2d78 100644 --- a/src/mango.c +++ b/src/mango.c @@ -1405,10 +1405,14 @@ void applyrules(Client *c) { // set geometry of floating client - if (r->width > 0) + if (r->width > 1) c->float_geom.width = r->width; - if (r->height > 0) + else + c->float_geom.width = round(mon->m.width * r->width); + if (r->height > 1) c->float_geom.height = r->height; + else + c->float_geom.height = round(mon->m.height * r->height); if (r->width > 0 || r->height > 0) { c->iscustomsize = 1;