/*
** Copyright (c) 2001 The OSSP Project
** Copyright (c) 2001 Cable & Wireless Deutschland
**
** This file is part of OSSP lmtp2nntp, an LMTP speaking local
** mailer which forwards mails as Usenet news articles via NNTP.
** It can be found at http://www.ossp.org/pkg/lmtp2nntp/.
**
** This program is free software; you can redistribute it and/or
** modify it under the terms of the GNU General Public License
** as published by the Free Software Foundation; either version
** 2.0 of the License, or (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
** General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this file; if not, write to the Free Software
** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
** USA, or contact the OSSP project .
**
** trace.c: I/O tracing support
*/
#include
#include
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#if defined(HAVE_DMALLOC_H) && defined(DMALLOC)
#include "dmalloc.h"
#endif
#include "trace.h"
#ifndef _POSIX_PATH_MAX
#if defined(PATH_MAX)
#define _POSIX_PATH_MAX PATH_MAX
#elif defined(MAX_PATH)
#define _POSIX_PATH_MAX MAX_PATH
#else
#error "unable to determime maximum path limit"
#endif
#endif
/*
* tracing
*/
ssize_t trace_read(int d, void *buf, size_t nbytes)
{
ssize_t rc;
int tf;
static char tfn[_POSIX_PATH_MAX] = "/tmp/trace";
if ((d == -1) && (buf != NULL) && (nbytes == 0)) {
strncpy(tfn, buf, _POSIX_PATH_MAX-1);
}
rc = read(d, buf, nbytes);
if ((tf = open(tfn, O_CREAT|O_WRONLY|O_APPEND, 0664)) != -1) {
write(tf, buf, rc);
close(tf);
}
return rc;
}
ssize_t trace_write(int d, const void *buf, size_t nbytes)
{
ssize_t rc;
int tf;
static char tfn[_POSIX_PATH_MAX] = "/tmp/trace";
if ((d == -1) && (buf != NULL) && (nbytes == 0)) {
strncpy(tfn, buf, _POSIX_PATH_MAX-1);
}
rc = write(d, buf, nbytes);
if ((tf = open(tfn, O_CREAT|O_WRONLY|O_APPEND, 0664)) != -1) {
write(tf, buf, rc);
close(tf);
}
return rc;
}