GrammarScope  4.0.0
Public Member Functions | Protected Attributes | Private Member Functions | List of all members
grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices > Class Template Reference
Inheritance diagram for grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >:
Inheritance graph
[legend]
Collaboration diagram for grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >:
Collaboration graph
[legend]

Public Member Functions

 SlotAllocatorForIndexRanges ()
 
void allocate (final Collection< T > elements)
 
int getSlot (final T element)
 
- Public Member Functions inherited from grammarscope.allocator.SlotAllocatorForSequences< Integer >
 SlotAllocatorForSequences ()
 
int allocateSlot (final List< T > elements)
 
int getMaxSlot ()
 

Protected Attributes

final Map< T, Integer > slots
 

Private Member Functions

void allocateSlot (final T element)
 

Detailed Description

Vertical slot allocator for indexed ranges (each having low and index)

Constructor & Destructor Documentation

◆ SlotAllocatorForIndexRanges()

Constructor

Member Function Documentation

◆ allocate()

void grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >.allocate ( final Collection< T >  elements)

Allocate slots and cache them

Parameters
elementselements in range

◆ allocateSlot()

void grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >.allocateSlot ( final T  element)
private

Allocate slot

Parameters
elementelement

◆ getSlot()

int grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >.getSlot ( final T  element)

Get element's slot from cache

Parameters
elementelement to get slot of
Returns
this element's slot

Member Data Documentation

◆ slots

final Map<T, Integer> grammarscope.allocator.SlotAllocatorForIndexRanges< T extends HasIndices >.slots
protected

Each element has one slot map attached to it. Each slot is represented by one bit in the slot map (0 to 63 slots)


The documentation for this class was generated from the following file: