enum lws_callback_reasons reason,
void *user, void *in, size_t len)
{
+ struct lws_context *context = lws_get_context(wsi);
struct lws_vhost *vhost = lws_get_vhost(wsi);
const struct lws_protocols *prot = lws_get_protocol(wsi);
/*
int n, m;
- list *lines = (list *)prot->user;
+ list *lines = (list *)lws_context_user(context);
char *line;
switch (reason) {
vhost, prot,
sizeof(struct per_vhost_data__merica_terminal)
);
- vhd->context = lws_get_context(wsi);
+ vhd->context = context;
vhd->protocol = prot;
vhd->vhost = vhost;
break;
m = lws_write(wsi, (unsigned char *)line, n, LWS_WRITE_TEXT);
list_remove(lines);
if (lines->first) {
- lws_callback_on_writable_all_protocol(lws_get_context(wsi),
+ lws_callback_on_writable_all_protocol(context,
&protocols[PROTOCOL_MERICA_TERMINAL]);
}
} else {
line = copy_line(JSON_EMPTY);
if (line) {
if (list_add(lines, line) == 0) {
- lws_callback_on_writable_all_protocol(lws_get_context(wsi),
+ lws_callback_on_writable_all_protocol(context,
&protocols[PROTOCOL_MERICA_TERMINAL]);
} else {
free_line(line);
{
struct lws_context_creation_info info;
+ list *l = list_init();
+ if (!l) {
+ return -1;
+ }
+
memset(&info, 0, sizeof(info));
info.port = HTTP_PORT;
info.mounts = &mount;
info.protocols = protocols;
info.max_http_header_pool = 1;
info.options |= LWS_SERVER_OPTION_LIBEV;
+ info.user = l;
struct lws_context *context = lws_create_context(&info);
if (!context) {
fprintf(stderr, "lws_create_context failed\n");
+ list_deinit(l);
return -1;
}
ev_io_ws *w = &(self->fd_watcher);
w->context = context;
- w->lines = list_init();
- if (!w->lines) {
- return -1;
- }
- protocols[PROTOCOL_MERICA_TERMINAL].user = (void *)w->lines;
+ w->lines = l;
+
char *line = new_line();
if (!line) {
- list_deinit(w->lines);
+ list_deinit(l);
return -1;
}
w->text = line;