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

📄 bitstring.h

📁 bind 9.3结合mysql数据库
💻 H
字号:
/* * Copyright (C) 2004  Internet Systems Consortium, Inc. ("ISC") * Copyright (C) 1999-2001  Internet Software Consortium. * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT, * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. *//* $Id: bitstring.h,v 1.7.206.1 2004/03/06 08:14:38 marka Exp $ */#ifndef ISC_BITSTRING_H#define ISC_BITSTRING_H 1/***** ***** Module Info *****//* * Bitstring * * A bitstring is a packed array of bits, stored in a contiguous * sequence of octets.  The "most significant bit" (msb) of a bitstring * is the high bit of the first octet.  The "least significant bit" of a * bitstring is the low bit of the last octet. * * Two bit numbering schemes are supported, "msb0" and "lsb0". * * In the "msb0" scheme, bit number 0 designates the most significant bit, * and any padding bits required to make the bitstring a multiple of 8 bits * long are added to the least significant end of the last octet. * * In the "lsb0" scheme, bit number 0 designates the least significant bit, * and any padding bits required to make the bitstring a multiple of 8 bits * long are added to the most significant end of the first octet. * * E.g., consider the bitstring "11010001111".  This bitstring is 11 bits * long and will take two octets.  Let "p" denote a pad bit.  In the msb0 * encoding, it would be * *             Octet 0           Octet 1 *                         | *         1 1 0 1 0 0 0 1 | 1 1 1 p p p p p *         ^               |               ^ *         |                               | *         bit 0                           bit 15 * * In the lsb0 encoding, it would be * *             Octet 0           Octet 1 *                         | *         p p p p p 1 1 0 | 1 0 0 0 1 1 1 1  *         ^               |               ^ *         |                               | *         bit 15                          bit 0 *//*** *** Imports ***/#include <isc/lang.h>#include <isc/types.h>ISC_LANG_BEGINDECLS/*** *** Types ***/struct isc_bitstring {	unsigned int		magic;	unsigned char *		data;	unsigned int		length;	unsigned int		size;	isc_boolean_t		lsb0;};/*** *** Functions ***/voidisc_bitstring_init(isc_bitstring_t *bitstring, unsigned char *data,		   unsigned int length, unsigned int size, isc_boolean_t lsb0);/* * Make 'bitstring' refer to the bitstring of 'size' bits starting * at 'data'.  'length' bits of the bitstring are valid.  If 'lsb0' * is set then, bit 0 refers to the least significant bit of the * bitstring.  Otherwise bit 0 is the most significant bit. * * Requires: * *	'bitstring' points to a isc_bitstring_t. * *	'data' points to an array of unsigned char large enough to hold *	'size' bits. * *	'length' <= 'size'. * * Ensures: * *	'bitstring' is a valid bitstring. */voidisc_bitstring_invalidate(isc_bitstring_t *bitstring);/* * Invalidate 'bitstring'. * * Requires: * *	'bitstring' is a valid bitstring. * * Ensures: * *	'bitstring' is not a valid bitstring. */voidisc_bitstring_copy(isc_bitstring_t *source, unsigned int sbitpos,		   isc_bitstring_t *target, unsigned int tbitpos,		   unsigned int n);/* * Starting at bit 'sbitpos', copy 'n' bits from 'source' to * the 'n' bits of 'target' starting at 'tbitpos'. * * Requires: * *	'source' and target are valid bitstrings with the same lsb0 setting. * *	'sbitpos' + 'n' is less than or equal to the length of 'source'. * *	'tbitpos' + 'n' is less than or equal to the size of 'target'. * * Ensures: * *	The specified bits have been copied, and the length of 'target' *	adjusted (if required). */ISC_LANG_ENDDECLS#endif /* ISC_BITSTRING_H */

⌨️ 快捷键说明

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