📄 slp_database.c
字号:
/***************************************************************************//* *//* Project: OpenSLP - OpenSource implementation of Service Location *//* Protocol *//* *//* File: slp_database.c *//* *//* Abstract: An SLP message database. The SLP message database holds *//* actual SLP "wire" message buffers as well as structures *//* that interpret the message buffer. The database exposes *//* an interface suitable linked-list based implementation *//* *//*-------------------------------------------------------------------------*//* *//* 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_database.h"#include "slp_xmalloc.h"/*=========================================================================*/int SLPDatabaseInit(SLPDatabase* database)/* Initialize a SLPDatabase. *//* *//* Parameters: database (IN) pointer to the database to initialize *//* *//* *//* Returns: zero on success. Non-zero on error *//*=========================================================================*/{ if(database && database->head) { SLPDatabaseDeinit(database); } return 0;}/*=========================================================================*/void SLPDatabaseDeinit(SLPDatabase* database)/* Deinitialze a SLPDatabase *//* *//* Parameters: database (IN) pointer to the database to de-initialize *//* *//* Returns: none *//*=========================================================================*/{ while(database->count) { SLPDatabaseEntryDestroy((SLPDatabaseEntry*)SLPListUnlink(database,database->head)); } memset(database,0,sizeof(SLPDatabase));}/*=========================================================================*/SLPDatabaseEntry* SLPDatabaseEntryCreate(SLPMessage msg, SLPBuffer buf)/* Create a SLPDatabaseEntry. *//* *//* Parameters: msg (IN) The interpreting message structure for buf *//* buf (IN) The SLP message buffer *//* *//* Returns: Pointer to a new SLPDatabaseEntry. NULL if out of memory *//* *//* Note: VERY IMPORTANT. The msg and especially the buf are owned by the *//* returned SLPDatabaseEntry and MUST NOT be freed by the caller *//* via SLPMessageFree() or SLPBufferFree()! Instead, the caller *//* should use SLPDatabaseEntryDestroy() only to free memory *//*=========================================================================*/{ SLPDatabaseEntry* result; result = (SLPDatabaseEntry*)xmalloc(sizeof(SLPDatabaseEntry)); if(result) { result->msg = msg; result->buf = buf; } return result;}/*=========================================================================*/void SLPDatabaseEntryDestroy(SLPDatabaseEntry* entry)/* Free resources associated with the specified entry *//* *//* Parameters: entry (IN) pointer to the entry to destroy *//* *//* Returns: none *//*=========================================================================*/{ SLPMessageFree(entry->msg); SLPBufferFree(entry->buf); xfree(entry);}/*=========================================================================*/SLPDatabaseHandle SLPDatabaseOpen(SLPDatabase* database)/* Open a handle that is used with subsequent calls to SLPDatabaseEnum(), *//* SLPDatabaseAdd() and SLPDatabaseRemove() *//* *//* Parameters (IN) pointer an initialized SLPDatabase *//* *//* Returns: Valid handle. NULL on error. *//* *//* Note: It is important to make sure that handles returned by this *//* function are used and closed as quickly as possible. Future *//* may use handles to ensure syncronized access to the database *//* in threaded environments *//*=========================================================================*/{ SLPDatabaseHandle result; result = (SLPDatabaseHandle) xmalloc(sizeof(struct _SLPDatabaseHandle)); if(result) { result->database = database; result->current = (SLPDatabaseEntry*)database->head; } return result;}/*=========================================================================*/SLPDatabaseEntry* SLPDatabaseEnum(SLPDatabaseHandle dh)/* Used to enumerate through entries of a SLPDatabase *//* *//* Parameters: dh (IN) A handle obtained via SLPDatabaseOpen() *//* *//* Returns: Pointer to a SLPDatabase entry or NULL if end of enumeration *//* has been reached. *//*=========================================================================*/{ SLPDatabaseEntry* result; result = dh->current; if(result) { dh->current = (SLPDatabaseEntry*)((SLPListItem*)(dh->current))->next; } return result;}/*=========================================================================*/void SLPDatabaseRewind(SLPDatabaseHandle dh)/* Reset handle so SLPDatabaseEnum starts at the beginning again *//* *//* Parameters: eh (IN) A handle obtained via SLPDatabaseOpen() *//* *//* Returns: None *//*=========================================================================*/{ dh->current = (SLPDatabaseEntry*) dh->database->head; }/*=========================================================================*/void SLPDatabaseClose(SLPDatabaseHandle dh)/* Closes a handle obtained from SLPDatabaseOpen() *//* *//* Parameters: dh (IN) a handle obtained from SLPDatabaseOpenEnum() *//* *//* Returns: None *//*=========================================================================*/{ xfree(dh); dh = 0;}/*=========================================================================*/void SLPDatabaseRemove(SLPDatabaseHandle dh, SLPDatabaseEntry* entry)/* Removes the specified entry *//* *//* Parameters: dh (IN) The SLPDatabaseEnumHandle used to obtain *//* the entry in the first place *//* entry (IN) The entry to remove *//* *//* Returns: None *//* *//* Note: During removal SLPDatabaseEntryDestroy() is called on entry. *//* This means that you MUST NOT use entry after it is removed *//*=========================================================================*/{ SLPDatabaseEntryDestroy((SLPDatabaseEntry*)(SLPListUnlink(dh->database,(SLPListItem*)entry)));}/*=========================================================================*/void SLPDatabaseAdd(SLPDatabaseHandle dh, SLPDatabaseEntry* entry)/* Add the specified entry *//* *//* Parameters: dh (IN) handle obtained from SLPDatabseOpen() *//* entry (IN) the entry to add *//* *//* Return: None *//* *//* Note: DO NOT call SLPDatabaseEntryDestroy() on an entry that has been *//* added to the database. Instead call SLPDatabaseDeinit() or *//* SLPDatabaseRemove() to free resources associated with an added *//* entry *//*=========================================================================*/{ SLPListLinkTail(dh->database, (SLPListItem*)entry);}/*=========================================================================*/int SLPDatabaseCount(SLPDatabaseHandle dh)/* Returns the number of entries that are in the database *//*=========================================================================*/{ return dh->database->count;}#ifdef TEST_SLP_DATABASE_TESTint main(int argc, char* argv[]){ SLPDatabase testdb; SLPDatabaseEntry* testentry; SLPDatabaseInit(&testdb); SLPDatabaseDeinit(&testdb);}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -