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

📄 idset.c

📁 代码检索工具GLOBAL源码。可用来浏览分析LINUX源码。
💻 C
字号:
/* * Copyright (c) 2005 Tama Communications Corporation * * This file is part of GNU GLOBAL. * * GNU GLOBAL is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * GNU GLOBAL is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA. */#ifdef HAVE_CONFIG_H#include <config.h>#endif#include <stdlib.h>#ifdef HAVE_LIMITS_H#include <limits.h>#endif#include "die.h"#include "idset.h"/*Idset: usage and memory status				idset->set				[]				 00000000  00111111  11112222				 01234567  89012345  67890123idset = idset_open(21)		[00000000][00000000][00000___](3bytes)				  vidset_add(idset, 1)		[01000000][00000000][00000___]				   vidset_add(idset, 2)		[01100000][00000000][00000___]				                         vidset_add(idset, 20)		[01100000][00000000][00001___]idset_contains(idset, 2) == trueidset_contains(idset, 3) == falseidset_close(idset)		[] *//* * Allocate memory for new idset. */IDSET *idset_open(size)	unsigned int size;{	IDSET *idset = malloc(sizeof(IDSET));	if (idset == NULL)		die("short of memory.");	idset->set = (unsigned char *)calloc((size + CHAR_BIT - 1) / CHAR_BIT, 1);	if (idset->set == NULL)		die("short of memory.");	idset->max = 0;	idset->size = size;	return idset;}/* * Add id to the idset. * *	i)	idset	idset structure *	i)	id	id number */voididset_add(idset, id)	IDSET *idset;	unsigned int id;{	if (id >= idset->size)		die("idset_add: id is out of range.");	idset->set[id / CHAR_BIT] |= 1 << (id % CHAR_BIT);	if (id >= idset->max)		idset->max = id + 1;}/* * Whether or not idset includes specified id. * *	i)	idset	idset structure *	i)	id	id number *	r)		true: contains, false: doesn't contain */intidset_contains(idset, id)	IDSET *idset;	unsigned int id;{	return (id >= idset->max) ? 0 :			(idset->set[id / CHAR_BIT] & (1 << (id % CHAR_BIT)));}/* * Return bits of idset. * *	i)	idset	idset structure *	r)		number of bits */intidset_count(idset)	IDSET *idset;{	int id, count = 0;	for (id = 0; id < idset->max; id++)		if (idset->set[id / CHAR_BIT] & (1 << (id % CHAR_BIT)))			count++;	return count;}/* * Free memory for the idset. */voididset_close(idset)	IDSET *idset;{	free(idset->set);	free(idset);}

⌨️ 快捷键说明

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