You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

182 lines
8.2 KiB

/***************************************************************************/
/* */
/* Project: OpenSLP - OpenSource implementation of Service Location */
/* Protocol */
/* */
/* File: slp_buffer.c */
/* */
/* Abstract: Header file that defines structures and constants that are */
/* are used to control memory allocation in OpenSLP */
/* */
/*-------------------------------------------------------------------------*/
/* */
/* Please submit patches to http://www.openslp.org */
/* */
/*-------------------------------------------------------------------------*/
/* */
/* Copyright (C) 2000 Caldera Systems, Inc */
/* All rights reserved. */
/* */
/* Redistribution and use in source and binary forms, with or without */
/* modification, are permitted provided that the following conditions are */
/* met: */
/* */
/* Redistributions of source code must retain the above copyright */
/* notice, this list of conditions and the following disclaimer. */
/* */
/* Redistributions in binary form must reproduce the above copyright */
/* notice, this list of conditions and the following disclaimer in */
/* the documentation and/or other materials provided with the */
/* distribution. */
/* */
/* Neither the name of Caldera Systems nor the names of its */
/* contributors may be used to endorse or promote products derived */
/* from this software without specific prior written permission. */
/* */
/* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
/* `AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
/* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR */
/* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE CALDERA */
/* SYSTEMS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
/* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT */
/* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, */
/* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON */
/* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT */
/* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE */
/* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
/* */
/***************************************************************************/
#include "slp_buffer.h"
#include "slp_xmalloc.h"
/*=========================================================================*/
void* memdup(const void* src, int srclen)
/* Generic memdup analogous to strdup() */
/*=========================================================================*/
{
char* result;
result = (unsigned char*)xmalloc(srclen);
if(result)
{
memcpy(result,src,srclen);
}
return result;
}
/*=========================================================================*/
SLPBuffer SLPBufferAlloc(size_t size)
/* Must be called to initially allocate a SLPBuffer */
/* */
/* size - (IN) number of bytes to reallocate */
/* */
/* returns - newly allocated SLPBuffer or NULL on ENOMEM. An extra byte */
/* is allocated to null terminating strings. This extra byte */
/* is not counted in the buffer size */
/*=========================================================================*/
{
SLPBuffer result;
/* allocate an extra byte for null terminating strings */
result = (SLPBuffer)xmalloc(sizeof(struct _SLPBuffer) + size + 1);
if(result)
{
result->allocated = size;
result->start = (unsigned char*)(result + 1);
result->curpos = result->start;
result->end = result->start + size;
#if(defined DEBUG)
memset(result->start,0x4d,size + 1);
#endif
}
return result;
}
/*=========================================================================*/
SLPBuffer SLPBufferRealloc(SLPBuffer buf, size_t size)
/* Must be called to initially allocate a SLPBuffer */
/* */
/* size - (IN) number of bytes to allocate */
/* */
/* returns - newly (re)allocated SLPBuffer or NULL on ENOMEM. An extra */
/* byte is allocated to null terminating strings. This extra */
/* byte is not counted in the buffer size */
/*=========================================================================*/
{
SLPBuffer result;
if(buf)
{
if(buf->allocated >= size)
{
result = buf;
}
else
{
/* allocate an extra byte for null terminating strings */
result = (SLPBuffer)xrealloc(buf, sizeof(struct _SLPBuffer) +
size + 1);
result->allocated = size;
}
if(result)
{
result->start = (unsigned char*)(result + 1);
result->curpos = result->start;
result->end = result->start + size;
#if(defined DEBUG)
memset(result->start,0x4d,size + 1);
#endif
}
}
else
{
result = SLPBufferAlloc(size);
}
return result;
}
/*=========================================================================*/
SLPBuffer SLPBufferDup(SLPBuffer buf)
/* Returns a duplicate buffer. Duplicate buffer must be freed by a call */
/* to SLPBufferFree() */
/* */
/* size - (IN) number of bytes to allocate */
/* */
/* returns - a newly allocated SLPBuffer or NULL on ENOMEM */
/*=========================================================================*/
{
SLPBuffer dup;
dup = SLPBufferAlloc(buf->end - buf->start);
if(dup)
{
memcpy(dup->start,buf->start,buf->end - buf->start);
}
return dup;
}
/*=========================================================================*/
void SLPBufferFree(SLPBuffer buf)
/* Free a previously allocated SLPBuffer */
/* */
/* msg - (IN) the SLPBuffer to free */
/* */
/* returns - none */
/*=========================================================================*/
{
if(buf)
{
xfree(buf);
}
}