Mercurial > hg > nginx
diff src/core/ngx_conf_file.h @ 43:53cd05892261
nginx-0.0.1-2002-12-27-19:22:50 import
author | Igor Sysoev <igor@sysoev.ru> |
---|---|
date | Fri, 27 Dec 2002 16:22:50 +0000 |
parents | src/core/ngx_config_file.h@cd035a94e0b6 |
children | 0e81ac0bb3e2 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/core/ngx_conf_file.h Fri Dec 27 16:22:50 2002 +0000 @@ -0,0 +1,87 @@ +#ifndef _NGX_HTTP_CONF_FILE_H_INCLUDED_ +#define _NGX_HTTP_CONF_FILE_H_INCLUDED_ + + +#include <ngx_config.h> +#include <ngx_files.h> +#include <ngx_log.h> +#include <ngx_file.h> +#include <ngx_string.h> +#include <ngx_alloc.h> +#include <ngx_hunk.h> +#include <ngx_array.h> + + +#define NGX_CONF_NOARGS 1 +#define NGX_CONF_TAKE1 2 +#define NGX_CONF_TAKE2 4 +#define NGX_CONF_ARGS_NUMBER 0x0ffff +#define NGX_CONF_ANY 0x10000 +#define NGX_CONF_BLOCK 0x20000 + + +#define NGX_CONF_UNSET -1 + + +#define NGX_CONF_ERROR (char *) -1 + +#define NGX_CONF_BLOCK_DONE 1 +#define NGX_CONF_FILE_DONE 2 + + +#define NGX_CORE_MODULE_TYPE 0x45524f43 /* "CORE" */ + + +typedef struct ngx_conf_s ngx_conf_t; + + +typedef struct ngx_command_s ngx_command_t; +struct ngx_command_s { + ngx_str_t name; + int type; + char *(*set)(ngx_conf_t *cf, ngx_command_t *cmd, char *conf); + int conf; + int offset; +}; + + +typedef struct { + void *ctx; + ngx_command_t *commands; + int type; + int (*init_module)(ngx_pool_t *p); +} ngx_module_t; + + +typedef struct { + ngx_file_t file; + ngx_hunk_t *hunk; + int line; +} ngx_conf_file_t; + + +struct ngx_conf_s { + char *name; + ngx_array_t *args; + + ngx_pool_t *pool; + ngx_conf_file_t *conf_file; + ngx_log_t *log; + + void *ctx; + int type; + int (*handler)(ngx_conf_t *cf); +}; + + +int ngx_conf_parse(ngx_conf_t *cf, ngx_str_t *filename); + + +char *ngx_conf_set_size_slot(ngx_conf_t *cf, ngx_command_t *cmd, char *conf); +char *ngx_conf_set_time_slot(ngx_conf_t *cf, ngx_command_t *cmd, char *conf); + + +extern ngx_module_t *ngx_modules[]; + + +#endif _NGX_HTTP_CONF_FILE_H_INCLUDED_