mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 10:26:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			106 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***********************************************************
 | |
| Copyright 1991-1995 by Stichting Mathematisch Centrum, Amsterdam,
 | |
| The Netherlands.
 | |
| 
 | |
|                         All Rights Reserved
 | |
| 
 | |
| Permission to use, copy, modify, and distribute this software and its
 | |
| documentation for any purpose and without fee is hereby granted,
 | |
| provided that the above copyright notice appear in all copies and that
 | |
| both that copyright notice and this permission notice appear in
 | |
| supporting documentation, and that the names of Stichting Mathematisch
 | |
| Centrum or CWI or Corporation for National Research Initiatives or
 | |
| CNRI not be used in advertising or publicity pertaining to
 | |
| distribution of the software without specific, written prior
 | |
| permission.
 | |
| 
 | |
| While CWI is the initial source for this software, a modified version
 | |
| is made available by the Corporation for National Research Initiatives
 | |
| (CNRI) at the Internet address ftp://ftp.python.org.
 | |
| 
 | |
| STICHTING MATHEMATISCH CENTRUM AND CNRI DISCLAIM ALL WARRANTIES WITH
 | |
| REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF
 | |
| MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH
 | |
| CENTRUM OR CNRI BE LIABLE FOR ANY SPECIAL, 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.
 | |
| 
 | |
| ******************************************************************/
 | |
| 
 | |
| /* Bitset primitives used by the parser generator */
 | |
| 
 | |
| #include "pgenheaders.h"
 | |
| #include "bitset.h"
 | |
| 
 | |
| bitset
 | |
| newbitset(nbits)
 | |
| 	int nbits;
 | |
| {
 | |
| 	int nbytes = NBYTES(nbits);
 | |
| 	bitset ss = PyMem_NEW(BYTE, nbytes);
 | |
| 	
 | |
| 	if (ss == NULL)
 | |
| 		Py_FatalError("no mem for bitset");
 | |
| 	
 | |
| 	ss += nbytes;
 | |
| 	while (--nbytes >= 0)
 | |
| 		*--ss = 0;
 | |
| 	return ss;
 | |
| }
 | |
| 
 | |
| void
 | |
| delbitset(ss)
 | |
| 	bitset ss;
 | |
| {
 | |
| 	PyMem_DEL(ss);
 | |
| }
 | |
| 
 | |
| int
 | |
| addbit(ss, ibit)
 | |
| 	bitset ss;
 | |
| 	int ibit;
 | |
| {
 | |
| 	int ibyte = BIT2BYTE(ibit);
 | |
| 	BYTE mask = BIT2MASK(ibit);
 | |
| 	
 | |
| 	if (ss[ibyte] & mask)
 | |
| 		return 0; /* Bit already set */
 | |
| 	ss[ibyte] |= mask;
 | |
| 	return 1;
 | |
| }
 | |
| 
 | |
| #if 0 /* Now a macro */
 | |
| int
 | |
| testbit(ss, ibit)
 | |
| 	bitset ss;
 | |
| 	int ibit;
 | |
| {
 | |
| 	return (ss[BIT2BYTE(ibit)] & BIT2MASK(ibit)) != 0;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| int
 | |
| samebitset(ss1, ss2, nbits)
 | |
| 	bitset ss1, ss2;
 | |
| 	int nbits;
 | |
| {
 | |
| 	int i;
 | |
| 	
 | |
| 	for (i = NBYTES(nbits); --i >= 0; )
 | |
| 		if (*ss1++ != *ss2++)
 | |
| 			return 0;
 | |
| 	return 1;
 | |
| }
 | |
| 
 | |
| void
 | |
| mergebitset(ss1, ss2, nbits)
 | |
| 	bitset ss1, ss2;
 | |
| 	int nbits;
 | |
| {
 | |
| 	int i;
 | |
| 	
 | |
| 	for (i = NBYTES(nbits); --i >= 0; )
 | |
| 		*ss1++ |= *ss2++;
 | |
| }
 | 
