The Include, Parser, and Python directories from the cPython 2.7.10 distribution. These files are unchanged and set the baseline for subsequent commits. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Daryl McDaniel <edk2-lists@mc2research.org> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18737 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
 | |
| /* Bitset primitives used by the parser generator */
 | |
| 
 | |
| #include "pgenheaders.h"
 | |
| #include "bitset.h"
 | |
| 
 | |
| bitset
 | |
| newbitset(int nbits)
 | |
| {
 | |
|     int nbytes = NBYTES(nbits);
 | |
|     bitset ss = (char *)PyObject_MALLOC(sizeof(BYTE) *  nbytes);
 | |
| 
 | |
|     if (ss == NULL)
 | |
|         Py_FatalError("no mem for bitset");
 | |
| 
 | |
|     ss += nbytes;
 | |
|     while (--nbytes >= 0)
 | |
|         *--ss = 0;
 | |
|     return ss;
 | |
| }
 | |
| 
 | |
| void
 | |
| delbitset(bitset ss)
 | |
| {
 | |
|     PyObject_FREE(ss);
 | |
| }
 | |
| 
 | |
| int
 | |
| addbit(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(bitset ss, int ibit)
 | |
| {
 | |
|     return (ss[BIT2BYTE(ibit)] & BIT2MASK(ibit)) != 0;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| int
 | |
| samebitset(bitset ss1, bitset ss2, int nbits)
 | |
| {
 | |
|     int i;
 | |
| 
 | |
|     for (i = NBYTES(nbits); --i >= 0; )
 | |
|         if (*ss1++ != *ss2++)
 | |
|             return 0;
 | |
|     return 1;
 | |
| }
 | |
| 
 | |
| void
 | |
| mergebitset(bitset ss1, bitset ss2, int nbits)
 | |
| {
 | |
|     int i;
 | |
| 
 | |
|     for (i = NBYTES(nbits); --i >= 0; )
 | |
|         *ss1++ |= *ss2++;
 | |
| }
 |