Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of BLE_WallbotBLE_Challenge by
CallChainOfFunctionPointersWithContext< ContextType > Class Template Reference
Group one or more functions in an instance of a CallChainOfFunctionPointersWithContext, then call them in sequence using CallChainOfFunctionPointersWithContext::call(). More...
#include <CallChainOfFunctionPointersWithContext.h>
| Public Member Functions | |
| CallChainOfFunctionPointersWithContext () | |
| Create an empty chain. | |
| pFunctionPointerWithContext_t | add (void(*function)(ContextType context)) | 
| Add a function at the front of the chain. | |
| template<typename T > | |
| pFunctionPointerWithContext_t | add (T *tptr, void(T::*mptr)(ContextType context)) | 
| Add a function at the front of the chain. | |
| void | clear (void) | 
| Clear the call chain (remove all functions in the chain). | |
| void | call (ContextType context) | 
| Call all the functions in the chain in sequence : the stack frames of all the callbacks within the chained FunctionPointers will stack up. | |
Detailed Description
template<typename ContextType>
 class mbed::CallChainOfFunctionPointersWithContext< ContextType >
Group one or more functions in an instance of a CallChainOfFunctionPointersWithContext, then call them in sequence using CallChainOfFunctionPointersWithContext::call().
Used mostly by the interrupt chaining code, but can be used for other purposes.
Example:
#include "mbed.h" CallChainOfFunctionPointersWithContext<void *> chain; void first(void *context) { printf("'first' function.\n"); } void second(void *context) { printf("'second' function.\n"); } class Test { public: void f(void *context) { printf("A::f (class member).\n"); } }; int main() { Test test; chain.add(second); chain.add_front(first); chain.add(&test, &Test::f); chain.call(); }
Definition at line 61 of file CallChainOfFunctionPointersWithContext.h.
Constructor & Destructor Documentation
Create an empty chain.
- Parameters:
- 
  size (optional) Initial size of the chain 
Definition at line 70 of file CallChainOfFunctionPointersWithContext.h.
Member Function Documentation
| pFunctionPointerWithContext_t add | ( | void(*)(ContextType context) | function ) | 
Add a function at the front of the chain.
- Parameters:
- 
  function A pointer to a void function 
- Returns:
- The function object created for 'function'
Definition at line 85 of file CallChainOfFunctionPointersWithContext.h.
| pFunctionPointerWithContext_t add | ( | T * | tptr, | 
| void(T::*)(ContextType context) | mptr | ||
| ) | 
Add a function at the front of the chain.
- Parameters:
- 
  tptr pointer to the object to call the member function on mptr pointer to the member function to be called 
- Returns:
- The function object created for 'tptr' and 'mptr'
Definition at line 98 of file CallChainOfFunctionPointersWithContext.h.
| void call | ( | ContextType | context ) | 
Call all the functions in the chain in sequence : the stack frames of all the callbacks within the chained FunctionPointers will stack up.
Hopefully there won't be too many chained FunctionPointers.
Definition at line 124 of file CallChainOfFunctionPointersWithContext.h.
| void clear | ( | void | ) | 
Clear the call chain (remove all functions in the chain).
Definition at line 104 of file CallChainOfFunctionPointersWithContext.h.
Generated on Tue Jul 12 2022 12:30:23 by
 1.7.2
 1.7.2 
    