return cpy;
}
-char *shell_escape(char *s)
-{
- char *e = malloc(2 * strlen(s) + 1);
-
- if (e == NULL) {
- return NULL;
- }
-
- int c = 0;
- int j = 0;
-
- for (size_t i = 0; i < strlen(s); i++) {
- if (s[i] == '\\') {
- c += 1;
- } else {
- if (s[i] == '$' || s[i] == '(' || s[i] == ')') {
- if (c % 2 == 0) {
- e[j++] = '\\';
- }
- }
- c = 0;
- }
- e[j++] = s[i];
- }
-
- e[j] = '\0';
- return e;
-}
-
char *mktempfifo(const char *template)
{
int tempfd;
void err(char *fmt, ...);
char *read_string(const char *file_path, size_t *tlen);
char *copy_string(char *str, size_t len);
-char *shell_escape(char *s);
char *mktempfifo(const char *template);
int asprintf(char **buf, const char *fmt, ...);
int vasprintf(char **buf, const char *fmt, va_list args);
rect_buf = malloc(1);
*rect_buf = '\0';
}
- char *monitor_desc = shell_escape(csq->monitor_desc);
- char *desktop_desc = shell_escape(csq->desktop_desc);
- char *node_desc = shell_escape(csq->node_desc);
- char *split_dir = shell_escape(csq->split_dir);
asprintf(buf, "monitor=%s desktop=%s node=%s state=%s layer=%s split_dir=%s split_ratio=%lf hidden=%s sticky=%s private=%s locked=%s marked=%s center=%s follow=%s manage=%s focus=%s border=%s rectangle=%s",
- monitor_desc == NULL ? "" : monitor_desc,
- desktop_desc == NULL ? "" : desktop_desc,
- node_desc == NULL ? "" : node_desc,
+ csq->monitor_desc, csq->desktop_desc, csq->node_desc,
csq->state == NULL ? "" : STATE_STR(*csq->state),
csq->layer == NULL ? "" : LAYER_STR(*csq->layer),
- split_dir == NULL ? "" : split_dir, csq->split_ratio,
+ csq->split_dir, csq->split_ratio,
ON_OFF_STR(csq->hidden), ON_OFF_STR(csq->sticky), ON_OFF_STR(csq->private),
ON_OFF_STR(csq->locked), ON_OFF_STR(csq->marked), ON_OFF_STR(csq->center), ON_OFF_STR(csq->follow),
ON_OFF_STR(csq->manage), ON_OFF_STR(csq->focus), ON_OFF_STR(csq->border), rect_buf);
free(rect_buf);
- free(monitor_desc);
- free(desktop_desc);
- free(node_desc);
- free(split_dir);
}
void print_rectangle(char **buf, xcb_rectangle_t *rect)