Mercurial > hg > nginx-vendor-current
view src/core/ngx_inet.h @ 244:500a3242dff6 NGINX_0_4_7
nginx 0.4.7
*) Feature: the ngx_http_flv_module.
*) Feature: the $request_body_file variable.
*) Feature: the "charset" and "source_charset" directives support the
variables.
*) Bugfix: if an "include" SSI command were before another "include"
SSI command with an "wait" parameter, then the "wait" parameter
might not work.
*) Bugfix: if the "proxy_buffering off" directive was used or while
working with memcached the connections might not be closed on
timeout.
*) Bugfix: nginx did not run on 64-bit platforms except amd64, sparc64,
and ppc64.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Tue, 10 Oct 2006 00:00:00 +0400 |
parents | 56688ed172c8 |
children | 644510700914 |
line wrap: on
line source
/* * Copyright (C) Igor Sysoev */ #ifndef _NGX_INET_H_INCLUDED_ #define _NGX_INET_H_INCLUDED_ #include <ngx_config.h> #include <ngx_core.h> #define NGX_PARSE_URL_INET 1 #define NGX_PARSE_URL_UNIX 2 typedef struct { in_addr_t addr; in_addr_t mask; } ngx_inet_cidr_t; typedef struct { struct sockaddr *sockaddr; socklen_t socklen; ngx_str_t name; char *uri_separator; ngx_uint_t current_weight; ngx_uint_t weight; ngx_uint_t fails; time_t accessed; ngx_uint_t max_fails; time_t fail_timeout; #if (NGX_SSL) ngx_ssl_session_t *ssl_session; #endif } ngx_peer_t; struct ngx_peers_s { ngx_uint_t current; ngx_uint_t number; ngx_uint_t last_cached; /* ngx_mutex_t *mutex; */ ngx_connection_t **cached; ngx_peer_t peer[1]; }; typedef struct { ngx_int_t type; ngx_peers_t *peers; ngx_str_t url; ngx_str_t host; ngx_str_t host_header; ngx_str_t port; ngx_str_t uri; in_port_t portn; in_port_t default_portn; unsigned listen:1; unsigned uri_part:1; unsigned upstream:1; unsigned default_port:1; unsigned wildcard:1; char *err; } ngx_url_t; typedef struct { ngx_str_t name; /* "schema:host:port/uri" */ ngx_str_t url; /* "host:port/uri" */ ngx_str_t host; ngx_str_t uri; ngx_str_t host_header; /* "host:port" */ ngx_str_t port_text; /* "port" */ in_port_t port; in_port_t default_port_value; unsigned default_port:1; unsigned wildcard:1; unsigned uri_part:1; unsigned port_only:1; } ngx_inet_upstream_t; size_t ngx_sock_ntop(int family, struct sockaddr *sa, u_char *text, size_t len); size_t ngx_inet_ntop(int family, void *addr, u_char *text, size_t len); ngx_int_t ngx_ptocidr(ngx_str_t *text, void *cidr); ngx_peers_t *ngx_inet_upstream_parse(ngx_conf_t *cf, ngx_inet_upstream_t *u); ngx_peers_t *ngx_inet_resolve_peer(ngx_conf_t *cf, ngx_str_t *name, in_port_t port); char *ngx_inet_parse_host_port(ngx_inet_upstream_t *u); ngx_int_t ngx_parse_url(ngx_conf_t *cf, ngx_url_t *u); #endif /* _NGX_INET_H_INCLUDED_ */