⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 slp_linkedlist.h

📁 SLP协议在linux下的实现。此版本为1.2.1版。官方网站为www.openslp.org
💻 H
字号:
/***************************************************************************//*                                                                         *//* Project:     OpenSLP                                                    *//*                                                                         *//* File:        linkedlist.h                                               *//*                                                                         *//* Abstract:    Functions to manipulate a simple linked list               *//*                                                                         *//*-------------------------------------------------------------------------*//*                                                                         *//*     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.    *//*                                                                         *//***************************************************************************/#if(!defined LINKEDLIST_H_INCLUDED)#define LINKEDLIST_H_INCLUDED/*=========================================================================*/typedef struct _SLPListItem/*=========================================================================*/{    struct _SLPListItem*    previous;    struct _SLPListItem*    next;}SLPListItem;/*=========================================================================*/typedef struct _SLPList/*=========================================================================*/{    SLPListItem* head;    SLPListItem* tail;    int          count;}SLPList;/*=========================================================================*/SLPListItem* SLPListUnlink(SLPList* list, SLPListItem* item);/* Unlinks the specified item from the specified list.                     *//*                                                                         *//* list     (IN) pointer to the list to unlink the item from               *//*                                                                         *//* item     (IN) item to be removed from the list                          *//*                                                                         *//* Returns  pointer to the unlinked item                                   *//*=========================================================================*//*=========================================================================*/SLPListItem* SLPListLinkHead(SLPList* list, SLPListItem* item);/* Links the specified item to the head of the specified list.             *//*                                                                         *//* list     (IN) pointer to the list to link to                            *//*                                                                         *//* item     (IN) item to be linkedto the list                              *//*                                                                         *//* Returns  pointer to the linked item                                     *//*=========================================================================*//*=========================================================================*/SLPListItem* SLPListLinkTail(SLPList* list, SLPListItem* item);/* Links the specified item to the tail of the specified list.             *//*                                                                         *//* list     (IN) pointer to the list to link to                            *//*                                                                         *//* item     (IN) item to be linkedto the list                              *//*                                                                         *//* Returns  pointer to the linked item                                     *//*=========================================================================*/  /********* circular list macros *********************/  /*---------------------------------------------------------------------**  ** structures used with these macros MUST have the following elements: **  ** struct type-name {                                                  **  ** 	struct type-name *next;                                            **  ** 	struct type-name *prev;                                            **  ** 	BOOL isHead;                                                       **  ** 	}                                                                  **  **---------------------------------------------------------------------*/  /*  is node x the head of the list? */  /* BOOL IS_HEAD(node *x); */#define SLP_IS_HEAD(x) ((x)->isHead )  /* where h is the head of the list */  /* BOOLSLP_IS_EMPTY(head);          */#define SLP_IS_EMPTY(h) \	((((h)->next == (h)) && ((h)->prev == (h)) ) ? TRUE : FALSE)  /* where n is the new node, insert it immediately after node x */  /* x can be the head of the list                               */  /* voidSLP_INSERT(new, after);                                  */#define SLP_INSERT(n, x)   	\	{(n)->prev = (x); 		\	(n)->next = (x)->next; 	\	(x)->next->prev = (n); 	\	(x)->next = (n); }		#define SLP_INSERT_AFTERSLP_INSERT#define SLP_INSERT_BEFORE(n, x)   \	{(n)->next = (x);					\	(n)->prev = (x)->prev;				\	(x)->prev->next = (n);				\	(x)->prev = (n); }#define SLP_INSERT_WORKNODE_LAST(n, x)    \        {gettimeofday(&((n)->timer));  \	(n)->next = (x);	       \	(n)->prev = (x)->prev;	       \	(x)->prev->next = (n);	       \	(x)->prev = (n); }#define SLP_INSERT_WORKNODE_FIRST(n, x)    \        {gettimeofday(&((n)->timer));  \	(n)->prev = (x); 	       \	(n)->next = (x)->next; 	       \	(x)->next->prev = (n); 	       \	(x)->next = (n); }		  /* delete node x  - harmless if mib is empty */  /* voidSLP_DELETE_(x);                        */#define SLP_UNLINK(x)				\	{(x)->prev->next = (x)->next;	\	(x)->next->prev = (x)->prev;}	  /* given the head of the list h, determine if node x is the last node */  /* BOOLSLP_IS_LAST(head, x);                                           */#define SLP_IS_LAST(h, x) \	(((x)->prev == (h) && (h)->prev == (x)) ? TRUE : FALSE)  /* given the head of the list h, determine if node x is the first node */  /* BOOLSLP_IS_FIRST(head, x);                                           */#define SLP_IS_FIRST(h, x) \	(((x)->prev == (h) && (h)->next == (x)) ? TRUE : FALSE)  /* given the head of the list h, determine if node x is the only node */  /* BOOLSLP_IS_ONLY(head, x);                                           */#define SLP_IS_ONLY(h, x) \	(((x)->next == (h) && (h)->prev == (x)) ? TRUE : FALSE)  /* voidSLP_LINK_HEAD(dest, src); */#define SLP_LINK_HEAD(d, s) \	{(d)->next = (s)->next;  \	(d)->prev = (s)->prev;  \	(s)->next->prev = (d);  \	(s)->prev->next = (d); }#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -