static void specific_handler_on_context_dispose(h2o_handler_t *_self, h2o_context_t *ctx) { struct st_h2o_specific_file_handler_t *self = (void *)_self; if (self->mime_type->type == H2O_MIMEMAP_TYPE_DYNAMIC) h2o_context_dispose_pathconf_context(ctx, &self->mime_type->data.dynamic.pathconf); }
void h2o_context_dispose(h2o_context_t *ctx) { h2o_globalconf_t *config = ctx->globalconf; size_t i, j; for (i = 0; config->hosts[i] != NULL; ++i) { h2o_hostconf_t *hostconf = config->hosts[i]; for (j = 0; j != hostconf->paths.size; ++j) { h2o_pathconf_t *pathconf = hostconf->paths.entries + j; h2o_context_dispose_pathconf_context(ctx, pathconf); } h2o_context_dispose_pathconf_context(ctx, &hostconf->fallback_path); } free(ctx->_pathconfs_inited.entries); free(ctx->_module_configs); h2o_timeout_dispose(ctx->loop, &ctx->zero_timeout); h2o_timeout_dispose(ctx->loop, &ctx->one_sec_timeout); h2o_timeout_dispose(ctx->loop, &ctx->hundred_ms_timeout); h2o_timeout_dispose(ctx->loop, &ctx->handshake_timeout); h2o_timeout_dispose(ctx->loop, &ctx->http1.req_timeout); h2o_timeout_dispose(ctx->loop, &ctx->http2.idle_timeout); h2o_timeout_dispose(ctx->loop, &ctx->proxy.io_timeout); /* what should we do here? assert(!h2o_linklist_is_empty(&ctx->http2._conns); */ h2o_filecache_destroy(ctx->filecache); ctx->filecache = NULL; /* TODO assert that the all the getaddrinfo threads are idle */ h2o_multithread_unregister_receiver(ctx->queue, &ctx->receivers.hostinfo_getaddr); h2o_multithread_destroy_queue(ctx->queue); #if H2O_USE_LIBUV /* make sure the handles released by h2o_timeout_dispose get freed */ uv_run(ctx->loop, UV_RUN_NOWAIT); #endif }