📄 libslp_findscopes.c
字号:
/***************************************************************************//* *//* Project: OpenSLP - OpenSource implementation of Service Location *//* Protocol Version 2 *//* *//* File: slplib_findattrs.c *//* *//* Abstract: Implementation for SLPFindScopes() call. *//* *//*-------------------------------------------------------------------------*//* *//* 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.h"#include "libslp.h"/*=========================================================================*/SLPError SLPAPI SLPFindScopes(SLPHandle hSLP, char** ppcScopeList)/* *//* Sets ppcScopeList parameter to a pointer to a comma separated list *//* including all available scope values. The list of scopes comes from *//* a variety of sources: the configuration file's net.slp.useScopes *//* property, unicast to DAs on the net.slp.DAAddresses property, DHCP, *//* or through the DA discovery process. If there is any order to the *//* scopes, preferred scopes are listed before less desirable scopes. *//* There is always at least one name in the list, the default scope, *//* "DEFAULT". *//* *//* hSLP The SLPHandle on which to search for scopes. *//* *//* ppcScopeList A pointer to char pointer into which the buffer pointer is *//* placed upon return. The buffer is null terminated. The *//* memory should be freed by calling SLPFree(). *//* *//* Returns: If no error occurs, returns SLP_OK, otherwise, the a *//* ppropriate error code. *//*=========================================================================*/{ int scopelistlen; /*------------------------------*/ /* check for invalid parameters */ /*------------------------------*/ if(hSLP == 0 || *(unsigned int*)hSLP != SLP_HANDLE_SIG || ppcScopeList == 0) { return SLP_PARAMETER_BAD; } /* start with nothing */ *ppcScopeList = 0;#ifndef MI_NOT_SUPPORTED if(KnownDAGetScopes(&scopelistlen,ppcScopeList, hSLP))#else if(KnownDAGetScopes(&scopelistlen,ppcScopeList))#endif /* MI_NOT_SUPPORTED */ { return SLP_MEMORY_ALLOC_FAILED; } return SLP_OK;}/*=========================================================================*/unsigned short SLPAPI SLPGetRefreshInterval()/* *//* Returns the maximum across all DAs of the min-refresh-interval *//* attribute. This value satisfies the advertised refresh interval *//* bounds for all DAs, and, if used by the SA, assures that no refresh *//* registration will be rejected. If no DA advertises a min-refresh- *//* interval attribute, a value of 0 is returned. *//* *//* Returns: If no error, the maximum refresh interval value allowed by all *//* DAs (a positive integer). If no DA advertises a *//* min-refresh-interval attribute, returns 0. If an error occurs,*/ /* returns an SLP error code. *//*=========================================================================*/{ return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -