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 mbed-src by
CallChain.h
00001 /* mbed Microcontroller Library 00002 * Copyright (c) 2006-2013 ARM Limited 00003 * 00004 * Licensed under the Apache License, Version 2.0 (the "License"); 00005 * you may not use this file except in compliance with the License. 00006 * You may obtain a copy of the License at 00007 * 00008 * http://www.apache.org/licenses/LICENSE-2.0 00009 * 00010 * Unless required by applicable law or agreed to in writing, software 00011 * distributed under the License is distributed on an "AS IS" BASIS, 00012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00013 * See the License for the specific language governing permissions and 00014 * limitations under the License. 00015 */ 00016 #ifndef MBED_CALLCHAIN_H 00017 #define MBED_CALLCHAIN_H 00018 00019 #include "FunctionPointer.h" 00020 #include <string.h> 00021 00022 namespace mbed { 00023 00024 /** Group one or more functions in an instance of a CallChain, then call them in 00025 * sequence using CallChain::call(). Used mostly by the interrupt chaining code, 00026 * but can be used for other purposes. 00027 * 00028 * Example: 00029 * @code 00030 * #include "mbed.h" 00031 * 00032 * CallChain chain; 00033 * 00034 * void first(void) { 00035 * printf("'first' function.\n"); 00036 * } 00037 * 00038 * void second(void) { 00039 * printf("'second' function.\n"); 00040 * } 00041 * 00042 * class Test { 00043 * public: 00044 * void f(void) { 00045 * printf("A::f (class member).\n"); 00046 * } 00047 * }; 00048 * 00049 * int main() { 00050 * Test test; 00051 * 00052 * chain.add(second); 00053 * chain.add_front(first); 00054 * chain.add(&test, &Test::f); 00055 * chain.call(); 00056 * } 00057 * @endcode 00058 */ 00059 00060 typedef FunctionPointer* pFunctionPointer_t; 00061 00062 class CallChain { 00063 public: 00064 /** Create an empty chain 00065 * 00066 * @param size (optional) Initial size of the chain 00067 */ 00068 CallChain(int size = 4); 00069 virtual ~CallChain(); 00070 00071 /** Add a function at the end of the chain 00072 * 00073 * @param function A pointer to a void function 00074 * 00075 * @returns 00076 * The function object created for 'function' 00077 */ 00078 pFunctionPointer_t add(void (*function)(void)); 00079 00080 /** Add a function at the end of the chain 00081 * 00082 * @param tptr pointer to the object to call the member function on 00083 * @param mptr pointer to the member function to be called 00084 * 00085 * @returns 00086 * The function object created for 'tptr' and 'mptr' 00087 */ 00088 template<typename T> 00089 pFunctionPointer_t add(T *tptr, void (T::*mptr)(void)) { 00090 return common_add(new FunctionPointer(tptr, mptr)); 00091 } 00092 00093 /** Add a function at the beginning of the chain 00094 * 00095 * @param function A pointer to a void function 00096 * 00097 * @returns 00098 * The function object created for 'function' 00099 */ 00100 pFunctionPointer_t add_front(void (*function)(void)); 00101 00102 /** Add a function at the beginning of the chain 00103 * 00104 * @param tptr pointer to the object to call the member function on 00105 * @param mptr pointer to the member function to be called 00106 * 00107 * @returns 00108 * The function object created for 'tptr' and 'mptr' 00109 */ 00110 template<typename T> 00111 pFunctionPointer_t add_front(T *tptr, void (T::*mptr)(void)) { 00112 return common_add_front(new FunctionPointer(tptr, mptr)); 00113 } 00114 00115 /** Get the number of functions in the chain 00116 */ 00117 int size() const; 00118 00119 /** Get a function object from the chain 00120 * 00121 * @param i function object index 00122 * 00123 * @returns 00124 * The function object at position 'i' in the chain 00125 */ 00126 pFunctionPointer_t get(int i) const; 00127 00128 /** Look for a function object in the call chain 00129 * 00130 * @param f the function object to search 00131 * 00132 * @returns 00133 * The index of the function object if found, -1 otherwise. 00134 */ 00135 int find(pFunctionPointer_t f) const; 00136 00137 /** Clear the call chain (remove all functions in the chain). 00138 */ 00139 void clear(); 00140 00141 /** Remove a function object from the chain 00142 * 00143 * @arg f the function object to remove 00144 * 00145 * @returns 00146 * true if the function object was found and removed, false otherwise. 00147 */ 00148 bool remove(pFunctionPointer_t f); 00149 00150 /** Call all the functions in the chain in sequence 00151 */ 00152 void call(); 00153 00154 #ifdef MBED_OPERATORS 00155 void operator ()(void) { 00156 call(); 00157 } 00158 pFunctionPointer_t operator [](int i) const { 00159 return get(i); 00160 } 00161 #endif 00162 00163 private: 00164 void _check_size(); 00165 pFunctionPointer_t common_add(pFunctionPointer_t pf); 00166 pFunctionPointer_t common_add_front(pFunctionPointer_t pf); 00167 00168 pFunctionPointer_t* _chain; 00169 int _size; 00170 int _elements; 00171 00172 /* disallow copy constructor and assignment operators */ 00173 private: 00174 CallChain(const CallChain&); 00175 CallChain & operator = (const CallChain&); 00176 }; 00177 00178 } // namespace mbed 00179 00180 #endif 00181
Generated on Fri Jul 15 2022 02:25:50 by
