view src/http/ngx_http_script.c @ 463:1f31dc6d33a3 release-0.1.6

nginx-0.1.6-RELEASE import *) Bugfix: some location directive combinations with the regular expressions caused the wrong configuration choose.
author Igor Sysoev <igor@sysoev.ru>
date Thu, 11 Nov 2004 20:58:09 +0000
parents a88a3e4e158f
children c52408583801
line wrap: on
line source


/*
 * Copyright (C) Igor Sysoev
 */


#include <ngx_config.h>
#include <ngx_core.h>
#include <ngx_http.h>


char *ngx_http_script_copy(ngx_http_request_t *r,
                           ngx_http_script_code_t *code,
                           char *p, size_t len)
{
    return ngx_cpymem(p, code->offset, code->len < len ? code->len : len);
}


char *ngx_http_script_header_in(ngx_http_request_t *r,
                                ngx_http_script_code_t *code,
                                char *p, size_t len)
{
    ngx_str_t *s;

    s = (ngx_str_t *) (((char *) r->headers_in) + code->offset);

    return ngx_cpymem(p, s->data, s->len < len ? s->len : len);
}


/* the log script codes */

char *ngx_http_script_request_line(ngx_http_request_t *r, char *p, size_t len)
{
    return ngx_cpymem(p, r->request_line.data,
                      r->request_line.len < len ? r->request_line.len : len);
}


char *ngx_http_script_status(ngx_http_request_t *r, char *p, size_t len)
{
    return ngx_snprintf(p, len, "%d", r->headers_out.status);
}


char *ngx_http_script_sent(ngx_http_request_t *r, char *p, size_t len)
{
    return ngx_sprintf(p, "%O", r->connection->sent);
}