Make start on i3bar json parsing

This commit is contained in:
crondog 2015-12-22 22:36:57 +11:00
parent 91c102a897
commit d1f6f45cb3

View file

@ -45,6 +45,18 @@ struct workspace {
bool urgent; bool urgent;
}; };
struct status_block {
char *full_text, *short_text, *align;
bool urgent;
uint32_t color;
int min_width;
char *name, *instance;
bool separator;
int separator_block_width;
};
list_t *status_line = NULL;
list_t *workspaces = NULL; list_t *workspaces = NULL;
int socketfd; int socketfd;
pid_t pid; pid_t pid;
@ -362,10 +374,21 @@ void render() {
// Command output // Command output
cairo_set_source_u32(window->cairo, colors.statusline); cairo_set_source_u32(window->cairo, colors.statusline);
int width, height; int width, height;
get_text_size(window, &width, &height, "%s", line);
cairo_move_to(window->cairo, window->width - margin - width, margin); if (status_line) {
pango_printf(window, "%s", line); int i;
int moved = 0;
for ( i = status_line->length - 1; i >= 0; --i ) {
struct status_block *block = status_line->items[i];
if (block->full_text) {
get_text_size(window, &width, &height, "%s", block->full_text);
moved += width + block->separator_block_width;
cairo_move_to(window->cairo, window->width - margin - moved, margin);
cairo_set_source_u32(window->cairo, block->color);
pango_printf(window, "%s", block->full_text);
}
}
}
// Workspaces // Workspaces
cairo_set_line_width(window->cairo, 1.0); cairo_set_line_width(window->cairo, 1.0);
@ -401,6 +424,116 @@ void render() {
} }
} }
void parse_json(const char *text) {
/*
* {
"full_text": "E: 10.0.0.1 (1000 Mbit/s)",
"short_text": "10.0.0.1",
"color": "#00ff00",
"min_width": 300,
"align": "right",
"urgent": false,
"name": "ethernet",
"instance": "eth0",
"separator": true,
"separator_block_width": 9
}
*
*
*
* */
json_object *result = json_tokener_parse(text);
if (!result) {
sway_log(L_DEBUG, "xxx Failed to parse json");
return;
}
if (json_object_array_length(result) < 1) {
return;
}
if (status_line) {
free_flat_list(status_line);
}
status_line = create_list();
int i;
for (i = 0; i < json_object_array_length(result); ++i) {
json_object *full_text, *short_text, *color, *min_width, *align, *urgent;
json_object *name, *instance, *separator, *separator_block_width;
json_object *json = json_object_array_get_idx(result, i);
if (!json) {
continue;
}
json_object_object_get_ex(json, "full_text", &full_text);
json_object_object_get_ex(json, "short_text", &short_text);
json_object_object_get_ex(json, "color", &color);
json_object_object_get_ex(json, "min_width", &min_width);
json_object_object_get_ex(json, "align", &align);
json_object_object_get_ex(json, "urgent", &urgent);
json_object_object_get_ex(json, "name", &name);
json_object_object_get_ex(json, "instance", &instance);
json_object_object_get_ex(json, "separator", &separator);
json_object_object_get_ex(json, "separator_block_width", &separator_block_width);
struct status_block *new = malloc(sizeof(struct status_block));
memset(new, 0, sizeof(struct status_block));
if (full_text) {
new->full_text = strdup(json_object_get_string(full_text));
}
if (short_text) {
new->short_text = strdup(json_object_get_string(short_text));
}
if (color) {
new->color = parse_color(json_object_get_string(color));
}
else {
new->color = 0xFFFFFFFF;
}
if (min_width) {
new->min_width = json_object_get_int(min_width);
}
if (align) {
new->align = strdup(json_object_get_string(align));
}
if (urgent) {
new->urgent = json_object_get_int(urgent);
}
if (name) {
new->name = strdup(json_object_get_string(name));
}
if (instance) {
new->instance = strdup(json_object_get_string(instance));
}
if (separator) {
new->separator = json_object_get_int(separator);
}
else {
new->separator = true; // i3bar spec
}
if (separator_block_width) {
new->separator_block_width = json_object_get_int(separator_block_width);
}
else {
new->separator_block_width = 9; // i3bar spec
}
list_add(status_line, new);
}
}
void poll_for_update() { void poll_for_update() {
fd_set readfds; fd_set readfds;
int activity; int activity;
@ -437,17 +570,22 @@ void poll_for_update() {
if (status_command && FD_ISSET(pipefd[0], &readfds)) { if (status_command && FD_ISSET(pipefd[0], &readfds)) {
sway_log(L_DEBUG, "Got update from status command."); sway_log(L_DEBUG, "Got update from status command.");
fgets(line, sizeof(line), command); fgets(line, sizeof(line), command);
sway_log(L_DEBUG, "zzz %s", line);
int l = strlen(line) - 1; int l = strlen(line) - 1;
if (line[l] == '\n') { if (line[l] == '\n') {
line[l] = '\0'; line[l] = '\0';
} }
if (line[0] == ',') {
line[0] = ' ';
}
dirty = true; dirty = true;
parse_json(line);
} }
} }
} }
int main(int argc, char **argv) { int main(int argc, char **argv) {
init_log(L_INFO); init_log(L_DEBUG);
char *socket_path = NULL; char *socket_path = NULL;
char *bar_id = NULL; char *bar_id = NULL;