“Algorithms + Data Structures = Programs.”
Fusion is a library for working with heterogeneous collections of data, commonly referred to as tuples. A set of containers (vector, list, set and map) is provided, along with views that provide a transformed presentation of their underlying data. Collectively the containers and views are referred to as sequences, and Fusion has a suite of algorithms that operate upon the various sequence types, using an iterator concept that binds everything together.
Tuples are powerful beasts. After having developed two significant projects (Spirit and Phoenix) that relied heavily metaprogramming, it became apparent that tuples are a powerful means to simplify otherwise tricky tasks; especially those that require a combination of metaprogramming and manipulation of heterogeneous data types with values. While MPL is an extremely powerful metaprogramming tool, MPL focuses on type manipulation only. Ultimately, you'll have to map these types to real values to make them useful in the runtime world where all the real action takes place.
As Spirit and Phoenix evolved, patterns and idioms related to tuple manipulation emerged. Soon, it became clear that those patterns and idioms were best assembled in a tuples algorithms library. David Abrahams outlined such a scheme in 2002. At that time, it just so happened that Spirit and Phoenix had an adhoc collection of tuple manipulation and traversal routines. It was an instant AHA! moment.
Some icons are used to mark certain topics indicative of their relevance. These icons precede some text to indicate:
Information provided is auxiliary but will give the reader a deeper insight into a specific topic. May be skipped.
Information provided is of utmost importance.
A mild warning.
A potentially useful and helpful piece of information.
This documentation is automatically generated by Boost QuickBook documentation tool. QuickBook can be found in the Boost Tools.