/* * Copyright (c) 2007 Mockito contributors * This program is made available under the terms of the MIT License. */ package org.powermock.api.mockito.repackaged.cglib.core; public class TinyBitSet { private static int[] T = new int[256]; static { for(int j = 0; j < 256; j++) { T[j] = gcount(j); } } private int value = 0; private static int gcount(int x) { int c = 0; while (x != 0) { c++; x &= (x - 1); } return c; } private static int topbit(int i) { int j; for (j = 0; i != 0; i ^= j) { j = i & -i; } return j; } private static int log2(int i) { int j = 0; for (j = 0; i != 0; i >>= 1) { j++; } return j; } public int length() { return log2(topbit(value)); } public int cardinality() { int w = value; int c = 0; while (w != 0) { c += T[w & 255]; w >>= 8; } return c; } public boolean get(int index) { return (value & (1 << index)) != 0; } public void set(int index) { value |= (1 << index); } public void clear(int index) { value &= ~(1 << index); } }