logger.h revision 299742
1/* 2 * logger.h : Public definitions for the Repository Cache 3 * 4 * ==================================================================== 5 * Licensed to the Apache Software Foundation (ASF) under one 6 * or more contributor license agreements. See the NOTICE file 7 * distributed with this work for additional information 8 * regarding copyright ownership. The ASF licenses this file 9 * to you under the Apache License, Version 2.0 (the 10 * "License"); you may not use this file except in compliance 11 * with the License. You may obtain a copy of the License at 12 * 13 * http://www.apache.org/licenses/LICENSE-2.0 14 * 15 * Unless required by applicable law or agreed to in writing, 16 * software distributed under the License is distributed on an 17 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 18 * KIND, either express or implied. See the License for the 19 * specific language governing permissions and limitations 20 * under the License. 21 * ==================================================================== 22 */ 23 24#ifndef LOGGER_H 25#define LOGGER_H 26 27#ifdef __cplusplus 28extern "C" { 29#endif /* __cplusplus */ 30 31#include "server.h" 32 33 34 35/* Opaque svnserve log file writer data structure. Access to the log 36 * file will be serialized among threads within the same process. 37 */ 38typedef struct logger_t logger_t; 39 40/* In POOL, create a writer object that will write log messages to stderr 41 * and return it in *LOGGER. The log file will not add any buffering 42 * on top of stderr. 43 */ 44svn_error_t * 45logger__create_for_stderr(logger_t **logger, 46 apr_pool_t *pool); 47 48/* In POOL, create a writer object for log file FILENAME and return it 49 * in *LOGGER. The log file will be flushed & closed when POOL gets 50 * cleared or destroyed. 51 */ 52svn_error_t * 53logger__create(logger_t **logger, 54 const char *filename, 55 apr_pool_t *pool); 56 57/* Write the first LEN bytes from ERRSTR to the log file managed by LOGGER. 58 */ 59svn_error_t * 60logger__write(logger_t *logger, 61 const char *errstr, 62 apr_size_t len); 63 64/* Write a description of ERR with additional information from REPOSITORY 65 * and CLIENT_INFO to the log file managed by LOGGER. REPOSITORY as well 66 * as CLIENT_INFO may be NULL. If either ERR or LOGGER are NULL, this 67 * becomes a no-op. 68 */ 69void 70logger__log_error(logger_t *logger, 71 svn_error_t *err, 72 repository_t *repository, 73 client_info_t *client_info); 74 75#ifdef __cplusplus 76} 77#endif /* __cplusplus */ 78 79#endif /* LOGGER_H */ 80