Skip to content

Latest commit

 

History

History
101 lines (71 loc) · 3.79 KB

README.md

File metadata and controls

101 lines (71 loc) · 3.79 KB

Oryol Container Classes

Oryol has it's own set of container classes which don't use exception, are easier to debug and allow better tweaking for Oryol's requirements than the C++ std library container classes.

Buffer

The Buffer class is a simple dynamic container for an 'untyped' memory chunk on the heap. When the Buffer object is deleted, the heap data will be freed. A Buffer object cannot be copied, only moved. This is to prevent accidential expensive memory allocation and duplicate data copies.

See the Buffer Unit Test for usage examples code.

StaticArray<TYPE>

A StaticArray is a a constant-size C-style array with bounds-checking (similar to the new std::array in C++11). Use this in places where you would use a C array, but want to have bounds-checking performed. However keep in mind that the bounds-checks are only performed in debug mode, not in (optimized) release mode!

For StaticArray code samples, see the Unit Test.

Array<TYPE>

The Array class is a dynamic, linear container similar to std::vector, but doesn't use exceptions for error reporting, has more control over allocation behaviour, and is easier to debug since it doesn't go quite as crazy with template metaprogramming.

See the Array Header File and Array Unit Test for more information and code samples.

Map<KEYTYPE,VALUETYPE>

The Map class is Oryol's version of std::map, with one important difference: trying to access an element with operator[] creates a fatal error if the element doesn't exists (instead of adding a new element like std::map).

Check out the Map Header File and Unit Test for more information and code samples.

ArrayMap<KEYTYPE,VALUETYPE>

The ArrayMap class combines features of the Array and Map class. It keeps value-items in a separate Array in the order they were added, but also allows a fast key-lookup by maintaining a separate Map which maps keys to array indices. The downsides are:

  • value and key items live in 2 separate heap memory chunks
  • Erase() operations are fairly slow

Use an ArrayMap if:

  • you need to preserve the original order in which items were added
  • or if the value-type is expensive to move, since adding new elements will never involve moving value objects around

For more info, see the ArrayMap Header File, and for code samples see the ArrayMap Unit Test.

Queue<TYPE>

This is a simple FIFO queue on top of a dynamic array. See the Header File and Unit Test for more information.

Set<TYPE>

This is a dynamic, sorted array which only allows adding unique elements. trying to add an identical item twice results in a fatal runtime error.

See the Header File and Unit Test for more information.

InlineArray<TYPE,CAPACITY>

The InlineArray class is similar to the Array class but doesn't allocate memory from the heap. The max capacity is fixed and must be provided as a template argument. A fatal runtime error will be thrown when attempting to add new items to a full array.

Slice<TYPE>

A Slice is an array without its own data, instead it provides an array-like interface to a chunk of non-owned memory. The same concept also exists under different names, like array-views or ranges.

NOTE: Since Slices do not own the memory they are pointing to, they are potentially dangerous to use. The underlying memory may have been moved or freed (similar to how iterators are affected by iterator-invalidation). Either make sure that the items referenced by Slices are 'pinned' into place, or use Slices only as a short-lived, transient reference.